/* =====================================================================
   sections-about.css
   Snippets spécifiques à /about (page institutionnelle).
   Charge APRÈS theme.css + sections-pillar.css.
     .s_hero_about         → hero éditorial avec monogrammes AT/OB
     .c-founder-card       → card fondateur avec mini-grille 3 chiffres
     .s_genesis            → récit + encadré citation sticky
     .s_convictions        → 5 convictions en grille 3+2
     .s_vision             → manifest + bandeau 3 chiffres-clés
     .s_cta_about          → CTA centré sur fond --navy
   Le manifesto fondateur (S02) réutilise .s_pillar_manifest sans modif.
   ===================================================================== */


/* =====================================================================
   S_HERO_ABOUT — hero éditorial, 2 colonnes desktop
   ===================================================================== */

.s_hero_about {
  position: relative;
  background: var(--canvas);
  padding-top: var(--s-9);
  padding-bottom: var(--s-10); /* 128px desktop */
  overflow: hidden;
}
@media (max-width: 1023px) {
  .s_hero_about { padding-bottom: var(--s-9); /* 96px tablet */ }
}
@media (max-width: 767px) {
  .s_hero_about { padding-top: var(--s-7); padding-bottom: var(--s-8); /* 64px mobile */ }
}

.s_hero_about__inner {
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--gutter-desktop);
  align-items: center;
}
@media (max-width: 1023px) { .s_hero_about__inner { grid-template-columns: repeat(6, 1fr); gap: var(--gutter-tablet); } }
@media (max-width: 767px)  { .s_hero_about__inner { grid-template-columns: repeat(4, 1fr); gap: var(--gutter-mobile); } }

.s_hero_about__inner > .l-pillar-hero__breadcrumb,
.s_hero_about__inner > .l-pillar-hero__meta {
  grid-column: 1 / -1;
}

.s_hero_about__title {
  grid-column: 1 / span 7;
  font-weight: 400;
  font-size: clamp(40px, 6vw, 84px);
  letter-spacing: -0.04em;
  line-height: 1.02;
  color: var(--text-strong);
  margin-bottom: var(--s-6);
}
.s_hero_about__title .serif-em {
  color: var(--orange);
  padding: 0 0.04em;
  font-size: 1.05em;
  letter-spacing: -0.02em;
}
@media (max-width: 1023px) { .s_hero_about__title { grid-column: 1 / -1; } }

.s_hero_about__lead {
  grid-column: 1 / span 6;
  font-size: clamp(17px, 1.3vw, 20px);
  line-height: 1.55;
  color: var(--text-mid);
  max-width: 60ch;
}
@media (max-width: 1023px) { .s_hero_about__lead { grid-column: 1 / -1; } }

/* Visuel à droite — 2 monogrammes XL séparés par un trait orange vertical */
.s_hero_about__visual {
  grid-column: 9 / span 4;
  grid-row: 3 / span 2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-5);
  align-self: center;
}
@media (max-width: 1023px) {
  .s_hero_about__visual {
    grid-column: 1 / -1;
    grid-row: auto;
    margin-top: var(--s-7);
  }
}
@media (max-width: 767px) {
  .s_hero_about__visual {
    flex-direction: column;
    gap: var(--s-4);
  }
}

.s_hero_about__divider {
  display: block;
  width: 1px;
  height: 80px;
  background: var(--orange);
  flex-shrink: 0;
}
@media (max-width: 1023px) {
  .s_hero_about__divider { height: 60px; }
}
@media (max-width: 767px) {
  .s_hero_about__divider { width: 60px; height: 1px; }
}


/* =====================================================================
   S_FOUNDERS_DUO — 2 cards fondateurs avec mini-grille de 3 chiffres
   ===================================================================== */

.s_founders_duo {
  background: var(--canvas);
}

.s_founders_duo__head {
  grid-column: 1 / span 9;
  margin-bottom: var(--s-8);
}
.s_founders_duo__head h2 { margin-top: var(--s-4); }
.s_founders_duo__head p { margin-top: var(--s-5); max-width: 56ch; }
@media (max-width: 1023px) {
  .s_founders_duo__head { grid-column: 1 / -1; margin-bottom: var(--s-6); }
}

.s_founders_duo__list {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7);
  align-items: stretch;
}
@media (max-width: 1023px) {
  .s_founders_duo__list { grid-template-columns: 1fr; gap: var(--s-6); }
}

.c-founder-card {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding: var(--s-7);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}
@media (max-width: 767px) {
  .c-founder-card { padding: var(--s-6); }
}

.c-founder-card__monogram-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: var(--s-5);
}

.c-founder-card__eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--orange);
}
.c-founder-card__eyebrow .mono { color: var(--orange); }

.c-founder-card__name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 32px;
  letter-spacing: -0.02em;
  color: var(--navy);
  margin: var(--s-2) 0 0;
  line-height: 1.05;
}

.c-founder-card__role {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
  margin-bottom: var(--s-5);
}

.c-founder-card__bio {
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-mid);
  margin: 0;
  max-width: 50ch;
}

.c-founder-card__quote {
  margin-top: var(--s-6);
  padding-top: var(--s-6);
  border-top: 1px solid var(--line);
}
.c-founder-card__quote blockquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  line-height: 1.35;
  color: var(--navy);
  margin: 0;
}
.c-founder-card__quote-attr {
  display: block;
  margin-top: var(--s-4);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.c-founder-card__kpis {
  margin-top: var(--s-6);
  padding-top: var(--s-6);
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.c-founder-card__kpi {
  padding: 0 var(--s-3);
  border-right: 1px solid var(--line);
}
.c-founder-card__kpi:first-child { padding-left: 0; }
.c-founder-card__kpi:last-child { border-right: none; padding-right: 0; }

@media (max-width: 767px) {
  /* Mobile : empilage vertical 1 col, séparateurs horizontaux 1px --line */
  .c-founder-card__kpis {
    grid-template-columns: 1fr;
  }
  .c-founder-card__kpi {
    padding: 20px 0;
    border-right: none;
    border-top: 1px solid var(--line);
  }
  .c-founder-card__kpi:first-child {
    padding-top: 0;
    border-top: none;
  }
  .c-founder-card__kpi:last-child {
    padding-bottom: 0;
  }
}

.c-founder-card__kpi-value {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: 32px;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--navy);
}
.c-founder-card__kpi-label {
  margin-top: var(--s-2);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
  line-height: 1.4;
}


/* =====================================================================
   S_GENESIS — récit asymétrique + encadré citation sticky
   ===================================================================== */

.s_genesis {
  background: var(--canvas-warm);
  border-top: 1px solid var(--line);
}

.s_genesis__head {
  grid-column: 1 / span 9;
  margin-bottom: var(--s-8);
}
.s_genesis__head h2 { margin-top: var(--s-4); }
@media (max-width: 1023px) {
  .s_genesis__head { grid-column: 1 / -1; margin-bottom: var(--s-6); }
}

.s_genesis__body {
  grid-column: 2 / span 7;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  font-size: 17px;
  line-height: 1.6;
  color: var(--text-mid);
}
.s_genesis__body p { margin: 0; max-width: 64ch; }
.s_genesis__body strong { font-weight: 600; color: var(--navy); }
.s_genesis__body em { font-style: italic; }
@media (max-width: 1023px) {
  .s_genesis__body { grid-column: 1 / -1; }
}

.s_genesis__quote {
  grid-column: 9 / span 4;
  align-self: start;
  position: sticky;
  top: var(--s-9);
  padding: var(--s-6);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}
.s_genesis__quote blockquote {
  margin: 0;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 24px;
  line-height: 1.3;
  color: var(--navy);
}
.s_genesis__quote-attr {
  display: block;
  margin-top: var(--s-5);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
}
@media (max-width: 1023px) {
  .s_genesis__quote {
    grid-column: 1 / -1;
    position: static;
    margin-top: var(--s-6);
  }
}


/* =====================================================================
   S_CONVICTIONS — 5 convictions en grille 3+2 (centrage visuel ligne 2)
   ===================================================================== */

.s_convictions {
  background: var(--canvas);
}

.s_convictions__head {
  grid-column: 1 / span 9;
  margin-bottom: var(--s-8);
}
.s_convictions__head h2 { margin-top: var(--s-4); }
.s_convictions__head p { margin-top: var(--s-5); max-width: 60ch; }
@media (max-width: 1023px) {
  .s_convictions__head { grid-column: 1 / -1; margin-bottom: var(--s-6); }
}

/* Desktop ≥ 1024px : 5 colonnes égales sur une seule ligne, alignées sur la
   même baseline. Tablet : 3+2 alignées à gauche (auto-flow naturel).
   Mobile : 1 colonne empilée. */
.s_convictions__list {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-7) var(--gutter-desktop);
}
.s_convictions__list > .c-conviction { grid-column: auto; }

@media (max-width: 1023px) {
  .s_convictions__list {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s-6) var(--gutter-tablet);
  }
}
@media (max-width: 767px) {
  .s_convictions__list { grid-template-columns: 1fr; gap: var(--s-6); }
}

.c-conviction {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.c-conviction__num {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: clamp(40px, 4vw, 56px);
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--navy);
}
.c-conviction__title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.015em;
  line-height: 1.3;
  color: var(--navy);
  margin-top: var(--s-3);
}
.c-conviction__desc {
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-mid);
  margin: 0;
}
.c-conviction__desc strong { font-weight: 600; color: var(--navy); }


/* =====================================================================
   S_VISION — manifest + bandeau 3 chiffres-clés
   ===================================================================== */

.s_vision {
  background: var(--canvas-warm);
  border-top: 1px solid var(--line);
}

.s_vision__eyebrow {
  grid-column: 1 / span 3;
  grid-row: 1;
}
@media (max-width: 1023px) { .s_vision__eyebrow { grid-column: 1 / -1; } }

.s_vision__title {
  grid-column: 5 / span 7;
  grid-row: 1;
  font-weight: 500;
  font-size: clamp(32px, 4vw, 56px);
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--text-strong);
}
.s_vision__title .serif-em {
  color: var(--orange);
  padding: 0 0.04em;
  font-size: 1.05em;
  letter-spacing: -0.02em;
}
@media (max-width: 1023px) {
  .s_vision__title { grid-column: 1 / -1; grid-row: auto; }
}

.s_vision__body {
  grid-column: 3 / span 8;
  grid-row: 2;
  margin-top: var(--s-7);
  font-size: clamp(16px, 1.2vw, 18px);
  line-height: 1.7;
  color: var(--text-mid);
  max-width: 70ch;
}
@media (max-width: 1023px) {
  .s_vision__body { grid-column: 1 / -1; grid-row: auto; margin-top: 0; }
}

.s_vision__kpis {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: var(--s-9);
  padding-top: var(--s-8);
  border-top: 1px solid var(--line);
}
@media (max-width: 767px) {
  .s_vision__kpis {
    grid-template-columns: 1fr;
    margin-top: var(--s-7);
  }
}

.s_vision__kpi {
  padding: 0 var(--s-5);
  border-right: 1px solid var(--line);
}
.s_vision__kpi:first-child { padding-left: 0; }
.s_vision__kpi:last-child { border-right: none; padding-right: 0; }
@media (max-width: 767px) {
  .s_vision__kpi {
    border-right: none;
    border-bottom: 1px solid var(--line);
    padding: var(--s-5) 0;
  }
  .s_vision__kpi:first-child { padding-top: 0; }
  .s_vision__kpi:last-child { border-bottom: none; padding-bottom: 0; }
}

.s_vision__kpi-value {
  font-family: var(--font-mono);
  font-weight: 300;
  font-size: clamp(40px, 5vw, 56px);
  letter-spacing: -0.03em;
  line-height: 1;
  color: var(--navy);
}
.s_vision__kpi-label {
  margin-top: var(--s-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-soft);
  line-height: 1.5;
  max-width: 28ch;
}


/* =====================================================================
   S_CTA_ABOUT — CTA centré sur fond --navy (plus clair que --navy-ink)
   ===================================================================== */

.s_cta_about {
  background: var(--navy);
  color: var(--canvas);
}

.s_cta_about__inner {
  grid-column: 3 / span 8;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--s-5);
}
@media (max-width: 1023px) {
  .s_cta_about__inner { grid-column: 1 / -1; }
}

.s_cta_about__inner .eyebrow {
  color: var(--orange);
}

.s_cta_about__title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(32px, 4.5vw, 56px);
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--canvas);
  max-width: 22ch;
}
.s_cta_about__title .serif-em {
  color: var(--orange);
  padding: 0 0.04em;
  font-size: 1.05em;
  letter-spacing: -0.02em;
}

.s_cta_about__lead {
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.6;
  color: rgba(250, 247, 241, 0.8);
  max-width: 60ch;
}
.s_cta_about__lead .mono { color: var(--canvas); }

.s_cta_about__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--s-5);
  margin-top: var(--s-3);
}
@media (max-width: 540px) {
  .s_cta_about__actions { flex-direction: column; gap: var(--s-3); width: 100%; }
  .s_cta_about__actions .c-button { width: 100%; }
}


/* =====================================================================
   Override léger : le manifest réutilisé sur /about prend des <strong>
   en Geist 600 dans le body (les piliers utilisent le default).
   ===================================================================== */

.s_pillar_manifest__body strong {
  font-weight: 600;
  color: var(--navy);
}


/* =====================================================================
   HERO_VENN — composition graphique 2 cercles (finance ∩ digital)
   - Cercle gauche : --navy plein (Finance)
   - Cercle droit : --navy stroke 1.5px (Digital)
   - Intersection : --orange plein (Advena, à la croisée)
   - Animation : ascend initial puis boucle 4s ease-in-out infinie
     (les centres oscillent de ±10px sur l'axe X)
   - Mobile (<768px) : caché. Tablet : centré sous le texte, 200px diam.
   ===================================================================== */

.hero-venn {
  grid-column: 8 / -1;
  grid-row: 3 / span 2;
  align-self: center;
  justify-self: end;
  width: 100%;
  max-width: 480px;
  padding-left: var(--s-7); /* +24 gutter ≈ 72px de respiration vs bord texte */
}

.hero-venn__svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.hero-venn__c1 { fill: var(--navy); }
.hero-venn__intersection { fill: var(--orange); }
.hero-venn__c2 {
  fill: none;
  stroke: var(--navy);
  stroke-width: 1.5;
}

/* Animation en boucle après l'ascend initial — déclenchée par .is-pulsing
   ajouté en JS quand l'animationend "ascend" se produit sur le wrapper.
   On anime l'attribut SVG cx (supporté en CSS depuis Chrome 77 / FF 71 /
   Safari 16) — plus fiable que transform sur des circles dans clipPath. */
@keyframes hero-venn-cx-left {
  0%, 100% { cx: 140px; }
  50%      { cx: 130px; }
}
@keyframes hero-venn-cx-right {
  0%, 100% { cx: 300px; }
  50%      { cx: 310px; }
}
.hero-venn.is-pulsing .hero-venn__c1,
.hero-venn.is-pulsing .hero-venn__intersection {
  animation: hero-venn-cx-left 4s ease-in-out infinite;
}
.hero-venn.is-pulsing .hero-venn__c2,
.hero-venn.is-pulsing .hero-venn__clip-right {
  animation: hero-venn-cx-right 4s ease-in-out infinite;
}

/* Tablet : la composition descend sous le texte, centrée, plus petite */
@media (max-width: 1023px) {
  .hero-venn {
    grid-column: 1 / -1;
    grid-row: auto;
    justify-self: center;
    margin-top: var(--s-7);
    max-width: 340px;
    padding-left: 0;
  }
}

/* Mobile : caché complètement */
@media (max-width: 767px) {
  .hero-venn { display: none; }
}

/* Reduced motion : la boucle est désactivée. L'ascend initial est déjà
   géré par la règle globale prefers-reduced-motion dans theme.css. */
@media (prefers-reduced-motion: reduce) {
  .hero-venn.is-pulsing .hero-venn__c1,
  .hero-venn.is-pulsing .hero-venn__intersection,
  .hero-venn.is-pulsing .hero-venn__c2,
  .hero-venn.is-pulsing .hero-venn__clip-right {
    animation: none;
  }
}
