/* ============================================
   À PROPOS — Editorial layout
   ============================================ */

/* HEADER */
.ap-header {
  padding-top: clamp(7rem, 12vw, 10rem);
  padding-bottom: clamp(3rem, 6vw, 4rem);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.ap-header-inner {
  display: flex; flex-direction: column; align-items: center;
  gap: 1.25rem;
}
.ap-header .eyebrow { justify-content: center; }
.ap-h1 {
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  letter-spacing: -0.02em;
  max-width: 16ch;
  margin-block: 0.5rem 0.5rem;
  line-height: 1.04;
}
.ap-sub {
  font-size: clamp(15px, 1.6vw, 18px);
  color: var(--ink-2);
  max-width: 62ch;
  line-height: 1.65;
  text-align: center;
  margin: 0 auto;
}
.ap-header-meta {
  display: flex; gap: 0.5rem 1rem; justify-content: center;
  flex-wrap: wrap;
  padding-top: 2rem;
  font-family: var(--mono);
  font-size: 11.5px;
  letter-spacing: 0.06em;
  color: var(--ink-3);
}
.ap-sep { color: var(--line-strong); }

/* PORTRAIT SECTION */
.ap-portrait-sec {
  padding-block: clamp(3rem, 6vw, 5rem);
}
.ap-portrait-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
}
.ap-portrait {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--brand-soft);
  aspect-ratio: 4 / 5;
}
.ap-portrait img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.35) contrast(1.05);
}
.ap-portrait::after {
  content: '';
  position: absolute; inset: auto 0 0 0;
  height: 30%;
  background: linear-gradient(180deg, transparent, oklch(0 0 0 / 0.45));
  pointer-events: none;
}
.ap-portrait figcaption {
  position: absolute;
  left: 1.25rem; bottom: 1.25rem;
  color: oklch(0.98 0.005 70);
  display: flex; flex-direction: column; gap: 4px;
  z-index: 1;
}
.apf-name {
  font-family: var(--serif);
  font-size: 1.3rem;
}
.apf-role {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: oklch(0.85 0.04 25);
}
.ap-portrait-text .eyebrow { margin-bottom: 1rem; }
.ap-h2 {
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.015em;
  margin-bottom: 1.5rem;
  max-width: 18ch;
  line-height: 1.05;
}
.ap-lead {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(1.15rem, 1.8vw, 1.4rem);
  line-height: 1.5;
  color: var(--ink);
  margin-bottom: 1.25rem;
  max-width: 38ch;
}
.ap-lead strong { font-weight: 500; color: var(--brand-ink); font-style: italic; }
.ap-portrait-text p {
  font-size: 16px;
  line-height: 1.7;
  max-width: 52ch;
}

/* PILLARS */
.ap-pillars { padding-block: clamp(4rem, 8vw, 6rem); }
.pillars-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2vw, 1.75rem);
}
.pillar {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 2.5vw, 2rem);
  display: flex; flex-direction: column; gap: 1rem;
  transition: transform 0.2s, border-color 0.2s;
}
.pillar:hover { transform: translateY(-3px); border-color: var(--brand-line); }
.pillar-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 2.2rem;
  color: var(--brand);
  line-height: 1;
}
.pillar h3 {
  font-size: 1.25rem;
  margin-bottom: 0;
}
.pillar p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-2);
}

/* BIO */
.ap-bio-sec {
  padding-block: clamp(4rem, 8vw, 6.5rem);
}
.ap-bio-grid {
  display: grid;
  grid-template-columns: 0.7fr 1.3fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.ap-bio-card {
  position: sticky;
  top: 5rem;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(1.5rem, 3vw, 2rem);
  display: flex; flex-direction: column; gap: 0.75rem;
}
.ap-bio-avatar {
  width: 64px; height: 64px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%);
  color: #fff;
  display: grid; place-items: center;
  font-family: var(--serif);
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}
.ap-bio-name {
  font-family: var(--serif);
  font-size: 1.5rem;
  color: var(--ink);
}
.ap-bio-role {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 1rem;
}
.ap-bio-meta {
  display: flex; flex-direction: column;
  margin-block: 0.5rem 1rem;
  border-top: 1px solid var(--line);
}
.ap-bio-meta div {
  display: flex; flex-direction: column;
  padding-block: 0.75rem;
  border-bottom: 1px solid var(--line);
}
.ap-bio-meta dt {
  font-family: var(--mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-3);
  margin-bottom: 4px;
}
.ap-bio-meta dd {
  font-size: 14.5px;
  color: var(--ink);
  font-weight: 500;
}

.ap-bio-text .eyebrow { margin-bottom: 1.25rem; }
.ap-bio-text h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  margin-bottom: 2rem;
}
.ap-bio-text p {
  font-size: 16.5px;
  line-height: 1.75;
  margin-bottom: 1.5rem;
  max-width: 60ch;
  color: var(--ink-2);
}
.ap-bio-text p strong {
  color: var(--ink);
  font-weight: 500;
}
.ap-bio-text p:first-of-type::first-letter {
  font-family: var(--serif);
  font-size: 3.5em;
  line-height: 0.85;
  float: left;
  margin: 0.05em 0.12em 0 0;
  color: var(--brand-ink);
  font-weight: 400;
}
.ap-signature {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--brand-ink);
  margin-top: 2rem !important;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}

/* TRUST GRID */
.ap-trust-sec { padding-block: clamp(4rem, 8vw, 6rem); }
.trust-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.trust-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 1.5rem;
  padding-block: clamp(1.5rem, 3vw, 2rem);
  border-bottom: 1px solid var(--line);
  align-items: start;
}
.trust-row:nth-child(odd) { padding-right: clamp(1.5rem, 3vw, 2.5rem); border-right: 1px solid var(--line); }
.trust-row:nth-child(even) { padding-left: clamp(1.5rem, 3vw, 2.5rem); }
.tr-n {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--brand);
  letter-spacing: 0.05em;
  padding-top: 4px;
}
.trust-row h4 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}
.trust-row p {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--ink-2);
  max-width: 42ch;
}

/* CTA */
.ap-cta {
  padding-block: clamp(4rem, 8vw, 6rem);
  position: relative;
  overflow: hidden;
  background: var(--bg-soft);
  border-top: 1px solid var(--line);
}
.ap-cta-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.ap-cta-wash {
  position: absolute;
  inset: 30% 0 0 0;
  background:
    radial-gradient(ellipse 70% 80% at 50% 100%, oklch(0.94 0.04 25 / 0.55), transparent 70%);
}
.ap-cta-hairlines {
  position: absolute;
  inset: auto 0 0 0;
  height: 30%;
  display: flex; flex-direction: column;
  justify-content: flex-end;
  gap: 16px;
  padding-bottom: 14px;
}
.ap-cta-hairlines span {
  display: block;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    oklch(0.55 0.16 25 / 0.20) 25%,
    oklch(0.55 0.16 25 / 0.20) 75%,
    transparent 100%);
}
.ap-cta-hairlines span:nth-child(1) { width: 80%; margin: 0 auto; opacity: 0.5; }
.ap-cta-hairlines span:nth-child(2) { width: 92%; margin: 0 auto; opacity: 0.7; }
.ap-cta-hairlines span:nth-child(3) { width: 100%; opacity: 1; background: linear-gradient(90deg, transparent, oklch(0.55 0.16 25 / 0.32) 50%, transparent); }
.ap-cta-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: 1.25rem;
}
.ap-cta-inner .eyebrow { justify-content: center; }
.ap-cta-h {
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  color: var(--ink);
  max-width: 22ch;
  letter-spacing: -0.018em;
  line-height: 1.04;
}
.ap-cta-h em { color: var(--brand-ink); font-style: italic; }
.ap-cta-inner p {
  color: var(--ink-2);
  font-size: clamp(15px, 1.5vw, 17px);
  max-width: 58ch;
  line-height: 1.65;
  text-align: center;
}
.ap-cta-actions {
  display: flex; gap: 1.5rem; align-items: center;
  flex-wrap: wrap; justify-content: center;
  margin-top: 1rem;
}

/* RESPONSIVE */
@media (max-width: 1024px) {
  .ap-portrait-grid, .ap-bio-grid { grid-template-columns: 1fr; }
  .ap-bio-card { position: static; }
  .pillars-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .pillars-grid, .trust-grid { grid-template-columns: 1fr; }
  .trust-row:nth-child(odd), .trust-row:nth-child(even) { border-right: none; padding-inline: 0; }
  .trust-row { grid-template-columns: 50px 1fr; gap: 1rem; }
  .ap-portrait { aspect-ratio: 4 / 4; }
}
