/* ═══════════════════════════════════════════════════════════════════
   NEOFY — SITE VITRINE — STYLE SHEET
   Direction : Technical Editorial
   Palette   : strictement blanc & bleu (charte officielle, aucune dérive)
   Typo      : Funnel Display (titrage) + Funnel Sans (corps) +
               JetBrains Mono (marginalia / méta)
   Approche  : grille éditoriale 12 colonnes, hairlines, marginalia,
               sections numérotées, asymétrie volontaire, motion sobre.
═══════════════════════════════════════════════════════════════════════ */

/* ── 00. TOKENS ──────────────────────────────────────────────────── */
:root{
  /* Palette charte */
  --blue:        #1B4FA8;
  --blue-deep:   #0F2756;
  --blue-vivid:  #2D7FF9;
  --blue-soft:   #5B85D6;
  --blue-pale:   #EBF3FF;
  --paper:       #F5F8FF;
  --paper-2:     #FFFFFF;
  --grey:        #6B7A93;
  --grey-2:      #94A3B8;
  --line:        #D1DCF0;
  --ink:         #0A1628;

  /* Typographies */
  --ff-display: 'Funnel Display', sans-serif;
  --ff-sans:    'Funnel Sans', sans-serif;
  --ff-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* ── Type scale ──
     Une échelle stricte, appliquée partout. Chaque clamp() est défini
     une seule fois ici, puis référencé par les composants — plus aucun
     clamp() inline dans le CSS. La hiérarchie reste lisible :
     un titre de section ne dépasse jamais le hero, un titre de carte
     ne dépasse jamais un titre de section.
  */
  --fs-hero:      clamp(48px, 6.4vw, 108px); /* h1 page d'accueil — un seul par site */
  --fs-page:      clamp(44px, 5.6vw, 96px);  /* h1 sur autres pages */
  --fs-section:   clamp(34px, 4.4vw, 68px);  /* h2 section */
  --fs-block:     clamp(26px, 2.8vw, 40px);  /* h3 — pull-quotes, blocs, manifest */
  --fs-card:      clamp(22px, 2.1vw, 30px);  /* h3 dans listes (services, pillars) */
  --fs-stat:      clamp(48px, 5.4vw, 88px);  /* chiffres */
  --fs-lede:      clamp(17px, 1.35vw, 19px); /* paragraphe d'introduction */
  --fs-body:      15px;                      /* corps */
  --fs-small:     13px;                      /* secondaire */
  --fs-caption:   11px;                      /* mono — légendes */
  --fs-micro:     10px;                      /* mono — eyebrow / margin */
  --fs-eyebrow:    9px;                      /* tout-petit mono pour étiquettes */

  /* Tempo */
  --ease:    cubic-bezier(.22,.61,.36,1);
  --ease-2:  cubic-bezier(.65,0,.35,1);
  --dur-1:   .35s;
  --dur-2:   .6s;
  --dur-3:   1.2s;

  /* Espace / grille */
  --gutter:  clamp(20px, 4vw, 56px);
  --margin:  clamp(28px, 6vw, 88px);
  --rule:    1px;
}

/* ── 01. RESET / GLOBAL ──────────────────────────────────────────── */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

html, body{
  font-family:var(--ff-sans);
  background:var(--paper-2);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","ss02";
  line-height:1.5;
  font-size:16px;
}

body{ overflow-x:hidden; }

img,svg{ display:block; max-width:100%; }

a{ color:inherit; text-decoration:none; }

::selection{ background:var(--blue); color:var(--paper-2); }

.display{
  font-family:var(--ff-display);
  font-weight:400;
  letter-spacing:-.02em;
}
.mono{
  font-family:var(--ff-mono);
  font-feature-settings:"tnum";
  font-size:11px;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:500;
}

em{ font-style:italic; font-weight:500; color:var(--blue); }

/* ── 02. GRILLE 12 COL ───────────────────────────────────────────── */
.grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap: 0 var(--gutter);
  padding-left:var(--margin);
  padding-right:var(--margin);
}
.col-span-2{  grid-column:span 2;  }
.col-span-3{  grid-column:span 3;  }
.col-span-4{  grid-column:span 4;  }
.col-span-5{  grid-column:span 5;  }
.col-span-6{  grid-column:span 6;  }
.col-span-7{  grid-column:span 7;  }
.col-span-8{  grid-column:span 8;  }
.col-span-9{  grid-column:span 9;  }
.col-span-12{ grid-column:1 / -1; }

/* ── 03. NAVIGATION ──────────────────────────────────────────────── */
.nav{
  position:fixed;
  top:0; left:0; right:0;
  z-index:50;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  transition:transform var(--dur-1) var(--ease), background var(--dur-1) var(--ease);
}
.nav.is-hidden{ transform:translateY(-100%); }
.nav.is-dark{
  background:rgba(15,39,86,.86);
  color:var(--paper-2);
}
.nav__inner{
  display:flex;
  align-items:center;
  gap:32px;
  padding: 18px var(--margin);
}
.nav__brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--blue);
  flex-shrink:0;
}
.nav.is-dark .nav__brand{ color:var(--paper-2); }
.nav__mark{ width:34px; height:24px; }
.nav__wordmark{
  font-family:var(--ff-display);
  font-size:22px;
  letter-spacing:-.025em;
  color:var(--ink);
}
.nav.is-dark .nav__wordmark{ color:var(--paper-2); }
.nav__menu{
  display:flex;
  gap:28px;
  margin-left:auto;
  font-size:13px;
}
.nav__menu a{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  position:relative;
  padding:8px 0;
  transition:color var(--dur-1) var(--ease);
}
.nav__menu a .num{
  font-family:var(--ff-mono);
  font-size:9px;
  letter-spacing:.1em;
  color:var(--grey-2);
  transition:color var(--dur-1) var(--ease);
}
.nav__menu a::after{
  content:"";
  position:absolute;
  left:0; bottom:6px;
  width:100%; height:1px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  transition:transform var(--dur-1) var(--ease);
}
.nav__menu a:hover{ color:var(--blue); }
.nav__menu a:hover::after{ transform:scaleX(1); }
.nav__menu a:hover .num{ color:var(--blue); }
.nav.is-dark .nav__menu a:hover{ color:var(--blue-vivid); }

.nav__cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:11px 18px;
  border:1px solid currentColor;
  font-size:13px;
  letter-spacing:.01em;
  transition:background var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}
.nav__cta svg{ width:18px; height:9px; transition:transform var(--dur-1) var(--ease); }
.nav__cta:hover{ background:var(--ink); color:var(--paper-2); }
.nav.is-dark .nav__cta:hover{ background:var(--paper-2); color:var(--blue-deep); }
.nav__cta:hover svg{ transform:translateX(4px); }

.nav__rule{
  height:1px;
  background:var(--line);
  transform-origin:left;
}
.nav.is-dark .nav__rule{ background:rgba(245,248,255,.18); }

.nav__burger{
  display:none;
  width:40px; height:32px;
  background:transparent;
  border:none;
  cursor:pointer;
  position:relative;
}
.nav__burger span{
  display:block;
  position:absolute;
  left:6px; right:6px;
  height:2px;
  background:currentColor;
  transition:transform var(--dur-1) var(--ease), top var(--dur-1) var(--ease);
}
.nav__burger span:nth-child(1){ top:11px; }
.nav__burger span:nth-child(2){ top:19px; }
.nav.is-open .nav__burger span:nth-child(1){ top:15px; transform:rotate(45deg); }
.nav.is-open .nav__burger span:nth-child(2){ top:15px; transform:rotate(-45deg); }

/* ── 04. MARGINALIA — bord de page ───────────────────────────────── */
.marginalia{
  position:fixed;
  top:50%;
  z-index:30;
  transform:translateY(-50%);
  pointer-events:none;
  font-family:var(--ff-mono);
  font-size:9px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--grey-2);
}
.marginalia--left{ left:14px; writing-mode:vertical-rl; transform:translateY(-50%) rotate(180deg); }
.marginalia--right{ right:14px; writing-mode:vertical-rl; }

.marginalia .mark-stamp,
.marginalia .mark-coord{
  display:flex;
  align-items:center;
  gap:8px;
}
.mark-stamp__num{
  font-size:13px;
  color:var(--blue);
  font-weight:500;
}
.mark-stamp__label,
.mark-coord__label{
  margin-top:18px;
  font-size:8px;
  color:var(--grey-2);
}

/* sur sections sombres : marginalia s'éclaircit */
body.is-dark-section .marginalia{ color:rgba(245,248,255,.55); }
body.is-dark-section .mark-stamp__num{ color:var(--blue-vivid); }

/* ── 05. BUTTONS ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:18px 28px;
  font-family:var(--ff-sans);
  font-size:14px;
  font-weight:500;
  letter-spacing:.005em;
  border:1px solid transparent;
  cursor:pointer;
  background:none;
  transition:background var(--dur-1) var(--ease), color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease);
}
.btn svg{ width:22px; height:11px; transition:transform var(--dur-1) var(--ease); }
.btn:hover svg{ transform:translateX(6px); }

.btn--primary{
  background:var(--ink);
  color:var(--paper-2);
  border-color:var(--ink);
}
.btn--primary:hover{ background:var(--blue); border-color:var(--blue); }

.btn--ghost{
  border-color:currentColor;
  color:var(--ink);
}
.btn--ghost:hover{ background:var(--ink); color:var(--paper-2); }

/* Bleu marine plein (ex : « Voir les services » du hero) */
.btn--navy{
  background:var(--blue-deep);
  color:var(--paper-2);
  border-color:var(--blue-deep);
}
.btn--navy:hover{ background:var(--blue); border-color:var(--blue); }

/* Blanc plein avec contour marine (ex : « Demander un audit » du hero) */
.btn--white{
  background:#fff;
  color:var(--blue-deep);
  border-color:var(--blue-deep);
}
.btn--white:hover{ background:var(--blue-deep); color:var(--paper-2); }

.section--navy .btn--ghost,
.section--blue .btn--ghost{
  color:var(--paper-2);
  border-color:var(--paper-2);
}
.section--navy .btn--ghost:hover,
.section--blue .btn--ghost:hover{
  background:var(--paper-2);
  color:var(--ink);
}

/* ── 06. EYEBROW / MOTIFS COMMUNS ────────────────────────────────── */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--ff-mono);
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--grey);
  font-weight:500;
}
.eyebrow__line{
  width:32px;
  height:1px;
  background:var(--blue);
}

.section{
  position:relative;
  padding: clamp(80px, 10vw, 160px) 0 clamp(80px, 10vw, 160px);
  overflow:hidden;
}
.section--paper{ background:var(--paper); color:var(--ink); }
.section--white{ background:var(--paper-2); color:var(--ink); }
.section--navy {
  background:var(--blue-deep);
  color:var(--paper-2);
}
.section--navy em{ color:var(--blue-vivid); }
.section--blue {
  background:var(--blue);
  color:var(--paper-2);
}
.section--blue em{ color:var(--paper-2); border-bottom:1px solid rgba(245,248,255,.4); }

.section__head{
  display:flex;
  align-items:baseline;
  gap:16px;
  margin-bottom: clamp(56px, 7vw, 96px);
  font-size:11px;
}
.section__num{
  font-size:13px;
  color:var(--blue);
  font-weight:500;
  letter-spacing:.04em;
}
.section--navy .section__num,
.section--blue .section__num{ color:var(--blue-vivid); }
.section--blue .section__num{ color:var(--paper-2); }

.section__role{
  font-size:11px;
  letter-spacing:.32em;
  color:var(--grey);
}
.section--navy .section__role,
.section--blue .section__role{ color:rgba(245,248,255,.6); }

.section__rule{
  flex:1;
  height:1px;
  background:var(--line);
}
.section--navy .section__rule,
.section--blue .section__rule{ background:rgba(245,248,255,.18); }

.section__progress{
  font-size:11px;
  color:var(--grey-2);
}
.section--navy .section__progress,
.section--blue .section__progress{ color:rgba(245,248,255,.5); }

.section__title{
  font-size: var(--fs-section);
  line-height:.96;
  letter-spacing:-.025em;
  font-weight:400;
  color:inherit;
  margin-bottom:32px;
  font-family:var(--ff-display);
}

/* ── 07. HERO ────────────────────────────────────────────────────── */
.hero{
  position:relative;
  padding: 138px 0 88px;
  background:var(--paper-2);
  min-height: min(92svh, 820px);
  display:flex;
  flex-direction:column;
  justify-content:center;
  isolation:isolate; /* contient les pseudo grain/spot */
  overflow:hidden;
}
/* Texture grain — SVG fractalNoise teint en bleu, multipliée
   pour respecter strictement la palette blanc/bleu de la charte. */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.106  0 0 0 0 0.310  0 0 0 0 0.659  0 0 0 0.55 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
  opacity:.16;
  mix-blend-mode:multiply;
}
/* Halo chromatique discret — tache de bleu pâle qui donne du
   relief en haut à droite, sans gradient flou type SaaS. */
.hero::after{
  content:"";
  position:absolute;
  top:-180px; right:-160px;
  width:780px; height:780px;
  background:
    radial-gradient(closest-side, rgba(45,127,249,.18), transparent 70%);
  z-index:0;
  pointer-events:none;
  filter:blur(40px);
}
.hero > *{ position:relative; z-index:1; }
.hero__grid{ row-gap:clamp(36px, 4vw, 60px); text-align:left; }

/* Hero aligné à gauche : titre, chapô et actions calés sur la marge gauche. */
.hero__title{ text-align:left; }
.hero__title .line--alt{ padding-left:0; }

.hero__meta{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:24px;
  flex-wrap:wrap;
  font-size:11px;
}
.hero__live{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:11px;
  letter-spacing:.16em;
  color:var(--grey);
  text-transform:uppercase;
}
.hero__live .dot{
  width:8px; height:8px;
  border-radius:50%;
  background:var(--blue-vivid);
  box-shadow:0 0 0 0 rgba(45,127,249,.5);
  animation:pulse 1.8s var(--ease) infinite;
}
.hero__live-text{
  color:var(--blue-deep);
  font-weight:600;
  font-size:12px;
  letter-spacing:.04em;
}

@keyframes pulse{
  0%   { box-shadow:0 0 0 0 rgba(45,127,249,.45); }
  70%  { box-shadow:0 0 0 14px rgba(45,127,249,0); }
  100% { box-shadow:0 0 0 0 rgba(45,127,249,0); }
}

.hero__title{
  font-size: var(--fs-hero);
  line-height:.94;
  letter-spacing:-.04em;
  color:var(--blue-deep);
  font-weight:400;
  font-family:var(--ff-display);
}
.hero__title .line{
  display:block;
  overflow:hidden;
}
.hero__title .line > span{
  display:inline-block;
  transition:transform var(--dur-3) var(--ease);
}
/* Hide-state n'est appliqué qu'avec JS prêt : sans JS, le titre est lisible */
.js-ready .hero__title:not(.is-revealed) .line > span{
  transform:translateY(105%);
}
.hero__title .line:nth-child(2) > span{ transition-delay:.08s; }
.hero__title .line:nth-child(3) > span{ transition-delay:.16s; }
.hero__title .line:nth-child(4) > span{ transition-delay:.24s; }
.hero__title .line--alt{ padding-left: clamp(40px, 8vw, 140px); }

.hero__lede{
  font-size: var(--fs-lede);
  line-height:1.55;
  color:var(--ink);
  max-width:54ch;
  margin-inline:0;
  text-align:left;
}
.hero__lede p + p{ margin-top:18px; }
.hero__lede-sub{
  font-size:14px;
  color:var(--grey);
  letter-spacing:-.005em;
}

.hero__actions{
  /* Boutons calés en bas à droite, alignés sur le bas du chapô (voir maquette) */
  grid-column: 8 / -1;
  align-self:end;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:14px;
  flex-wrap:wrap;
}

.hero__schema{
  margin-top:clamp(50px, 6vw, 80px);
  border-top:1px solid var(--line);
  padding-top:32px;
  color:var(--blue);
}
.schema{
  width:100%;
  height:auto;
  max-height:240px;
  display:block;
}
.schema__label{
  font-family:var(--ff-mono);
  font-size:8px;
  letter-spacing:.16em;
  fill:var(--blue);
  font-weight:500;
}
.schema__sub{
  font-family:var(--ff-mono);
  font-size:8px;
  letter-spacing:.1em;
  fill:var(--grey);
}
.schema__hub-name{
  font-size:18px;
  letter-spacing:-.02em;
  fill:var(--blue-deep);
  font-weight:500;
}
.schema__hub-sub{
  font-size:7px;
  letter-spacing:.14em;
  fill:var(--blue);
}
.schema__caption{
  margin-top:18px;
  font-size:10px;
  color:var(--grey);
  letter-spacing:.14em;
}

/* schéma — tracé animé */
.schema__links .link{
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
}
.schema.is-drawn .link{
  animation: schema-draw 1.6s var(--ease) forwards;
}
.schema.is-drawn .link:nth-child(2){ animation-delay:.15s; }
.schema.is-drawn .link:nth-child(3){ animation-delay:.30s; }
.schema.is-drawn .link:nth-child(4){ animation-delay:.45s; }
.schema.is-drawn .link:nth-child(5){ animation-delay:.60s; }

@keyframes schema-draw{
  to{ stroke-dashoffset:0; }
}

.hero__scroll{
  position:absolute;
  bottom:36px; right:var(--margin);
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  font-size:9px;
  letter-spacing:.32em;
  color:var(--grey);
}
.hero__scroll-bar{
  width:1px;
  height:48px;
  background:var(--blue);
  position:relative;
  overflow:hidden;
}
.hero__scroll-bar::after{
  content:"";
  position:absolute;
  inset:0;
  background:var(--paper-2);
  transform:translateY(-100%);
  animation: scroll-cue 2.4s var(--ease) infinite;
}
@keyframes scroll-cue{
  0%   { transform:translateY(-100%); }
  60%  { transform:translateY(100%); }
  100% { transform:translateY(100%); }
}

/* ── 08. TICKER ──────────────────────────────────────────────────── */
.ticker{
  background:var(--ink);
  color:var(--paper-2);
  padding:18px 0;
  overflow:hidden;
  border-top:1px solid var(--blue-deep);
  border-bottom:1px solid var(--blue-deep);
}
.ticker__track{
  display:inline-flex;
  white-space:nowrap;
  gap:48px;
  font-family:var(--ff-mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  animation: ticker-scroll 60s linear infinite;
  padding-left:100%;
}
.ticker__track .dot-sep{ color:var(--blue-vivid); font-size:8px; }
.ticker:hover .ticker__track{ animation-play-state:paused; }

@keyframes ticker-scroll{
  from{ transform:translateX(0); }
  to  { transform:translateX(-50%); }
}

/* ── 09. MANIFESTE / pillars ─────────────────────────────────────── */
.manifest__body{
  font-size: clamp(15px, 1.2vw, 17px);
  line-height:1.65;
  color:rgba(245,248,255,.84);
}
.manifest__body p + p{ margin-top:20px; }
.manifest__sign{
  margin-top:32px;
  font-size:10px;
  color:rgba(245,248,255,.5);
  letter-spacing:.18em;
}

.pillars{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  margin-top:clamp(80px, 10vw, 140px);
  padding-top:48px;
  border-top:1px solid rgba(245,248,255,.18);
}
.pillar{
  padding:0 32px;
  border-left:1px solid rgba(245,248,255,.18);
  position:relative;
}
.pillar:first-child{ border-left:none; padding-left:0; }
.pillar:last-child{ padding-right:0; }
.pillar__num{
  font-size:10px;
  color:var(--blue-vivid);
  letter-spacing:.18em;
}
.pillar__title{
  margin-top:18px;
  margin-bottom:18px;
  font-size: var(--fs-card);
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--paper-2);
  font-family:var(--ff-display);
}
.pillar p{
  font-size:14px;
  line-height:1.65;
  color:rgba(245,248,255,.7);
}

/* ── 10. SERVICES ────────────────────────────────────────────────── */
.services__intro{
  display:contents;
}
.services__title{
  font-size: var(--fs-section);
  line-height:.96;
  letter-spacing:-.025em;
  font-weight:400;
  color:var(--blue-deep);
  font-family:var(--ff-display);
}
.services__lede{
  margin-top:auto;
  font-size:15px;
  line-height:1.6;
  color:var(--grey);
  max-width:38ch;
}

.services__list{
  list-style:none;
  margin-top:clamp(64px, 8vw, 112px);
  border-top:1px solid var(--line);
}
.service{
  display:grid;
  grid-template-columns: 80px 1fr 1.4fr 1fr;
  gap:var(--gutter);
  padding:36px 0;
  border-bottom:1px solid var(--line);
  align-items:start;
  cursor:default;
  transition:padding var(--dur-1) var(--ease);
  position:relative;
}
.service::before{
  content:"";
  position:absolute;
  left:0; top:0;
  width:0; height:1px;
  background:var(--blue);
  transition:width var(--dur-2) var(--ease);
}
.service:hover::before,
.service:focus-within::before{ width:100%; }
.service:hover{ padding-left:14px; }

.service__num{
  font-size:13px;
  color:var(--blue);
  letter-spacing:.04em;
  padding-top:8px;
  font-weight:500;
}
.service__head{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.service__name{
  font-size: var(--fs-card);
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--blue-deep);
  font-weight:400;
  transition:color var(--dur-1) var(--ease);
  font-family:var(--ff-display);
}
.service:hover .service__name{ color:var(--blue); }
.service__tag{
  font-size:10px;
  color:var(--grey);
  letter-spacing:.16em;
}
.service__copy{
  font-size:14px;
  line-height:1.65;
  color:var(--ink);
  max-width:48ch;
}
.service__specs{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:10px;
  color:var(--grey);
  letter-spacing:.14em;
  padding-top:10px;
  border-top:1px solid var(--line);
}
.service__specs li::before{
  content:"·  ";
  color:var(--blue);
}

/* ── 11. COMPARE TABLE ───────────────────────────────────────────── */
.diff__lede{
  font-size:15px;
  line-height:1.65;
  color:var(--grey);
  max-width:42ch;
  margin-top:auto;
  align-self:end;
}

.compare{
  margin-top:clamp(64px, 8vw, 112px);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.compare__row{
  display:grid;
  grid-template-columns: 1fr 1.2fr 1.2fr;
  gap:var(--gutter);
  padding:24px 0;
  border-bottom:1px solid var(--line);
  align-items:center;
}
.compare__row:last-child{ border-bottom:none; }
.compare__row--head{
  font-size:10px;
  letter-spacing:.24em;
  color:var(--grey);
  padding:18px 0;
}
.compare__cell--us{ color:var(--blue); }
.compare__cell{ font-size:15px; }
.compare__label{
  font-family:var(--ff-mono);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--grey);
}
.compare__them{
  color:var(--grey);
  font-size:15px;
  text-decoration:line-through;
  text-decoration-color:rgba(107,122,147,.4);
  text-decoration-thickness:1px;
}
.compare__us{
  font-family:var(--ff-display);
  font-size: 18px;
  letter-spacing:-.01em;
  color:var(--blue-deep);
  font-weight:500;
}

/* ── 12. STATS / CHIFFRES ────────────────────────────────────────── */
.stats__title{ margin-bottom:clamp(40px, 5vw, 64px); }
.stats{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  border-top:1px solid rgba(245,248,255,.22);
}
.stat{
  padding: 48px 28px;
  border-right:1px solid rgba(245,248,255,.22);
  border-bottom:1px solid rgba(245,248,255,.22);
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  min-height:240px;
}
.stat:nth-child(3n){ border-right:none; }
.stat:nth-last-child(-n+3){ border-bottom:none; }
.stat__num{
  font-size: var(--fs-stat);
  line-height:1;
  letter-spacing:-.04em;
  color:var(--paper-2);
  font-weight:300;
  font-feature-settings:"tnum";
  font-family:var(--ff-display);
}
.stat__unit{
  font-size: clamp(18px, 1.5vw, 22px);
  font-weight:300;
  letter-spacing:-.01em;
  color:var(--paper-2);
  margin-top:-6px;
  font-family:var(--ff-display);
}
.stat__label{
  margin-top:auto;
  font-size:10px;
  letter-spacing:.18em;
  color:rgba(245,248,255,.65);
}

/* ── 13. QUOTES / TÉMOIGNAGES ────────────────────────────────────── */
.voix__lede{
  font-size:15px;
  line-height:1.65;
  color:var(--grey);
  max-width:42ch;
  margin-top:auto;
  align-self:end;
}
.quote{
  display:grid;
  grid-template-columns: 1fr 320px;
  gap:var(--gutter);
  padding: clamp(50px, 6vw, 80px) 0;
  border-top:1px solid var(--line);
  align-items:end;
  margin-top:0;
}
.quote:last-of-type{ border-bottom:1px solid var(--line); }
.quote__text{
  font-size: var(--fs-block);
  line-height:1.18;
  letter-spacing:-.02em;
  font-weight:400;
  color:var(--blue-deep);
  position:relative;
  padding-left: clamp(20px, 2.5vw, 40px);
  font-family:var(--ff-display);
}
.quote__text::before{
  content:"« ";
  position:absolute;
  left:0; top:0;
  color:var(--blue);
  font-family:var(--ff-display);
}
.quote__text::after{ content:" »"; color:var(--blue); }

.quote__source{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding-top:12px;
  border-top:1px solid var(--blue);
  font-size:13px;
  text-align:left;
}
.quote__name{
  font-family:var(--ff-display);
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--blue-deep);
  font-size:18px;
}
.quote__role{
  font-size:10px;
  color:var(--grey);
  letter-spacing:.14em;
  line-height:1.5;
}

/* ── 14. CTA / CONTACT ───────────────────────────────────────────── */
.section--cta{ padding-bottom: clamp(60px, 8vw, 120px); }
.cta__title{
  font-size: var(--fs-section);
  line-height:.96;
  letter-spacing:-.03em;
  color:var(--paper-2);
  margin-bottom:clamp(50px, 6vw, 80px);
  font-family:var(--ff-display);
}
.cta__title em{ color:var(--blue-vivid); border-bottom:2px solid rgba(45,127,249,.4); padding-bottom:4px; }

.cta__panel{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 5vw, 80px);
  padding-top:48px;
  border-top:1px solid rgba(245,248,255,.22);
}
.cta__panel-text p{
  font-size: clamp(15px, 1.3vw, 18px);
  line-height:1.65;
  color:rgba(245,248,255,.84);
  max-width:46ch;
  margin-bottom:24px;
}
.cta__bullets{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:8px;
  font-size:11px;
  letter-spacing:.14em;
  color:rgba(245,248,255,.7);
  padding-top:18px;
  border-top:1px solid rgba(245,248,255,.22);
}

.cta__form{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.cta__field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cta__field label{
  font-size:9px;
  letter-spacing:.24em;
  color:rgba(245,248,255,.6);
}
.cta__field input,
.cta__field select{
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(245,248,255,.32);
  padding:14px 0;
  font-family:var(--ff-display);
  font-size:20px;
  color:var(--paper-2);
  font-weight:400;
  letter-spacing:-.01em;
  transition:border-color var(--dur-1) var(--ease);
}
.cta__field input:focus,
.cta__field select:focus{
  outline:none;
  border-bottom-color:var(--blue-vivid);
}
.cta__field input::placeholder{ color:rgba(245,248,255,.32); font-style:italic; }
.cta__field select{
  appearance:none;
  -webkit-appearance:none;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23F5F8FF' stroke-width='1' fill='none'/></svg>") no-repeat right center/10px 6px;
  cursor:pointer;
}
.cta__field option{ background:var(--blue-deep); color:var(--paper-2); }

.cta__submit{
  align-self:flex-start;
  margin-top:14px;
  background:var(--paper-2);
  color:var(--blue-deep);
  border-color:var(--paper-2);
}
.cta__submit:hover{ background:var(--blue-vivid); color:var(--paper-2); border-color:var(--blue-vivid); }

.cta__feedback{
  font-size:11px;
  color:var(--blue-vivid);
  letter-spacing:.14em;
  margin-top:6px;
}
.cta__legal{
  font-size:9px;
  color:rgba(245,248,255,.4);
  letter-spacing:.14em;
}

/* ── 15. FOOTER ──────────────────────────────────────────────────── */
.footer{
  background:var(--ink);
  color:rgba(245,248,255,.7);
  padding: clamp(64px, 8vw, 96px) 0 36px;
  font-size:13px;
}
.footer__grid{ row-gap: clamp(36px, 4vw, 56px); }
.footer__brand{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.footer__mark{
  width:64px; height:46px;
  color:var(--paper-2);
}
.footer__claim{
  font-size: 22px;
  line-height:1.18;
  letter-spacing:-.015em;
  color:var(--paper-2);
  max-width:24ch;
  font-family:var(--ff-display);
}
.footer__col h4{
  font-size:10px;
  letter-spacing:.24em;
  color:var(--blue-vivid);
  margin-bottom:18px;
  font-weight:500;
}
.footer__col p{ line-height:1.7; }
.footer__col a{
  display:block;
  padding:5px 0;
  transition:color var(--dur-1) var(--ease);
}
.footer__col a:hover{ color:var(--paper-2); }

.footer__rule{
  height:1px;
  background:rgba(245,248,255,.14);
  margin-top:24px;
}

.footer__meta{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  font-size:9px;
  letter-spacing:.16em;
  color:rgba(245,248,255,.4);
}
.footer__meta a:hover{ color:var(--paper-2); }
.footer__center{ text-align:center; }
.footer__right{ text-align:right; }

/* ── 16. SCROLL REVEALS ──────────────────────────────────────────── */
/*  Pattern : "JS-aware reveal".
    Sans JS, ou si l'animation échoue, le contenu reste pleinement visible.
    Le hide-state est appliqué uniquement quand body a `.js-ready`,
    classe ajoutée par le script tout en début d'exécution. */
[data-reveal]{
  transition: opacity var(--dur-3) var(--ease), transform var(--dur-3) var(--ease);
  transition-delay: var(--reveal-delay, 0ms);
}
.js-ready [data-reveal]:not(.is-revealed){
  opacity:0;
  transform:translateY(28px);
}
[data-reveal].is-revealed{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ opacity:1; transform:none; transition:none; }
  .hero__title .line > span{ transform:none; }
  .schema__links .link{ stroke-dashoffset:0 !important; animation:none !important; }
  .ticker__track{ animation:none !important; }
}

/* ── 17. RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width: 1100px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .stat{ min-height:200px; }
  .stat:nth-child(3n){ border-right:1px solid rgba(245,248,255,.22); }
  .stat:nth-child(2n){ border-right:none; }
  .stat:nth-last-child(-n+3){ border-bottom:1px solid rgba(245,248,255,.22); }
  .stat:nth-last-child(-n+2){ border-bottom:none; }

  .compare__row{ grid-template-columns: 1fr 1fr; row-gap:8px; }
  .compare__row > .compare__label{ grid-column:1/-1; padding-bottom:4px; }
  .compare__row--head .compare__cell:first-child{ display:none; }

  .hero__title .line--alt{ padding-left:8vw; }
}

@media (max-width: 880px){
  .nav__menu{ display:none; }
  .nav__cta{ margin-left:auto; }
  .nav__burger{ display:block; }

  .nav.is-open .nav__menu{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%; left:0; right:0;
    background:var(--paper-2);
    padding:24px var(--margin) 32px;
    border-top:1px solid var(--line);
    gap:16px;
    font-size:18px;
  }
  .nav.is-open.is-dark .nav__menu{
    background:var(--blue-deep);
    border-top-color:rgba(245,248,255,.18);
  }

  .marginalia{ display:none; }

  .col-span-7,
  .col-span-5,
  .col-span-4,
  .col-span-3,
  .col-span-8,
  .col-span-9{
    grid-column: 1 / -1;
  }

  .hero{ padding-top:120px; }
  /* Mobile : on revient à l'alignement à gauche d'origine (le centrage
     n'est appliqué qu'en desktop). */
  .hero__grid{ text-align:left; }
  .hero__title{ text-align:left; }
  .hero__lede{ grid-column:1 / -1; text-align:left; margin-inline:0; max-width:48ch; }
  .hero__meta{ flex-direction:column; align-items:flex-start; justify-content:flex-start; }
  .hero__title .line--alt{ padding-left:0; }
  .hero__actions{ grid-column:1 / -1; align-self:auto; justify-content:flex-start; }

  .pillars{ grid-template-columns:1fr; }
  .pillar{
    padding:32px 0;
    border-left:none;
    border-top:1px solid rgba(245,248,255,.18);
  }
  .pillar:first-child{ border-top:none; padding-top:8px; }

  .stats{ grid-template-columns:1fr; }
  .stat{ border-right:none !important; min-height:180px; }
  .stat:not(:last-child){ border-bottom:1px solid rgba(245,248,255,.22) !important; }

  .service{
    grid-template-columns: 56px 1fr;
    gap:24px 16px;
  }
  .service__head{ grid-column: 2; }
  .service__copy{ grid-column: 1 / -1; padding-left:72px; }
  .service__specs{ grid-column: 1 / -1; padding-left:72px; }

  .quote{ grid-template-columns:1fr; gap:24px; }

  .cta__panel{ grid-template-columns:1fr; }

  .compare__cell{ font-size:14px; }
  .compare__us{ font-size:18px; }

  .footer__meta{ grid-template-columns:1fr; gap:8px; }
  .footer__center, .footer__right{ text-align:left; }

  .hero__scroll{ display:none; }
}

@media (max-width: 540px){
  :root{ --margin: 20px; --gutter: 16px; }
  body{ overflow-x:hidden; }
  .hero__lede,
  .manifest__body,
  .services__lede,
  .diff__lede,
  .voix__lede,
  .footer__claim,
  .quote__source,
  .cta__panel-text p { max-width:100% !important; }
  .btn{ padding:14px 20px; font-size:13px; }
  .hero__actions{ flex-direction:column; align-items:stretch; }
  .hero__actions .btn{ width:100%; justify-content:flex-start; }
  .hero__title{
    font-size: clamp(34px, 9.5vw, 42px);
    line-height:1;
    letter-spacing:-.03em;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .hero__title .line--alt{ padding-left:0; }
  .section__title{ font-size: clamp(36px, 9.5vw, 56px); }
  .section__head{ flex-wrap:wrap; gap:8px 12px; }
  .section__rule{ flex-basis:100%; order:5; }
  .section__progress{ margin-left:auto; }
  .schema{ overflow:visible; }
  .quote__text{ font-size: clamp(22px, 6vw, 32px); padding-left:14px; }
  .cta__title{ font-size: clamp(36px, 10vw, 56px); }
  .pillar__title{ font-size: clamp(24px, 7vw, 32px); }
  .stat__num{ font-size: clamp(48px, 14vw, 80px); }
  .service__name{ font-size: clamp(20px, 5.5vw, 28px); }
  .compare__row{ grid-template-columns:1fr; gap:4px; padding:18px 0; }
  .compare__row > .compare__label{ padding-bottom:6px; font-size:9px; }
  .compare__them, .compare__us{ font-size:14px; }
  .footer__claim{ font-size:18px; }
  .nav__cta{ display:none; }
  .nav__inner{ padding: 14px var(--margin); gap:12px; }
  .nav__burger{ margin-left:auto; }
  .hero__live-text{ font-size:11px; }
  .hero__live{ font-size:10px; gap:6px; }
}

/* ════════════════════════════════════════════════════════════════════
   18. PAGE-LEVEL COMPONENTS (multi-page)
   Tout ce qui sert sur services / equipe / contact, et qui n'existait
   pas dans la version one-pager.
═══════════════════════════════════════════════════════════════════════ */

/* ── Section lede générique (remplace diff__lede, voix__lede, etc.) ─ */
.section__lede{
  font-size: var(--fs-body);
  line-height:1.65;
  color:var(--grey);
  max-width:42ch;
  margin-top:auto;
  align-self:end;
}
.section--navy .section__lede,
.section--blue .section__lede{ color:rgba(245,248,255,.7); }

/* ── "Lire en entier →" dans le head de section ─────────────────── */
.section__more{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size: var(--fs-eyebrow);
  color:var(--blue);
  letter-spacing:.18em;
  transition:gap var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
  text-transform:uppercase;
  font-weight:500;
}
.section__more svg{ width:16px; height:8px; }
.section__more:hover{ gap:14px; color:var(--blue-deep); }
.section--navy .section__more,
.section--blue .section__more{ color:var(--blue-vivid); }
.section--navy .section__more:hover,
.section--blue .section__more:hover{ color:var(--paper-2); }

/* ── Page header (services / equipe / contact) ─────────────────── */
.page-header{
  position:relative;
  padding: 168px 0 clamp(48px, 6vw, 80px);
  background:var(--paper-2);
  isolation:isolate;
  border-bottom:1px solid var(--line);
}
.page-header::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.106  0 0 0 0 0.310  0 0 0 0 0.659  0 0 0 0.55 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");
  background-size:240px 240px;
  opacity:.10;
  mix-blend-mode:multiply;
}
.page-header > *{ position:relative; z-index:1; }

.page-header__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  margin-bottom: clamp(40px, 5vw, 64px);
}
.page-header__back{
  font-size:11px;
  color:var(--grey);
  letter-spacing:.18em;
  transition:color var(--dur-1) var(--ease);
}
.page-header__back:hover{ color:var(--blue); }

.page-header__title{
  font-size: var(--fs-page);
  line-height:.96;
  letter-spacing:-.035em;
  color:var(--blue-deep);
  font-weight:400;
  font-family:var(--ff-display);
  margin-bottom:clamp(40px, 5vw, 72px);
}
.page-header__title em{ color:var(--blue-vivid); font-style:italic; font-weight:400; }
.page-header__title .line{ display:block; }

.page-header__lede{
  font-size: var(--fs-lede);
  line-height:1.55;
  color:var(--ink);
  max-width:48ch;
}

.page-header__index{
  list-style:none;
  font-size:11px;
  letter-spacing:.04em;
  border-top:1px solid var(--line);
  padding-top:14px;
  align-self:start;
}
.page-header__index-label{
  display:block;
  font-size:9px;
  color:var(--grey);
  letter-spacing:.32em;
  margin-bottom:14px;
}
.page-header__index li{
  border-bottom:1px solid var(--line);
}
.page-header__index a{
  display:block;
  padding:10px 0;
  color:var(--blue-deep);
  font-size:11px;
  letter-spacing:.06em;
  transition:padding-left var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}
.page-header__index a:hover{
  padding-left:8px;
  color:var(--blue);
}

/* ── Bio card (Camil & Kevin) ──────────────────────────────────── */
.bio-card{
  display:grid;
  grid-template-columns: 360px 1fr;
  gap: clamp(40px, 5vw, 80px);
  align-items:start;
}
.bio-card--reverse{ grid-template-columns: 1fr 360px; }
.bio-card__avatar{
  position:relative;
  aspect-ratio: 4 / 5;
  background:var(--blue-deep);
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:32px;
  isolation:isolate;
  overflow:hidden;
}
.bio-card__avatar::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.4 0'/></filter><rect width='180' height='180' filter='url(%23n)'/></svg>");
  background-size:180px 180px;
  opacity:.18;
  mix-blend-mode:screen;
}
.bio-card__avatar::after{
  content:"";
  position:absolute;
  bottom:-90px; right:-60px;
  width:280px; height:280px;
  background:radial-gradient(closest-side, rgba(45,127,249,.4), transparent 70%);
  filter:blur(20px);
  z-index:0;
}
.bio-card__avatar-letters{
  font-size: clamp(96px, 11vw, 168px);
  line-height:1;
  color:var(--paper-2);
  letter-spacing:-.04em;
  font-weight:300;
  position:relative;
  z-index:1;
}
.bio-card__body{ padding-top:24px; }
.bio-card__name{
  font-size: var(--fs-page);
  line-height:.98;
  letter-spacing:-.035em;
  color:var(--blue-deep);
  font-weight:400;
  margin-bottom:8px;
}
.bio-card__role{
  font-size:11px;
  letter-spacing:.18em;
  color:var(--blue);
  text-transform:uppercase;
  margin-bottom:32px;
}
.bio-card__bio{
  font-size: var(--fs-lede);
  line-height:1.65;
  color:var(--ink);
  max-width:54ch;
}
.bio-card__bio + .bio-card__bio{ margin-top:18px; }
.bio-card__facts{
  margin-top:32px;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px 32px;
  padding-top:22px;
  font-size:11px;
}
.bio-card__facts > div{ display:flex; flex-direction:column; gap:4px; }
.bio-card__facts dt{
  font-size:9px;
  letter-spacing:.24em;
  color:var(--grey);
  font-weight:500;
  text-transform:uppercase;
}
.bio-card__facts dd{
  color:var(--blue-deep);
  font-weight:500;
  letter-spacing:.04em;
  text-transform:none;
  font-size:11px;
}

/* ── Manifeste full (page équipe) ──────────────────────────────── */
.manifest__full{
  font-size: var(--fs-body);
  line-height:1.7;
  color:rgba(245,248,255,.84);
  max-width:920px;
}
.manifest__full p + p{ margin-top:22px; }
.manifest__lead{
  font-family:var(--ff-display);
  font-size: var(--fs-block);
  line-height:1.25;
  color:var(--paper-2);
  letter-spacing:-.015em;
  margin-bottom:32px;
}
.manifest__lead em{
  color:var(--paper-2);
  font-style:italic;
  font-weight:500;
  border-bottom:1px solid rgba(45,127,249,.6);
  padding-bottom:1px;
}

/* ── Approche (3 étapes) ───────────────────────────────────────── */
.approche{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  margin-top:clamp(56px, 7vw, 96px);
  border-top:1px solid var(--line);
}
.approche__step{
  padding:48px 32px;
  border-right:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:20px;
  position:relative;
}
.approche__step:last-child{ border-right:none; }
.approche__num{
  font-size:48px;
  line-height:1;
  color:var(--blue);
  letter-spacing:-.03em;
  font-weight:300;
  font-feature-settings:"tnum";
}
.approche__title{
  font-size: var(--fs-card);
  line-height:1.05;
  letter-spacing:-.02em;
  color:var(--blue-deep);
  font-weight:400;
  margin-bottom:8px;
}
.approche__step p{
  font-size: var(--fs-body);
  line-height:1.65;
  color:var(--ink);
}
.approche__time{
  margin-top:auto;
  font-size:10px;
  letter-spacing:.18em;
  color:var(--grey);
  border-top:1px solid var(--line);
  padding-top:14px;
}

/* ── FAQ ───────────────────────────────────────────────────────── */
.faq{
  margin-top:clamp(40px, 5vw, 64px);
  border-top:1px solid var(--line);
}
.faq__item{
  border-bottom:1px solid var(--line);
}
.faq__q{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:24px 0;
  cursor:pointer;
  list-style:none;
  font-family:var(--ff-display);
  font-size: var(--fs-card);
  font-weight:400;
  letter-spacing:-.02em;
  color:var(--blue-deep);
  transition:padding-left var(--dur-1) var(--ease), color var(--dur-1) var(--ease);
}
.faq__q::-webkit-details-marker{ display:none; }
.faq__q:hover{ color:var(--blue); padding-left:8px; }
.faq__icon{
  font-family:var(--ff-mono);
  font-size:18px;
  color:var(--blue);
  transition:transform var(--dur-1) var(--ease);
  flex-shrink:0;
  font-weight:400;
}
.faq__item[open] .faq__icon{ transform:rotate(45deg); }
.faq__a{
  padding: 0 0 28px 0;
  font-size: var(--fs-body);
  line-height:1.7;
  color:var(--ink);
  max-width:72ch;
}
.faq__item[open] .faq__q{ color:var(--blue); }

/* ── Coordonnées (page contact) ────────────────────────────────── */
.coords{
  margin-top:clamp(48px, 6vw, 80px);
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.coords__cell{
  padding:36px 28px;
  border-right:1px solid var(--line);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.coords__cell:last-child{ border-right:none; }
.coords__label{
  font-size:9px;
  letter-spacing:.32em;
  color:var(--blue);
}
.coords__value{
  font-family:var(--ff-display);
  font-size: clamp(20px, 2.2vw, 28px);
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--blue-deep);
  font-weight:400;
}
.coords__value a{ transition:color var(--dur-1) var(--ease); }
.coords__value a:hover{ color:var(--blue); }
.coords__sub{
  font-size:10px;
  letter-spacing:.14em;
  color:var(--grey);
  margin-top:auto;
}

/* ── Pull-quote feature (home) ─────────────────────────────────── */
.quote--feature{
  grid-template-columns: 1fr;
  border-top:none;
  padding-top:0;
}
.quote--feature .quote__text{
  font-size: clamp(28px, 4.2vw, 56px);
  line-height:1.12;
  max-width:24ch;
  margin-bottom:32px;
}
.quote--feature .quote__source{
  border-top:1px solid var(--line);
  padding-top:14px;
  max-width:480px;
}

/* ── Pillars sur fond clair (page équipe — valeurs) ────────────── */
.pillars--paper{
  border-top-color:var(--line);
}
.pillars--paper .pillar{
  border-left-color:var(--line);
}
.pillars--paper .pillar__title{
  color:var(--blue-deep);
}
.pillars--paper .pillar p{
  color:var(--ink);
}
.pillars--paper .pillar__num{
  color:var(--blue);
}

/* ── Services list — variantes ─────────────────────────────────── */
.services__list--full{ margin-top:0; }
.services__list--full .service--full{
  grid-template-columns: 80px 1fr 1.6fr;
  padding: 56px 0;
  align-items:start;
}
.services__list--full .service--full .service__body{
  display:flex;
  flex-direction:column;
  gap:18px;
}
.services__list--full .service__head{ padding-top:6px; }
.services__list--full .service__name{
  font-size: clamp(28px, 3vw, 42px);
}
.services__list--full .service__copy{
  font-size: var(--fs-body);
  line-height:1.7;
}
.services__list--full .service__specs{
  grid-column: 2 / -1;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px 24px;
  border-top:1px solid var(--line);
  padding-top:18px;
  margin-top:8px;
}

.services__list--teaser .service{
  grid-template-columns: 80px 1fr 1.4fr;
  padding: 32px 0;
}
.services__list--teaser .service__specs{ display:none; }

.services__more{
  text-align:center;
  margin-top: clamp(48px, 6vw, 72px);
}

/* ── CTA home / sub-pages (panel simple) ───────────────────────── */
.section--cta-home{
  padding-bottom: clamp(80px, 10vw, 140px);
}
.cta-home__panel{
  display:grid;
  grid-template-columns: 1fr auto;
  gap: clamp(32px, 4vw, 56px);
  align-items:end;
  padding-top:48px;
  border-top:1px solid rgba(245,248,255,.22);
}
.cta-home__copy{
  font-size: var(--fs-lede);
  line-height:1.65;
  color:rgba(245,248,255,.84);
  max-width:54ch;
}
.cta-home__btn{
  align-self:end;
  background:var(--paper-2);
  color:var(--blue-deep);
  border-color:var(--paper-2);
}
.cta-home__btn:hover{
  background:var(--blue-vivid);
  color:var(--paper-2);
  border-color:var(--blue-vivid);
}

/* ── Form contact additional ───────────────────────────────────── */
.cta__panel-title{
  font-family:var(--ff-display);
  font-size: var(--fs-card);
  line-height:1.1;
  letter-spacing:-.02em;
  color:var(--paper-2);
  margin-bottom:24px;
  font-weight:400;
}
.cta__bullets-foot{
  margin-top:24px;
  font-size:10px;
  letter-spacing:.14em;
  color:rgba(245,248,255,.5);
  font-style:italic;
}
.cta__field textarea{
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(245,248,255,.32);
  padding:14px 0;
  font-family:var(--ff-display);
  font-size:18px;
  color:var(--paper-2);
  font-weight:400;
  letter-spacing:-.01em;
  resize:vertical;
  min-height:60px;
  transition:border-color var(--dur-1) var(--ease);
}
.cta__field textarea:focus{ outline:none; border-bottom-color:var(--blue-vivid); }
.cta__field textarea::placeholder{ color:rgba(245,248,255,.32); font-style:italic; }
.cta__submit:disabled{
  opacity:.5;
  cursor:default;
  pointer-events:none;
}

/* ── Active nav state (multi-page) ─────────────────────────────── */
.nav__menu a[aria-current="page"]{
  color:var(--blue);
}
.nav__menu a[aria-current="page"]::after{
  transform:scaleX(1);
}
.nav.is-dark .nav__menu a[aria-current="page"]{
  color:var(--paper-2);
}

/* ════════════════════════════════════════════════════════════════════
   19. RESPONSIVE — additions multi-page
═══════════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px){
  .approche{ grid-template-columns:1fr; }
  .approche__step{
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .approche__step:last-child{ border-bottom:none; }

  .coords{ grid-template-columns:1fr; }
  .coords__cell{
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .coords__cell:last-child{ border-bottom:none; }

  .bio-card,
  .bio-card--reverse{
    grid-template-columns: 220px 1fr;
    gap: 32px;
  }
  .bio-card--reverse .bio-card__avatar{ order:-1; }

  .services__list--full .service--full{
    grid-template-columns: 56px 1fr;
  }
  .services__list--full .service--full .service__body{ grid-column: 2; }
  .services__list--full .service__specs{
    grid-column: 1 / -1;
    grid-template-columns:repeat(2,1fr);
    padding-left:72px;
  }
}

@media (max-width: 880px){
  .page-header__meta{ flex-direction:column; align-items:flex-start; gap:14px; }
  .page-header__index{ margin-top:24px; }

  .bio-card,
  .bio-card--reverse{
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .bio-card__avatar{ aspect-ratio: 16/9; padding:24px; }
  .bio-card__avatar-letters{ font-size:72px; }
  .bio-card__facts{ grid-template-columns:1fr; }

  .cta-home__panel{ grid-template-columns:1fr; }

  .quote--feature .quote__text{ max-width:100%; }
}

@media (max-width: 540px){
  .page-header{ padding-top:120px; }
  .page-header__title{
    font-size: clamp(34px, 9.5vw, 44px);
    line-height:1;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .approche__step{ padding:32px 0; }
  .approche__num{ font-size:40px; }
  .coords__cell{ padding:24px 0; }
  .coords__value{ font-size: 20px; }
  .faq__q{ font-size:18px; gap:14px; padding:18px 0; }
  .faq__a{ padding-bottom:18px; }
  .bio-card__name{ font-size: clamp(28px, 7vw, 40px); }
  .manifest__lead{ font-size:22px; }
  .services__list--full .service--full{ padding:32px 0; }
  .services__list--full .service__name{ font-size: clamp(22px, 6vw, 28px); }
  .services__list--full .service__specs{
    grid-template-columns:1fr;
    padding-left:0;
  }
  .services__list--full .service__copy{ padding-left:0; }
  .services__list--full .service__head{ grid-column: 1 / -1; }
  .services__list--full .service--full{ grid-template-columns: 1fr; }
  .services__list--full .service__num{ display:none; }
}

/* ── 22. ORBITAL ANIMATIONS ──────────────────────────────────────── */
/*
  Hero orbit : motif principal en arrière-plan du hero (home).
  Le logo Neofy au centre, deux orbites pointillées, trois points
  qui tournent via <animateMotion>. Posé en absolute, z-index 0,
  derrière le contenu (.hero > * remonte en z-index 1).
*/
.hero-orbit{
  position:absolute;
  top:50%;
  right:2%;
  transform:translateY(-50%);
  width:min(580px, 48vw);
  height:min(580px, 48vw);
  z-index:0;
  pointer-events:none;
  opacity:.95;
}
.hero-orbit .orbit__rotor{
  transform-box:fill-box;
  transform-origin:50% 50%;
  animation:orbitSpin 90s linear infinite;
}
.hero-orbit .orbit__mark{
  opacity:.32;
  animation:orbitPulse 7s var(--ease) infinite;
  transform-box:fill-box;
  transform-origin:50% 50%;
}
.hero-orbit .orbit__dot{
  filter:drop-shadow(0 0 6px rgba(45,127,249,.35));
}

@keyframes orbitSpin{
  to{ transform:rotate(360deg); }
}
@keyframes orbitPulse{
  0%,100%{ opacity:.28; }
  50%    { opacity:.42; }
}

/*
  Page orbit : rappel discret du même motif sur les pages internes,
  sans logo, sans labels, plus petit, plus translucide.
*/
.page-orbit{
  position:absolute;
  top:65%;
  right:5%;
  transform:translateY(-50%);
  width:340px;
  height:340px;
  z-index:0;
  pointer-events:none;
  opacity:.85;
}
.page-header{ overflow:hidden; }

/*
  Schéma technique : extrait du hero, posé dans sa propre section
  pour respirer et alléger le hero (boutons coupés résolu).
*/
.schema-section{
  position:relative;
  padding: clamp(48px, 6vw, 88px) 0;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.schema-section .hero__schema{
  margin-top:0;
  border-top:none;
  padding-top:0;
}

/* Mobile : on retire les orbites pour ne pas saturer */
@media (max-width: 880px){
  .hero-orbit{ display:none; }
  .page-orbit{ display:none; }
}

@media (prefers-reduced-motion: reduce){
  .hero-orbit .orbit__rotor,
  .hero-orbit .orbit__mark{ animation:none; }
  .hero-orbit .orbit__dot animateMotion,
  .page-orbit circle animateMotion{ display:none; }
}

/* ═════════════════════════════════════════════════════════════════════
   23. ORBIT STAGE — section pinned scroll-driven (4 piliers)
   ─────────────────────────────────────────────────────────────────────
   Le N central reste fixe, les satellites s'allument tour à tour selon
   la position du scroll. Les fiches services crossfadent à droite.
   Hauteur totale = 100vh (pin) + 4 × 60vh (steps).
   Tout le contenu visuel est strictement contenu dans le pin (overflow
   hidden multi-niveaux) — rien ne déborde.
═════════════════════════════════════════════════════════════════════ */
.orbit-stage{
  position:relative;
  background:var(--paper);
  height: calc(100vh + 6 * 60vh);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  isolation:isolate;
  /* PAS d'overflow:hidden ici — ça casserait le position:sticky du pin.
     Le clip horizontal est assuré par body{overflow-x:hidden} et par
     .orbit-stage__pin{overflow:hidden}. */
}
.orbit-stage::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='220'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.106  0 0 0 0 0.310  0 0 0 0 0.659  0 0 0 0.55 0'/></filter><rect width='220' height='220' filter='url(%23n)'/></svg>");
  background-size:220px 220px;
  opacity:.05;
  mix-blend-mode:multiply;
}

.orbit-stage__pin{
  position:sticky;
  top:0;
  height:100vh;
  min-height:600px;            /* garde-fou pour très petits écrans */
  display:grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto;
  grid-template-areas:
    "head head"
    "visual panels"
    "nav nav";
  align-items:center;
  column-gap: clamp(32px, 5vw, 96px);
  row-gap: clamp(20px, 3vh, 36px);
  padding:
    clamp(70px, 8vh, 110px)
    var(--margin)
    clamp(36px, 5vh, 64px);
  z-index:1;
  overflow:hidden;             /* suspenders — clip dur des transitions */
}

.orbit-stage__head{
  grid-area:head;
  display:flex;
  align-items:center;
  gap:18px;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.orbit-stage__head .section__num{ color:var(--blue); }
.orbit-stage__head .section__role{ color:var(--grey); letter-spacing:.18em; }
.orbit-stage__progress{
  margin-left:auto;
  font-size:11px;
  color:var(--grey);
  letter-spacing:.22em;
}
.orbit-stage__progress span{
  color:var(--blue-deep);
  font-weight:500;
  font-variant-numeric: tabular-nums;
}

/* ── Visuel (SVG) — colonne gauche ─────────────────────────────────── */
.orbit-stage__visual{
  grid-area:visual;
  position:relative;
  aspect-ratio:1;
  width:100%;
  max-width: min(440px, 56vh);   /* plus compact qu'avant */
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:0;                  /* laisse le grid réduire si besoin */
}
.orbit-stage__svg{
  width:100%;
  height:100%;
  display:block;
  overflow:visible;              /* le ring scaling ne s'auto-clippe pas */
}

/* Halo pulse */
@keyframes osPulse{
  0%   { opacity:0;   r:78;  }
  60%  { opacity:.45; r:108; }
  100% { opacity:0;   r:140; }
}
.orbit-stage__pulse{
  animation: osPulse 4s var(--ease) infinite;
  transform-origin:400px 400px;
}

/* N central : float très subtil */
@keyframes osFloat{
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-2px); }
}
.orbit-stage__mark{ color: var(--blue); animation: osFloat 7s ease-in-out infinite; }

/* Satellites — base */
.orbit-stage__svg .sat{
  transform-box: fill-box;
  transform-origin:center;
  transition: transform .6s var(--ease);
}
.orbit-stage__svg .sat__bg{
  transition: fill .5s var(--ease), stroke .5s var(--ease);
}
.orbit-stage__svg .sat__icon{
  transition: stroke .5s var(--ease);
}
.orbit-stage__svg .sat__icon circle[fill]{
  transition: fill .5s var(--ease);
}
.orbit-stage__svg .sat__ring{
  transition: opacity .6s var(--ease);
}
.orbit-stage__svg .sat__label{
  font-family: var(--ff-mono);
  font-size:11px;
  letter-spacing:.18em;
  fill:var(--grey);
  transition: fill .5s var(--ease);
}

/* Beams — un par satellite, masqués par défaut */
.orbit-stage__beams .beam{
  opacity:0;
  stroke-dasharray: 3 7;
  transition: opacity .55s var(--ease);
}

.orbit-stage__dot{ filter: drop-shadow(0 0 6px rgba(45,127,249,.55)); }

/* États actifs */
.orbit-stage[data-active="0"] .sat--0 .sat__bg,
.orbit-stage[data-active="1"] .sat--1 .sat__bg,
.orbit-stage[data-active="2"] .sat--2 .sat__bg,
.orbit-stage[data-active="3"] .sat--3 .sat__bg,
.orbit-stage[data-active="4"] .sat--4 .sat__bg,
.orbit-stage[data-active="5"] .sat--5 .sat__bg{
  fill: var(--blue);
  stroke: var(--blue-deep);
}
.orbit-stage[data-active="0"] .sat--0 .sat__icon,
.orbit-stage[data-active="1"] .sat--1 .sat__icon,
.orbit-stage[data-active="2"] .sat--2 .sat__icon,
.orbit-stage[data-active="3"] .sat--3 .sat__icon,
.orbit-stage[data-active="4"] .sat--4 .sat__icon,
.orbit-stage[data-active="5"] .sat--5 .sat__icon{
  stroke: #fff;
}
.orbit-stage[data-active="0"] .sat--0 .sat__icon circle[fill],
.orbit-stage[data-active="1"] .sat--1 .sat__icon circle[fill],
.orbit-stage[data-active="2"] .sat--2 .sat__icon circle[fill],
.orbit-stage[data-active="3"] .sat--3 .sat__icon circle[fill],
.orbit-stage[data-active="4"] .sat--4 .sat__icon circle[fill],
.orbit-stage[data-active="5"] .sat--5 .sat__icon circle[fill]{
  fill: #fff;
}
.orbit-stage[data-active="0"] .sat--0 .sat__ring,
.orbit-stage[data-active="1"] .sat--1 .sat__ring,
.orbit-stage[data-active="2"] .sat--2 .sat__ring,
.orbit-stage[data-active="3"] .sat--3 .sat__ring,
.orbit-stage[data-active="4"] .sat--4 .sat__ring,
.orbit-stage[data-active="5"] .sat--5 .sat__ring{
  opacity:.45;
}
.orbit-stage[data-active="0"] .sat--0 .sat__label,
.orbit-stage[data-active="1"] .sat--1 .sat__label,
.orbit-stage[data-active="2"] .sat--2 .sat__label,
.orbit-stage[data-active="3"] .sat--3 .sat__label,
.orbit-stage[data-active="4"] .sat--4 .sat__label,
.orbit-stage[data-active="5"] .sat--5 .sat__label{
  fill: var(--blue-deep);
  font-weight:500;
}

.orbit-stage[data-active="0"] .beam--0,
.orbit-stage[data-active="1"] .beam--1,
.orbit-stage[data-active="2"] .beam--2,
.orbit-stage[data-active="3"] .beam--3,
.orbit-stage[data-active="4"] .beam--4,
.orbit-stage[data-active="5"] .beam--5{ opacity:.55; }

.orbit-stage[data-active="0"] .sat--0,
.orbit-stage[data-active="1"] .sat--1,
.orbit-stage[data-active="2"] .sat--2,
.orbit-stage[data-active="3"] .sat--3,
.orbit-stage[data-active="4"] .sat--4,
.orbit-stage[data-active="5"] .sat--5{
  transform: scale(1.06);
}

/* ── Panneaux service à droite ────────────────────────────────────────
   Technique grid-stack : tous les panels occupent la même cellule
   (1/1) — la cellule prend la hauteur du plus grand. Pas de
   position:absolute, pas de débordement possible. */
.orbit-stage__panels{
  grid-area:panels;
  position:relative;
  width:100%;
  max-width: 480px;
  margin-right:auto;
  display:grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  min-height:0;
  align-self:center;
}
.orbit-panel{
  grid-column: 1;
  grid-row: 1;
  display:flex;
  flex-direction:column;
  gap: 14px;
  opacity:0;
  transform: translateX(20px);
  pointer-events:none;
  visibility:hidden;
  transition:
    opacity .55s var(--ease),
    transform .55s var(--ease),
    visibility 0s linear .55s;
}
body:not(.js-ready) .orbit-panel:first-child{
  opacity:1; transform:none; pointer-events:auto; visibility:visible;
}
.orbit-panel.is-active{
  opacity:1;
  transform:none;
  pointer-events:auto;
  visibility:visible;
  transition:
    opacity .65s var(--ease) .1s,
    transform .65s var(--ease) .1s,
    visibility 0s linear 0s;
}
.orbit-panel__num{
  font-size:11px;
  letter-spacing:.22em;
  color:var(--blue);
}
.orbit-panel__title{
  font-family: var(--ff-display);
  font-size: clamp(28px, 2.8vw, 44px);
  line-height:1.04;
  letter-spacing:-.022em;
  color: var(--blue-deep);
  font-weight:400;
  margin:0;
}
.orbit-panel__title em{
  color: var(--blue-vivid);
  font-style:italic;
  font-weight:400;
}
.orbit-panel__lede{
  font-size: clamp(14px, 1.05vw, 16px);
  line-height:1.55;
  color: var(--ink);
  max-width: 44ch;
}
.orbit-panel__points{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:11px;
  letter-spacing:.06em;
  color: var(--grey);
}
.orbit-panel__points li{
  position:relative;
  padding-left:18px;
}
.orbit-panel__points li::before{
  content:"";
  position:absolute;
  left:0;
  top:.65em;
  width:10px;
  height:1px;
  background: var(--blue);
}
.orbit-panel__cta{ align-self:flex-start; margin-top:4px; }

/* ── Navigation par dots ──────────────────────────────────────────── */
.orbit-stage__nav{
  grid-area:nav;
  display:flex;
  justify-content:center;
  gap:14px;
}
.orbit-stage__dotnav{
  width:8px; height:8px;
  border-radius:50%;
  border:1px solid var(--blue);
  background:transparent;
  padding:0;
  cursor:pointer;
  transition: background .35s var(--ease), width .4s var(--ease), border-radius .4s var(--ease);
}
.orbit-stage__dotnav:hover{ background: var(--blue); }
.orbit-stage[data-active="0"] .orbit-stage__dotnav[data-jump="0"],
.orbit-stage[data-active="1"] .orbit-stage__dotnav[data-jump="1"],
.orbit-stage[data-active="2"] .orbit-stage__dotnav[data-jump="2"],
.orbit-stage[data-active="3"] .orbit-stage__dotnav[data-jump="3"],
.orbit-stage[data-active="4"] .orbit-stage__dotnav[data-jump="4"],
.orbit-stage[data-active="5"] .orbit-stage__dotnav[data-jump="5"]{
  background: var(--blue-deep);
  width:28px;
  border-radius:4px;
}

/* ── Écrans courts (laptops 13" en plein écran) ──────────────────── */
@media (min-width: 881px) and (max-height: 760px){
  .orbit-stage__pin{
    padding-top: clamp(60px, 7vh, 90px);
    padding-bottom: clamp(28px, 4vh, 48px);
    column-gap: clamp(28px, 3.5vw, 64px);
  }
  .orbit-stage__visual{ max-width: min(380px, 50vh); }
  .orbit-panel__title{ font-size: clamp(24px, 2.4vw, 36px); }
  .orbit-panel__lede{ font-size: 14px; }
  .orbit-panel{ gap:10px; }
}

/* ── Mobile : on délinéarise (pas de pin) ─────────────────────────── */
@media (max-width: 880px){
  .orbit-stage{ height:auto; }
  .orbit-stage__pin{
    position:static;
    height:auto;
    min-height:0;
    display:flex;
    flex-direction:column;
    gap:32px;
    padding: 64px 24px 56px;
  }
  .orbit-stage__visual{ max-width: min(380px, 76vw); }
  .orbit-stage__panels{ max-width:none; display:block; }
  .orbit-panel{
    grid-column:auto; grid-row:auto;
    opacity:1;
    transform:none;
    pointer-events:auto;
    visibility:visible;
    padding: 24px 0;
    border-top:1px solid var(--line);
  }
  .orbit-panel:first-child{ border-top:none; padding-top:0; }
  .orbit-stage__nav{ display:none; }
  .orbit-stage__progress{ display:none; }
}

@media (prefers-reduced-motion: reduce){
  .orbit-stage{ height:auto; }
  .orbit-stage__pin{
    position:static;
    height:auto;
    min-height:0;
    display:flex;
    flex-direction:column;
    gap:32px;
  }
  .orbit-panel{
    grid-column:auto; grid-row:auto;
    opacity:1;
    transform:none;
    pointer-events:auto;
    visibility:visible;
  }
  .orbit-stage__pulse,
  .orbit-stage__mark{ animation:none !important; }
  .orbit-stage__dot animateMotion{ display:none; }
}



