/* =============================================================
   Y&N Growth — assets/css/styles.css
   Feuille de styles UNIQUE et partagee (BRIEF.md §4).
   Base visuelle : maquette d'accueil validee « vivant » (non reinventee).
   Tokens : BRIEF.md §3 (source) + alias pour porter la maquette.
   Ordre : @font-face -> :root -> reset -> base -> navbar -> hero
           -> approche -> constat -> portfolio -> methode -> apropos
           -> faq -> cta -> footer -> animations -> responsive.
   ============================================================= */

/* =============================================================
   1. POLICES (auto-hebergees, BRIEF §3 — pas de CDN Google Fonts)
   Polices variables : 1 woff2 par sous-ensemble couvre toutes les
   graisses -> plages de graisses. latin + latin-ext (œ/Œ francais).
   ============================================================= */
@font-face{font-family:'Archivo';font-style:normal;font-weight:400 900;font-stretch:100%;font-display:swap;
  src:url('../fonts/archivo-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Archivo';font-style:normal;font-weight:400 900;font-stretch:100%;font-display:swap;
  src:url('../fonts/archivo-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400 600;font-display:swap;
  src:url('../fonts/inter-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400 600;font-display:swap;
  src:url('../fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}
@font-face{font-family:'Newsreader';font-style:italic;font-weight:400 500;font-display:swap;
  src:url('../fonts/newsreader-italic-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Newsreader';font-style:italic;font-weight:400 500;font-display:swap;
  src:url('../fonts/newsreader-italic-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;}

/* =============================================================
   2. TOKENS :root (BRIEF §3 — charte verrouillee) + alias maquette
   ============================================================= */
:root{
  /* — BRIEF (source de verite) — */
  --ink:#1A2340;            /* titres & texte (jamais de noir pur) */
  --soft:#5B627D;           /* texte secondaire */
  --action:#4F46E5;         /* SEULE couleur d'action : CTA, liens, hover */
  --action-dark:#4338CA;
  --data:#3B82F6;           /* chiffres, stats, preuves */
  --bg:#FFFFFF;
  --bg-soft:#F6F7FB;
  --pale:#EEF2FF;
  --line:rgba(26,35,64,.09);
  --violet:#6C5CE7; --cyan:#4AC8F0; --magenta:#E96BD4;   /* decoratif uniquement */
  --nuit:linear-gradient(100deg,#172554,#1E40AF,#4338CA);
  --vivant:linear-gradient(100deg,#4F46E5 0%,#6C5CE7 38%,#4AC8F0 80%,#E96BD4 100%);
  --display:'Archivo',system-ui,-apple-system,'Segoe UI',sans-serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --container:1200px; --r:16px;

  /* — Alias pour porter la maquette « vivant » sans la reinventer — */
  --accent:var(--action); --accent-dark:var(--action-dark); --accent-soft:var(--pale);
  --ink-soft:var(--soft); --grad:var(--vivant);
  --font-display:var(--display); --font-body:var(--body);
  --shadow-soft:0 8px 30px -12px rgba(26,35,64,.18);
  --shadow-btn:0 10px 24px -8px rgba(79,70,229,.55);

  /* — Encadres semantiques « constat » (issus de la maquette) — */
  --rose-bg:linear-gradient(160deg,#fcf1f4,#faecf0);
  --rose-line:rgba(201,138,162,.28); --rose-label:#b06d88; --rose-ink:#6f6571;
  --nous-bg:linear-gradient(140deg,#EEF2FF 0%,#EAF1FF 100%);
}

/* =============================================================
   3. RESET
   ============================================================= */
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:#eef0f6;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;position:relative;overflow-x:clip}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--action);text-decoration:none}
button,input,select,textarea{font:inherit;color:inherit}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--action);outline-offset:3px;border-radius:6px}
::selection{background:var(--pale);color:var(--ink)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* Curseur signature (hover-capable + mouvement non reduit uniquement) */
@media (hover:hover){
  body:not(.reduced){cursor:none}
  body:not(.reduced) a,body:not(.reduced) button,body:not(.reduced) input{cursor:none}
}
.cursor-canvas{position:fixed;inset:0;pointer-events:none;z-index:9999}

/* =============================================================
   4. BASE PARTAGEE (surtitres, boutons, conteneur)
   ============================================================= */
.surtitre{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:7px;margin-bottom:12px}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;line-height:1.1}
.grad{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-box-decoration-break:clone;box-decoration-break:clone;padding:.02em .18em .08em 0}
.sub-lead{color:var(--ink);font-weight:600}
@media(min-width:600px){.sub-lead{white-space:nowrap}}
.em{font-family:var(--serif);font-style:italic;font-weight:500}

.btn{font-family:var(--font-body);font-weight:600;font-size:14.5px;text-decoration:none;border-radius:11px;
  padding:11px 18px;white-space:nowrap;display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:0;
  transition:background-color .18s,color .18s,box-shadow .18s,transform .18s}
.btn-ghost{color:var(--ink);background:transparent}
.btn-ghost:hover{color:var(--accent);background:var(--accent-soft)}
.btn-primary{color:#fff;background:var(--accent)}
.btn-primary:hover{background:var(--accent-dark);box-shadow:var(--shadow-btn)}
.btn .arr{transition:transform .2s}.btn-primary:hover .arr{transform:translateX(3px)}

/* =============================================================
   5. NAVBAR (mutualisee — header canonique sticky, IDENTIQUE partout)
   Reprend la pilule .navB de la maquette, extraite du hero.
   ============================================================= */
.site-header{position:sticky;top:0;z-index:60;padding:13px 0 0}
.site-header > .container{padding-inline:24px}
.navB{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:8px 12px 8px 20px;background:#fff;border:1px solid rgba(26,35,64,.06);
  border-radius:16px;box-shadow:0 12px 40px -18px rgba(26,35,64,.28)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;flex:none}
.brand svg{height:27px;width:auto;display:block;overflow:visible}
.navlinks{display:flex;align-items:center;gap:2px;margin:0 auto}
.navlinks a{position:relative;text-decoration:none;color:var(--ink);font-size:14px;font-weight:500;
  padding:7px 11px;border-radius:8px;transition:color .18s}
.navlinks a::after{content:"";position:absolute;left:11px;right:11px;bottom:3px;height:2px;border-radius:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .22s}
.navlinks a:hover{color:var(--accent)}
.navlinks a:hover::after{transform:scaleX(1)}
.navlinks a[aria-current="page"]{color:var(--accent)}
.navlinks a[aria-current="page"]::after{transform:scaleX(1)}
.cta-wrap{display:flex;align-items:center;gap:10px;flex:none}
.cta-wrap .btn{padding:9px 16px;font-size:14px}
.nav-toggle{display:none;background:#fff;border:1px solid var(--line);border-radius:11px;width:42px;height:42px;align-items:center;justify-content:center;padding:0;cursor:pointer;color:var(--ink);flex:none}
.nt-bars{position:relative;width:20px;height:14px;display:block}
.nt-bars i{position:absolute;left:0;right:0;height:2px;border-radius:2px;background:var(--ink);transition:transform .25s ease,opacity .2s ease,top .25s ease}
.nt-bars i:nth-child(1){top:0}
.nt-bars i:nth-child(2){top:6px}
.nt-bars i:nth-child(3){top:12px}
.site-header.is-open .nt-bars i:nth-child(1){top:6px;transform:rotate(45deg)}
.site-header.is-open .nt-bars i:nth-child(2){opacity:0}
.site-header.is-open .nt-bars i:nth-child(3){top:6px;transform:rotate(-45deg)}

/* =============================================================
   6. HERO (stage + canvas web + mots flottants + barre d'audit)
   ============================================================= */
.wrap{max-width:1300px;margin:0 auto;padding:18px 24px 40px}
.stage{position:relative;border-radius:24px;overflow:hidden;background:var(--bg);box-shadow:var(--shadow-soft)}
.stage::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(50% 70% at 6% -5%,rgba(108,92,231,.13),transparent 60%),
  radial-gradient(55% 75% at 100% 4%,rgba(233,107,212,.11),transparent 62%),
  radial-gradient(45% 60% at 88% 100%,rgba(74,200,240,.13),transparent 60%)}
canvas.web{position:absolute;inset:0;z-index:0;pointer-events:none}

.hero{position:relative;min-height:480px;max-width:1200px;margin:0 auto;padding:38px 30px 44px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.hero-text{position:relative;z-index:2;max-width:640px;display:flex;flex-direction:column;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid rgba(26,35,64,.08);
  border-radius:999px;padding:8px 16px 8px 13px;font-size:13px;font-weight:500;color:var(--ink-soft);box-shadow:var(--shadow-soft)}
.eyebrow .spark{font-size:14px;font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow .gp{background:var(--grad);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:600;animation:flow 4.5s linear infinite}
@keyframes flow{to{background-position:220% center}}
.hero h1{font-family:var(--font-display);font-weight:900;font-size:clamp(40px,5vw,64px);line-height:1.02;letter-spacing:-.025em;color:var(--ink);margin:24px 0 0}
.sub{margin:22px auto 0;max-width:560px;color:var(--ink-soft);font-size:17px;line-height:1.6}
.sub b{color:var(--ink);font-weight:600}
.audit{margin:30px auto 0;width:100%;max-width:580px;position:relative;z-index:2}
.abar{display:flex;align-items:center;background:#fff;border:1px solid rgba(26,35,64,.10);border-radius:999px;
  padding:7px 7px 7px 22px;box-shadow:var(--shadow-soft);transition:box-shadow .2s,border-color .2s}
.abar:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--shadow-soft)}
.abar .pfx{font-family:ui-monospace,monospace;color:var(--ink-soft);font-size:14px;margin-right:8px;white-space:nowrap;letter-spacing:.02em}
.abar input{flex:1;border:none;outline:none;font-family:var(--font-body);font-size:15.5px;color:var(--ink);background:transparent;min-width:0}
.abar input::placeholder{color:#9aa0b4}
.abar .go{flex-shrink:0;font-family:var(--font-body);font-weight:600;font-size:15px;color:#fff;background:var(--accent);
  border:none;border-radius:999px;padding:12px 22px;display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:background-color .18s,box-shadow .18s}
.abar .go:hover{background:var(--accent-dark);box-shadow:var(--shadow-btn)}
.abar .go .arr{transition:transform .2s}.abar .go:hover .arr{transform:translateX(3px)}
.reassure{margin:16px 0 0;display:flex;gap:16px;flex-wrap:wrap;justify-content:center;font-size:13px;color:var(--ink-soft)}
.reassure span{display:inline-flex;align-items:center;gap:6px}
.reassure svg{width:15px;height:15px;color:var(--accent);flex-shrink:0}
.audit-demo{margin:12px 0 0;font-size:13px;color:var(--accent);min-height:18px}

.words{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;
  -webkit-mask-image:radial-gradient(ellipse 50% 54% at 50% 50%,transparent 0 58%,rgba(0,0,0,.55) 76%,#000 100%);
  mask-image:radial-gradient(ellipse 50% 54% at 50% 50%,transparent 0 58%,rgba(0,0,0,.55) 76%,#000 100%)}
.word{position:absolute;bottom:-8%;font-family:var(--font-display);font-weight:800;color:var(--ink);white-space:nowrap;letter-spacing:.01em;will-change:transform,opacity;animation:rise var(--d,22s) linear infinite}
.word.g{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.word.far{filter:blur(1.4px)}
@keyframes rise{0%{transform:translateY(0);opacity:0}12%{opacity:var(--o,.1)}85%{opacity:var(--o,.1)}100%{transform:translateY(-740px);opacity:0}}

/* =============================================================
   7. NOTRE APPROCHE (coverflow epingle)
   ============================================================= */
.scroll-sec{position:relative}
.pin{position:sticky;top:0;height:min(100vh,640px);overflow:hidden;display:flex;flex-direction:column;background:var(--bg)}
.pin::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(45% 50% at 50% 4%,rgba(108,92,231,.08),transparent 60%)}
.phead{position:relative;z-index:2;padding:22px 30px 0;text-align:center}
.phead h2{font-family:var(--font-display);font-weight:900;font-size:clamp(26px,3vw,40px);line-height:1.05;letter-spacing:-.02em}
.phead .intro{margin:12px auto 0;max-width:620px;color:var(--ink-soft);font-size:15px;line-height:1.55}
.track-wrap{flex:1;display:flex;align-items:center;overflow:visible}
.track{display:flex;gap:40px;will-change:transform}
.scard{flex:0 0 auto;height:448px;background:#fff;border:1px solid rgba(26,35,64,.08);border-radius:22px;padding:22px;box-shadow:0 20px 50px -22px rgba(26,35,64,.4);display:flex;flex-direction:column;transform-origin:center center;position:relative;overflow:hidden}
.scard::after{content:"";position:absolute;inset:0;border-radius:22px;padding:1.6px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:0;transition:opacity .3s}
.scard.focus::after{opacity:1}
.ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:13px;transition:background .3s,color .3s;flex-shrink:0}
.ic svg{width:22px;height:22px}
.scard.focus .ic{background:var(--grad);color:#fff}
.ttl{font-family:var(--font-display);font-weight:800;font-size:19px;color:var(--ink)}
.dsc{font-size:14px;line-height:1.5;color:var(--ink-soft);margin-top:7px}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px}
.chip{font-size:11.5px;font-weight:600;color:var(--accent-dark);background:var(--accent-soft);border-radius:7px;padding:4px 9px}
.fill{margin-top:auto}
.mini-bw{margin-top:14px;border:1px solid rgba(26,35,64,.12);border-radius:10px;overflow:hidden}
.mini-bw .b{background:#f3f4f9;padding:7px 9px;display:flex;gap:5px}.mini-bw .b i{width:8px;height:8px;border-radius:50%;background:#cfd3e0}
.mini-bw .s{height:92px;background:linear-gradient(180deg,#fff,#f7f8fc);position:relative}
.mini-bw .s::before{content:"";position:absolute;left:14px;right:14px;top:16px;height:9px;border-radius:5px;background:rgba(26,35,64,.10)}
.mini-bw .s::after{content:"";position:absolute;left:14px;top:34px;width:90px;height:24px;border-radius:7px;background:var(--accent);opacity:.85}
.brandkit{margin-top:14px;border:1px solid rgba(26,35,64,.1);border-radius:12px;padding:14px;background:#fff;box-shadow:0 8px 24px -14px rgba(26,35,64,.25)}
.bk-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(26,35,64,.08)}
.bk-logo{font-family:var(--font-display);font-weight:800;font-size:23px;color:var(--ink);letter-spacing:-.02em}
.bk-logo-img{height:22px;width:auto;display:block}
.bk-logo .amp{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.bk-aa{display:flex;flex-direction:column;align-items:center;line-height:1}
.bk-aa span{font-family:var(--font-display);font-weight:900;font-size:25px;color:var(--ink)}
.bk-aa em{font-style:normal;font-size:9px;color:var(--ink-soft);margin-top:4px;letter-spacing:.05em}
.bk-pal{display:flex;gap:7px;margin-top:12px}
.bk-pal i{flex:1;height:26px;border-radius:6px;display:block}
.gsc{margin-top:12px;border:1px solid rgba(26,35,64,.1);border-radius:12px;padding:11px;background:#fff}
.gsc-tiles{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:6px;margin-bottom:9px}
.tile{border-radius:7px;padding:7px 8px;background:#f4f5fa}
.tile .l{font-size:9px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tile .v{font-size:15px;font-weight:700;font-family:var(--font-display);margin-top:1px}
.tile.blue{background:var(--data);color:#fff}.tile.blue .l{color:rgba(255,255,255,.85)}
.tile.violet{background:#6C5CE7;color:#fff}.tile.violet .l{color:rgba(255,255,255,.85)}
.gsc-legend{display:flex;justify-content:space-between;font-size:9px;color:var(--ink-soft);margin-bottom:2px}
.gsc svg{width:100%;height:78px;display:block}
.cg{margin-top:14px;display:flex;flex-direction:column;gap:11px}
.cg-input{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid rgba(26,35,64,.14);border-radius:16px;padding:11px 12px;box-shadow:0 8px 22px -14px rgba(26,35,64,.35);min-height:46px}
.cg-q{font-size:12.5px;color:var(--ink);line-height:1.35;flex:1;text-align:left}
.cg-caret{width:1.5px;height:15px;background:var(--accent);display:inline-block;vertical-align:-2px;margin-left:1px;animation:cgblink 1.05s steps(1) infinite}
.cg-caret.hide{display:none}
@keyframes cgblink{50%{opacity:0}}
.cg-send{width:28px;height:28px;border-radius:9px;background:var(--ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.32;transition:opacity .3s,background .3s}
.cg-send.on{opacity:1;background:var(--accent)}
.cg-send svg{width:15px;height:15px;color:#fff}
.cg-ans{display:flex;gap:9px;align-items:flex-start;opacity:0;transform:translateY(6px);transition:opacity .45s,transform .45s}
.cg-ans.show{opacity:1;transform:none}
.cg-ai{width:25px;height:25px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;flex-shrink:0;margin-top:1px}
.cg-ans p{font-size:12.5px;line-height:1.6;color:var(--ink)}
.cg-ans mark{background:var(--accent-soft);color:var(--accent-dark);font-weight:700;padding:1px 5px;border-radius:5px}
.insta{margin-top:13px;border:1px solid rgba(26,35,64,.1);border-radius:12px;overflow:hidden;background:#fff}
.ig-top{display:flex;align-items:center;gap:8px;padding:8px 10px}
.ig-av{width:24px;height:24px;border-radius:50%;background:var(--grad);flex-shrink:0}
.ig-handle{font-size:12px;font-weight:600;color:var(--ink)}
.ig-more{margin-left:auto;color:var(--ink-soft);letter-spacing:1px}
.ig-img{height:92px;background:linear-gradient(135deg,#4F46E5,#6C5CE7 40%,#4AC8F0 82%,#E96BD4);display:flex;align-items:center;justify-content:center}
.ig-img b{color:#fff;font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:.02em;text-shadow:0 2px 10px rgba(0,0,0,.18)}
.ig-act{display:flex;align-items:center;gap:12px;padding:8px 10px 2px;color:var(--ink)}
.ig-act svg{width:18px;height:18px}
.ig-cap{padding:0 10px 10px;font-size:11.5px;color:var(--ink-soft);line-height:1.4}.ig-cap b{color:var(--ink)}
.scard.cta{background:#EEF2FF;border:1px solid rgba(79,70,229,.18);color:var(--ink);justify-content:center}
.scard.cta::after{display:none}
.scard.cta::before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;right:-70px;top:-70px;background:radial-gradient(circle,rgba(79,70,229,.16),transparent 70%);pointer-events:none}
.scard.cta .ic{background:#fff;color:var(--accent);box-shadow:0 6px 16px -8px rgba(79,70,229,.5)}
.scard.cta h3{font-family:var(--font-display);font-weight:900;font-size:24px;line-height:1.08;margin-bottom:12px;color:var(--accent-dark);position:relative}
.scard.cta p{font-size:14.5px;line-height:1.55;color:var(--ink-soft);margin-bottom:22px;position:relative}
.scard.cta .go{align-self:flex-start;display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;font-weight:600;font-size:15px;border-radius:11px;padding:13px 22px;text-decoration:none;transition:transform .2s,background-color .2s,box-shadow .2s;position:relative}
.scard.cta .go:hover{transform:translateY(-2px);background:var(--accent-dark);box-shadow:0 12px 26px -10px rgba(79,70,229,.55)}
.scard.cta .go svg{width:17px;height:17px}
.dots{display:flex;gap:8px;justify-content:center;padding:0 0 22px;position:relative;z-index:2}
.dot{width:7px;height:7px;border-radius:50%;background:rgba(26,35,64,.18);transition:width .25s,background .25s}
.dot.on{background:var(--accent);width:22px;border-radius:4px}

/* =============================================================
   8. LE CONSTAT (manifeste typewriter + tableau marche vs nous)
   ============================================================= */
.constat{position:relative;overflow:hidden;background:#f6f7fb}
.atmo{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.atmo .r1{position:absolute;width:60vw;height:60vw;left:-18vw;top:-14vw;background:radial-gradient(circle,rgba(108,92,231,.10),transparent 62%)}
.atmo .r2{position:absolute;width:55vw;height:55vw;right:-16vw;bottom:-18vw;background:radial-gradient(circle,rgba(74,200,240,.10),transparent 62%)}
.atmo .r3{position:absolute;width:40vw;height:40vw;right:8vw;top:6vw;background:radial-gradient(circle,rgba(233,107,212,.07),transparent 62%)}
.grain{position:absolute;inset:0;z-index:1;opacity:.03;pointer-events:none;mix-blend-mode:multiply}
.constat-wrap{position:relative;z-index:2;max-width:1060px;margin:0 auto;padding:58px 28px 66px}
.constat h2{font-family:var(--font-display);font-weight:900;font-size:clamp(30px,4.6vw,54px);line-height:1.04;letter-spacing:-.025em;max-width:14ch}
.constat h2 .g{display:inline-block;font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;padding:.04em .22em .14em .04em}
.lede{margin-top:22px;max-width:60ch;font-size:clamp(15.5px,1.6vw,18px);line-height:1.6;color:var(--ink-soft)}
.lede b{color:var(--ink);font-weight:600}
.hl{color:var(--ink);font-weight:600;background-image:linear-gradient(transparent 58%,rgba(79,70,229,.22) 58%);background-repeat:no-repeat;background-position:0 100%;background-size:0% 100%;-webkit-box-decoration-break:clone;box-decoration-break:clone;padding:0 2px;transition:background-size .9s cubic-bezier(.2,.7,.2,1) .35s}
.lede.in .hl{background-size:100% 100%}
.head-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;margin-top:8px}
.manifesto{position:relative;padding:8px 0 8px 30px}
.manifesto::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--grad)}
.manifesto .qm{font-family:var(--serif);font-style:italic;font-weight:500;font-size:46px;line-height:.5;display:block;margin-bottom:0;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.5}
.manifesto .qm-end{position:absolute;right:8px;bottom:-12px;display:inline-block;font-family:var(--serif);font-style:italic;font-weight:500;font-size:46px;line-height:1;margin:0;opacity:.5}
.manifesto p{font-family:var(--font-display);font-weight:600;font-style:italic;font-size:clamp(15px,1.35vw,17px);line-height:1.4;letter-spacing:-.01em;color:var(--ink);min-height:2.5em;text-wrap:balance}
.manifesto .g{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
/* — Tableau comparatif « le marché vs Y&N » (VS central, colonne Y&N surélevée) — */
.cmp{position:relative;margin-top:34px}
.cmp-cols{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:0 28px}
.cmp-col{background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-soft)}
.cmp-col--yn{transform:translateY(-16px);border-color:rgba(79,70,229,.22);box-shadow:0 28px 58px -26px rgba(79,70,229,.45),0 0 34px -8px rgba(108,92,231,.3);animation:cmpGlow 3.6s ease-in-out infinite}
@keyframes cmpGlow{0%,100%{box-shadow:0 26px 54px -28px rgba(79,70,229,.4),0 0 26px -10px rgba(108,92,231,.22)}50%{box-shadow:0 32px 64px -24px rgba(79,70,229,.5),0 0 50px -4px rgba(108,92,231,.5)}}
.cmp-col-head{padding:14px 16px;display:flex;align-items:center;justify-content:center;gap:8px;min-height:52px;text-align:center;font-family:var(--font-display);font-weight:800;font-size:11px;letter-spacing:.05em;text-transform:uppercase}
.cmp-col--market .cmp-col-head{background:var(--rose-bg);color:var(--rose-label)}
.cmp-col--market .cmp-col-head span{font-family:var(--font-body);font-weight:500;font-size:11px;letter-spacing:0;text-transform:none;opacity:.82}
.cmp-col--yn .cmp-col-head{position:relative;background:linear-gradient(120deg,#EEF2FF,#EAF1FF)}
.cmp-col--yn .cmp-col-head::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:var(--grad)}
.cmp-logo svg{height:18px;width:auto;display:block;overflow:visible}
.cmp-col ul li{display:flex;gap:10px;padding:14px 18px;border-top:1px solid var(--line);align-items:flex-start}
.cmp-col ul li p{margin:0;font-size:13.5px;line-height:1.5}
.cmp-col--market p{color:var(--rose-ink);font-weight:500}
.cmp-col--yn p{color:var(--ink);font-weight:600}
.cmp-ic{flex:none;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;margin-top:1px}
.cmp-ic svg{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.cmp-x{background:rgba(201,138,162,.16);color:var(--rose-label)}
.cmp-check{background:var(--grad);color:#fff}
.cmp-vs{justify-self:center;width:54px;height:54px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:900;font-size:15px;letter-spacing:.02em;z-index:3;box-shadow:0 12px 26px -8px rgba(79,70,229,.5),0 0 0 4px var(--bg)}
.cmp-num{font-family:var(--font-display);font-weight:900;font-size:1.2em;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-right:3px;vertical-align:-.06em;display:inline-block;transform:scale(.4);opacity:0;transition:transform .6s cubic-bezier(.34,1.56,.64,1) .25s,opacity .45s .25s}
.cmp.in .cmp-num{transform:scale(1);opacity:1}
.cmp-foot{margin-top:14px;max-width:46%;font-size:12px;font-style:italic;color:var(--soft);text-align:left}
.uline{background-image:var(--grad);background-repeat:no-repeat;background-position:0 100%;background-size:0% 2.5px;padding-bottom:2px;-webkit-box-decoration-break:clone;box-decoration-break:clone;transition:background-size .7s cubic-bezier(.2,.7,.2,1) .35s}
.cmp.in .uline{background-size:100% 2.5px}
.cmp-fade{font-weight:400;opacity:.78}
.tw-quote{opacity:0;transform:translateY(10px);transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}
.tw-quote.in{opacity:1;transform:none}
.tw-caret{display:inline-block;width:2px;height:1.05em;background:var(--accent);margin-left:1px;vertical-align:-.12em;opacity:0;border-radius:2px}
.tw-quote.in .tw-caret{opacity:1;animation:twcaret 1.05s step-end infinite}
.tw-quote.done .tw-caret{opacity:0;animation:none}
@keyframes twcaret{50%{opacity:0}}

/* =============================================================
   9. SECTIONS STANDARD (portfolio, methode, apropos, faq, cta)
   Conteneur 1200px (BRIEF §4), sur fond blanc encadre comme le hero.
   ============================================================= */
.section{position:relative}
.section-inner{max-width:var(--container);margin:0 auto;padding:64px 30px}
.section.alt{background:var(--bg)}
.section .stitle{font-family:var(--font-display);font-weight:900;font-size:clamp(26px,3.2vw,42px);line-height:1.05;letter-spacing:-.02em;max-width:18ch}
.section .sintro{margin:14px 0 0;max-width:62ch;color:var(--ink-soft);font-size:15.5px;line-height:1.6}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* — Portfolio — */
.pf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:24px;margin-top:34px}
.pf-card{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.pf-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px -30px rgba(26,35,64,.5)}
.pf-shot{position:relative;border-bottom:1px solid var(--line)}
.pf-shot .pf-browser{display:flex;gap:5px;padding:9px 12px;background:#f3f4f9;border-bottom:1px solid var(--line)}
.pf-shot .pf-browser i{width:9px;height:9px;border-radius:50%;background:#cfd3e0}
/* Galerie / carrousel d'aperçus */
.pf-gallery{position:relative;overflow:hidden;aspect-ratio:1440/662;background:linear-gradient(135deg,#eef2ff,#f6f7fb)}
.pf-track{display:flex;height:100%;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.pf-slide{flex:0 0 100%;height:100%;display:flex;align-items:center;justify-content:center}
.pf-slide img{width:100%;height:100%;object-fit:contain;display:block}
.pf-slide .pf-ph{color:var(--accent-dark);font-family:var(--font-display);font-weight:900;font-size:24px;letter-spacing:.02em;opacity:.5}
.pf-construction{flex-direction:column;gap:12px;color:var(--accent)}
.pf-construction svg{width:40px;height:40px;animation:gearspin 9s linear infinite}
.pf-construction .pf-cons-label{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-dark);opacity:.8}
@keyframes gearspin{to{transform:rotate(360deg)}}
.pf-nav{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.38);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.5);color:var(--ink);display:grid;place-items:center;cursor:pointer;font-size:22px;line-height:0;padding:0 0 3px;box-shadow:0 4px 12px -7px rgba(26,35,64,.35);transition:background .18s,transform .18s,box-shadow .18s;z-index:2}
.pf-nav:hover{background:rgba(255,255,255,.92);box-shadow:0 6px 16px -8px rgba(26,35,64,.45);transform:translateY(-50%) scale(1.06)}
.pf-prev{left:10px}.pf-next{right:10px}
.pf-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;gap:6px;justify-content:center;z-index:2}
.pf-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.7);box-shadow:0 0 0 1px rgba(26,35,64,.18);cursor:pointer;transition:width .25s,background .25s}
.pf-dot.on{background:var(--accent);width:18px;border-radius:4px}
.pf-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.pf-sector{align-self:flex-start}
.pf-title{font-family:var(--font-display);font-weight:800;font-size:20px}
.pf-desc{font-size:14px;color:var(--ink-soft);line-height:1.55}
.pf-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto;padding-top:8px}
.pf-proof{display:flex;flex-direction:column;line-height:1.1}
.pf-proof .n{font-family:var(--font-display);font-weight:900;font-size:26px;color:var(--data);letter-spacing:-.02em}
.pf-proof .t{font-size:11.5px;color:var(--ink-soft)}
.pf-link{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:14px;color:var(--accent);white-space:nowrap;flex:none}
.pf-proof{min-width:0}
.pf-proof .t{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pf-link:hover{color:var(--accent-dark)}

/* — Methode (timeline verticale animee) — */
.timeline{position:relative;max-width:920px;margin:40px 0 0}
.tl-rail{position:absolute;left:25px;top:14px;bottom:14px;width:4px;border-radius:3px;background:var(--line);overflow:hidden}
.tl-rail-fill{position:absolute;left:0;top:0;width:100%;height:0;border-radius:3px;
  background-image:linear-gradient(180deg,#4F46E5 0%,#6C5CE7 38%,#4AC8F0 80%,#E96BD4 100%);
  background-repeat:no-repeat;background-size:100% var(--tl-h,1200px);transition:height .12s linear}
.tl-step{position:relative;padding-left:80px;padding-bottom:26px}
.tl-step:last-child{padding-bottom:0}
.tl-node{position:absolute;left:3px;top:18px;width:48px;height:48px;border-radius:50%;z-index:2;
  display:grid;place-items:center;background:#fff;color:var(--soft);
  box-shadow:inset 0 0 0 1.5px var(--line),0 6px 16px -10px rgba(26,35,64,.4);
  font-family:var(--font-display);font-weight:800;font-size:16px;
  transition:background .35s,color .35s,box-shadow .35s}
.tl-step.active .tl-node{background:var(--vivant);color:#fff;
  box-shadow:0 0 0 4px var(--bg),0 12px 26px -8px rgba(79,70,229,.5)}
.tl-card{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:22px 24px;box-shadow:var(--shadow-soft);transition:transform .3s,box-shadow .3s}
.tl-step.active .tl-card{transform:translateY(-2px);box-shadow:0 22px 50px -30px rgba(26,35,64,.5)}
.tl-ic{width:46px;height:46px;border-radius:13px;background:var(--pale);display:grid;place-items:center;color:var(--action);flex:none}
.tl-ic svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tl-content h3{font-family:var(--font-display);font-weight:800;font-size:19px;letter-spacing:-.01em}
.tl-content > p{font-size:14.5px;color:var(--soft);margin-top:5px;line-height:1.55;text-wrap:pretty}
.tl-insight{display:flex !important;gap:9px;align-items:flex-start;margin-top:13px;
  background:#F4F1FB;border:1px solid #ece7f7;border-radius:11px;padding:11px 13px;
  font-size:13px;color:var(--action-dark);line-height:1.5}
.tl-insight svg{width:17px;height:17px;fill:none;stroke:var(--action);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;margin-top:1px}
.tl-insight > span{text-wrap:balance}
.tl-emoji{flex:none;font-size:17px;line-height:1.4;margin-top:-1px}
.tl-insight b{font-weight:700;color:var(--action)}
/* Carte resultat (05) — point d'orgue sombre */
.tl-result .tl-card{position:relative;overflow:hidden;border:0;color:#fff;
  background:linear-gradient(120deg,#1E1B4B,#312E81 50%,#4338CA)}
.tl-result .tl-card::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(42% 80% at 100% 0%,rgba(108,92,231,.5),transparent 60%),
  radial-gradient(40% 80% at 90% 120%,rgba(74,200,240,.3),transparent 60%)}
.tl-result .tl-card > *{position:relative;z-index:1}
.tl-result .tl-ic{background:rgba(255,255,255,.14);color:#fff}
.tl-result .tl-content h3{color:#fff}
.tl-result .tl-content > p{color:rgba(255,255,255,.82)}
.tl-note{margin-top:11px;font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.5}

/* — A propos (fondateurs) — */
.apropos-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;margin-top:8px}
.about-cards{display:flex;flex-direction:column;gap:16px}
.about-card{display:flex;gap:16px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 22px;box-shadow:var(--shadow-soft)}
.about-card .avatar{width:54px;height:54px;border-radius:15px;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:900;font-size:20px;
  background:linear-gradient(135deg,#4F46E5,#6C5CE7 38%,#4AC8F0 76%,#E96BD4);background-size:230% 230%;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.2),0 8px 20px -8px rgba(79,70,229,.5);
  animation:avatarFlow 7s ease-in-out infinite}
.about-card .avatar{overflow:hidden}
.about-card .avatar svg{width:100%;height:100%;display:block}
.about-card .avatar.ink{animation-delay:-3.5s}
.about-card .avatar img{width:100%;height:100%;object-fit:cover;border-radius:15px}
@keyframes avatarFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.about-card h3{font-size:16px;font-weight:800}
.about-card h3 .fn{font-weight:500;color:var(--ink-soft)}
.about-card .role{font-size:12.5px;font-weight:600;color:var(--accent);margin:3px 0 6px}
.about-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.55}
.about-card.premium{background:var(--nous-bg);border-color:rgba(79,70,229,.18)}
.about-card.premium .avatar{background:var(--pale);color:var(--accent)}
.about-card.premium .avatar svg{width:24px;height:24px}
.about-card.premium h3{color:var(--accent-dark)}
.apropos-quote{margin-top:26px}
.apropos-quote{margin-top:30px}

/* — FAQ (details/summary, sans JS) — */
.faq{max-width:820px;margin:30px auto 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:box-shadow .2s}
.faq details[open]{box-shadow:var(--shadow-soft)}
.faq summary{list-style:none;cursor:pointer;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-family:var(--font-display);font-weight:700;font-size:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .plus{flex:none;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--accent);color:var(--accent);display:grid;place-items:center;transition:transform .25s;font-size:16px;line-height:1}
.faq details[open] summary .plus{transform:rotate(45deg)}
.faq .answer{padding:0 22px 20px;color:var(--ink-soft);font-size:14.5px;line-height:1.6}

/* — CTA final — */
.cta-final{max-width:var(--container);margin:0 auto;padding:30px 24px 50px}
.cta-panel{position:relative;overflow:hidden;border-radius:26px;padding:56px 40px;text-align:center;color:#fff;
  background:linear-gradient(120deg,#1E1B4B,#312E81 45%,#4338CA);box-shadow:0 30px 70px -34px rgba(67,56,202,.7)}
.cta-panel::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(40% 60% at 12% 0%,rgba(108,92,231,.5),transparent 60%),
  radial-gradient(46% 70% at 100% 100%,rgba(74,200,240,.32),transparent 60%),
  radial-gradient(40% 60% at 78% 0%,rgba(233,107,212,.28),transparent 60%)}
.cta-panel > *{position:relative;z-index:1}
.cta-panel h2{color:#fff;font-weight:900;font-size:clamp(28px,3.6vw,46px);line-height:1.05;max-width:18ch;margin:0 auto}
.cta-panel h2 .grad{background:linear-gradient(100deg,#c7d2fe,#a5f3fc 60%,#f5d0fe);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta-panel p{margin:16px auto 0;max-width:52ch;color:rgba(255,255,255,.82);font-size:16px}
.cta-panel .btn-row{margin-top:28px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.cta-panel .btn-light{background:#fff;color:var(--accent-dark)}
.cta-panel .btn-light:hover{background:#eef2ff;box-shadow:0 12px 30px -10px rgba(0,0,0,.4)}
.cta-panel .btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.cta-panel .btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}

/* =============================================================
   9b. PAGE CONTACT (formulaire Netlify + honeypot)
   ============================================================= */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:start;
  padding:48px 40px;position:relative;z-index:1}
.contact-aside h1{font-family:var(--font-display);font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1.04;letter-spacing:-.025em}
.contact-aside .lead{margin-top:16px;max-width:46ch;color:var(--ink-soft);font-size:16px;line-height:1.6}
.contact-points{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.contact-points li{display:flex;align-items:flex-start;gap:10px;font-size:14.5px;color:var(--ink)}
.contact-points svg{width:20px;height:20px;color:var(--accent);flex:none;margin-top:1px}
.contact-info{margin-top:26px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px;font-size:14px}
.contact-info a{font-weight:600;color:var(--accent)}
.contact-info a:hover{color:var(--accent-dark)}
.contact-info .lbl{color:var(--ink-soft);font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}

.form-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;box-shadow:var(--shadow-soft)}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-family:var(--font-body);font-weight:600;font-size:13.5px;margin-bottom:6px}
.field .req{color:var(--accent)}
.field input,.field textarea,.field select{width:100%;border:1px solid rgba(26,35,64,.14);border-radius:12px;
  padding:12px 14px;font-family:var(--font-body);font-size:15px;color:var(--ink);background:#fff;
  transition:border-color .18s,box-shadow .18s}
.field input::placeholder,.field textarea::placeholder{color:#9aa0b4}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.field textarea{min-height:140px;resize:vertical;line-height:1.5}
.field select{appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235B627D' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-submit{width:100%;justify-content:center;margin-top:6px;font-size:15.5px;padding:14px 22px}
.form-note{margin-top:14px;font-size:12.5px;color:var(--ink-soft);line-height:1.5}
.form-note a{color:var(--accent);font-weight:600}

@media(max-width:820px){
  .contact-grid{grid-template-columns:1fr;gap:28px;padding:36px 26px}
}
@media(max-width:520px){
  .contact-grid{padding:28px 18px}
  .field-row{grid-template-columns:1fr;gap:0}
}

/* =============================================================
   9c. PAGE MERCI (confirmation d'envoi)
   ============================================================= */
.merci{position:relative;z-index:1;text-align:center;padding:72px 40px;display:flex;flex-direction:column;align-items:center}
.merci .check{width:74px;height:74px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;margin-bottom:24px;box-shadow:0 16px 36px -14px rgba(79,70,229,.6)}
.merci .check svg{width:34px;height:34px}
.merci h1{font-family:var(--font-display);font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1.05;letter-spacing:-.025em;max-width:18ch}
.merci p{margin-top:16px;max-width:52ch;color:var(--ink-soft);font-size:16px;line-height:1.6}
.merci .btn-row{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* =============================================================
   9d. BLOG (liste + article)
   ============================================================= */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:34px}
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.blog-grid{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 26px 60px -30px rgba(26,35,64,.5)}
.post-card .pc-cover{aspect-ratio:16/9;background:linear-gradient(135deg,#4F46E5,#6C5CE7 42%,#4AC8F0 86%,#E96BD4);display:flex;align-items:flex-end;padding:16px}
.post-card .pc-cover .pc-cat{background:rgba(255,255,255,.92);color:var(--accent-dark);font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:7px}
.post-card .pc-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-card h2{font-family:var(--font-display);font-weight:800;font-size:18px;line-height:1.25}
.post-card h2 a{color:var(--ink)}
.post-card:hover h2 a{color:var(--accent)}
.post-card .pc-excerpt{font-size:14px;color:var(--ink-soft);line-height:1.55}
.post-card .pc-meta{margin-top:auto;padding-top:8px;display:flex;gap:12px;font-size:12.5px;color:var(--ink-soft)}

/* Article */
.article{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:40px 0 8px}
.breadcrumb{font-size:13px;color:var(--ink-soft);margin-bottom:18px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumb a{color:var(--accent)}
.breadcrumb a:hover{color:var(--accent-dark)}
.breadcrumb span[aria-current]{color:var(--ink)}
.article .post-cat{margin-bottom:14px}
.article h1{font-family:var(--font-display);font-weight:900;font-size:clamp(28px,4vw,44px);line-height:1.06;letter-spacing:-.025em}
.article .post-meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:var(--ink-soft);padding-bottom:22px;border-bottom:1px solid var(--line)}
.article-body{margin-top:26px}
.article-body > * + *{margin-top:18px}
.article-body p,.article-body li{font-size:16.5px;line-height:1.7;color:#2c3357}
.article-body h2{font-family:var(--font-display);font-weight:800;font-size:clamp(21px,2.4vw,27px);letter-spacing:-.02em;margin-top:38px}
.article-body h3{font-family:var(--font-display);font-weight:800;font-size:19px;margin-top:26px}
.article-body ul{padding-left:4px;display:flex;flex-direction:column;gap:10px}
.article-body ul li{display:flex;gap:10px;align-items:flex-start}
.article-body ul li::before{content:"";flex:none;width:9px;height:9px;margin-top:8px;border-radius:50%;background:var(--grad)}
.article-body a{color:var(--accent);font-weight:600;text-decoration:underline;text-decoration-color:rgba(79,70,229,.3);text-underline-offset:2px}
.article-body a:hover{color:var(--accent-dark);text-decoration-color:var(--accent)}
.article-body blockquote{border-left:3px solid;border-image:var(--grad) 1;padding:4px 0 4px 20px;font-family:var(--font-display);font-style:italic;font-weight:600;font-size:19px;color:var(--ink)}
.article-body strong{font-weight:600;color:var(--ink)}
.article-cta{margin-top:40px;background:var(--nous-bg);border:1px solid rgba(79,70,229,.18);border-radius:20px;padding:26px 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.article-cta .t{font-family:var(--font-display);font-weight:800;font-size:18px}
.article-cta .d{font-size:14px;color:var(--ink-soft);margin-top:4px}

/* =============================================================
   10. FOOTER (sombre & premium — fond encre, logo inverse)
   ============================================================= */
.site-footer{position:relative;background:var(--ink);color:rgba(255,255,255,.66);margin-top:10px}
.f-filet{display:block;height:3px;width:100%;background:var(--grad)}
.site-footer .container{max-width:var(--container);margin:0 auto;padding:56px 30px 30px}
.f-grid{display:grid;grid-template-columns:1.5fr .8fr .8fr .9fr;gap:34px}
.f-brand .f-logo{width:150px;height:auto;overflow:visible;margin-bottom:14px}
.f-tag{max-width:34ch;font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.6)}
.f-baseline{margin-top:14px;font-size:14px;color:rgba(255,255,255,.82)}
.f-col h4{font-family:var(--font-display);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:14px}
.f-col ul li{margin-bottom:10px}
.f-col a{color:rgba(255,255,255,.72);font-size:14px;transition:color .18s}
.f-col a:hover{color:#fff}
.f-col .ext{font-size:11px;opacity:.7;margin-left:2px}
.f-bottom{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:rgba(255,255,255,.5)}
.f-bottom .em{color:rgba(255,255,255,.72)}

/* =============================================================
   11. RESPONSIVE
   ============================================================= */
@media(max-width:980px){
  .apropos-grid{grid-template-columns:1fr;gap:30px}
  .f-grid{grid-template-columns:1fr 1fr}
  .f-brand{grid-column:1 / -1}
}
/* Notre approche : carrousel tactile (swipe) sur mobile/petite tablette */
@media(max-width:980px){
  .navB{flex-wrap:wrap}
  .navlinks{display:none}
  .cta-wrap{display:none}
  .nav-toggle{display:inline-flex}
  .site-header.is-open .navlinks{display:flex;flex-direction:column;align-items:stretch;gap:4px;width:100%;order:3;margin:8px 0 0;padding-top:10px;border-top:1px solid var(--line)}
  .site-header.is-open .navlinks a{padding:11px 8px}
  .site-header.is-open .navlinks a::after{display:none}
  .site-header.is-open .cta-wrap{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%;order:4;margin-top:10px}
  .site-header.is-open .cta-wrap .btn{width:100%;justify-content:center}
  .word.far{display:none}
}
@media(max-width:560px){
  .tl-step{padding-left:64px}
  .tl-node{width:40px;height:40px;left:5px;font-size:14px}
  .tl-rail{left:24px}
  .tl-card{flex-direction:column;gap:12px;padding:18px 18px}
}
@media(max-width:720px){
  .constat-wrap{padding:42px 20px 50px}
  .head-grid{grid-template-columns:1fr;gap:24px;align-items:start}
  /* Tableau comparatif : empilé (marché -> VS -> Y&N) sur mobile */
  .cmp-cols{grid-template-columns:1fr;gap:0}
  .cmp-col--yn{transform:none}
  .cmp-vs{margin:-20px 0}
  .cmp-col--yn .cmp-col-head{padding-top:30px}
  .cmp-foot{text-align:left;max-width:none}
  .section-inner{padding:48px 20px}
}
@media(max-width:640px){
  .site-header{padding-top:12px}
  .site-header > .container{padding-inline:16px}
  .navB{padding:10px 12px 10px 16px}
  .brand svg{height:26px}
  .wrap{padding:14px 14px 28px}
  .hero{padding:30px 18px 36px}
  .hero .sub{font-size:16px}
  .phead{padding:18px 22px 0}
  .f-grid{grid-template-columns:1fr}
  .f-bottom{flex-direction:column}
  .abar{flex-direction:column;align-items:stretch;border-radius:18px;padding:14px;gap:10px}
  .abar .pfx{display:none}
  .abar .go{justify-content:center}
  .cta-panel{padding:42px 22px}
  .cta-panel .btn-row{flex-direction:column}
  .cta-panel .btn-row .btn{width:100%;justify-content:center}
}

/* =============================================================
   12. MOUVEMENT REDUIT (BRIEF §4 — respecte partout)
   ============================================================= */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{animation:none!important;transition-duration:.001ms!important}
  .word{opacity:var(--o,.08)!important}
  .pin{position:relative;height:auto}
  .scroll-sec{height:auto!important}
  .track-wrap{overflow-x:auto;padding:0 20px}
  .track{transform:none!important}
  .scard{transform:none!important;opacity:1!important}
  .reveal,.tw-quote{opacity:1;transform:none}
  .hl{background-size:100% 100%}
  .uline{background-size:100% 2.5px}
  .cmp-num{transform:none;opacity:1}
}
