@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300..800;1,9..40,300..800&family=Figtree:ital,wght@0,300..900;1,300..900&family=Fira+Sans:wght@400;500&display=swap');

/* Logo uniquement — conservé (typo de marque) */
@font-face{font-family:'GPKN';src:url('../../fonts/gpkn/gpkn.ttf') format('truetype');font-weight:normal;font-style:normal;font-display:swap}

:root{
  /* ── DARK (variante recolorée — aligné design system app) ── */
  --bg:#0A0A0A;--bg2:#141414;--bg3:#1C1C1C;--bg4:#262626;
  --bl:#1B3461;--bl2:#2C4F8A;--bl3:#5A7FB8;--blg:rgba(44,79,138,.10);
  --cyan:#5A7FB8;--amber:#F59E0B;--teal:#3E8E73;
  --iv:#F3EEE3;--w:#F3EEE3;--w2:rgba(243,238,227,.88);--w3:rgba(243,238,227,.72);
  --w4:rgba(243,238,227,.4);--w5:rgba(243,238,227,.06);
  --t1:rgba(243,238,227,.92);--t2:rgba(243,238,227,.75);--t3:rgba(243,238,227,.55);
  --t4:rgba(243,238,227,.45);--t5:rgba(243,238,227,.35);--t6:rgba(243,238,227,.5);
  --t7:rgba(243,238,227,.65);--t8:rgba(243,238,227,.82);--t9:rgba(243,238,227,.85);
  --tbg1:rgba(255,255,255,.06);--tbg2:rgba(255,255,255,.04);--tbg3:rgba(255,255,255,.02);
  --tbg4:rgba(255,255,255,.05);--tbg5:rgba(255,255,255,.08);
  --bord:rgba(255,255,255,.10);--bord2:rgba(255,255,255,.16);
  --ok:#10C987;--warn:#F59E0B;--err:#E53E3E;
  --glow:rgba(44,79,138,.20);
  --ss:'DM Sans',ui-sans-serif,system-ui,-apple-system,sans-serif;
  --sf:'Figtree',Georgia,serif;
  --sm:'Fira Sans',ui-sans-serif,system-ui,sans-serif;
}

/* ── LIGHT (thème par défaut — design system app) ─────── */
[data-theme="light"]{
  --bg:#FFFFFF;--bg2:#F7F7F7;--bg3:#EEEEEE;--bg4:#E4E6EB;
  --bl:#C5D3E8;--bl2:#2B57A6;--bl3:#4571C0;--blg:rgba(43,87,166,.08);
  --cyan:#2B57A6;--amber:#F59E0B;--teal:#1F5C4A;
  --iv:#0C0B0A;--w:#111827;--w2:rgba(17,24,39,.88);--w3:rgba(17,24,39,.65);
  --w4:rgba(17,24,39,.35);--w5:rgba(17,24,39,.04);
  --t1:rgba(17,24,39,.92);--t2:rgba(17,24,39,.7);--t3:rgba(17,24,39,.5);
  --t4:rgba(17,24,39,.4);--t5:rgba(17,24,39,.3);--t6:rgba(17,24,39,.45);
  --t7:rgba(17,24,39,.6);--t8:rgba(17,24,39,.78);--t9:rgba(17,24,39,.82);
  --tbg1:rgba(17,24,39,.04);--tbg2:rgba(17,24,39,.03);--tbg3:rgba(17,24,39,.02);
  --tbg4:rgba(17,24,39,.04);--tbg5:rgba(17,24,39,.06);
  --bord:rgba(17,24,39,.10);--bord2:rgba(17,24,39,.16);
  --ok:#10C987;--warn:#F59E0B;--err:#E53E3E;
  --glow:rgba(43,87,166,.14);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{font-family:var(--ss);background:var(--bg);color:var(--w);-webkit-font-smoothing:antialiased;overflow-x:clip;max-width:100%;transition:background .4s,color .4s; }
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:var(--bl3);border-radius:3px}
a{text-decoration:none;color:inherit}
/* Évite qu'un mot trop long (titres display) ne déborde horizontalement sur petits écrans */
.hero-h1,.feat-h,.koko-h2,.cta-h2,.sol-h1,.stat-n,.cta-eyb,.feat-label{overflow-wrap:break-word;max-width:100%}

/* ── NAV ─────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;background:rgba(6,8,14,.85);backdrop-filter:blur(24px);border-bottom:1px solid var(--bord);transition:all .3s}
[data-theme="light"] nav{background:rgba(244,246,250,.9)}
.nlogo{display:flex;align-items:center;gap:8px;cursor:pointer}
.nlogo-mark{width:32px;height:32px;background:linear-gradient(150deg,#3E6BA8,var(--bl3) 45%,hsl(262,92%,66%) 105%);border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px hsla(262,80%,55%,.4),inset 0 1px 0 rgba(255,255,255,.32),inset 0 0 0 1px rgba(255,255,255,.08)}
.nlogo-mark span{font-family:'GPKN',Georgia,serif;font-weight:600;font-size:28px;color:#fff;line-height:0;margin-top:-1px;text-shadow:0 1px 2px rgba(40,20,70,.4)}
[data-theme="light"] .nlogo-mark span{color:#fff}
.nlogo-text{font-family:'GPKN',sans-serif;font-weight:400;font-size:18px;letter-spacing:-.02em}
.nlinks{display:flex;align-items:center;gap:24px}
@media(min-width:769px){nav>.nlinks{margin-left:38px;margin-right:auto}nav>.ncta{margin-left:12px}}
.nlink{font-size:13px;color:var(--t2);cursor:pointer;background:none;border:none;font-family:var(--ss);padding:0;transition:color .12s;text-decoration:none;display:inline-block}
.nlink:hover,.nlink.act{color:var(--w)}
.ndrop{position:relative}
.ndrop-btn{font-size:13px;color:var(--t2);cursor:pointer;background:none;border:none;font-family:var(--ss);display:flex;align-items:center;gap:4px;transition:color .12s}
.ndrop-btn:hover{color:var(--w)}
.ndrop-menu{position:absolute;top:calc(100% + 12px);left:-16px;background:var(--bg3);border:1px solid var(--bord2);border-radius:10px;padding:8px;min-width:240px;display:none;z-index:300;box-shadow:0 20px 60px rgba(0,0,0,.6),0 0 20px var(--glow)}
.ndrop-menu.open{display:flex;flex-direction:column;gap:2px}
.ndrop-item{padding:10px 12px;border-radius:6px;cursor:pointer;transition:background .12s;display:flex;align-items:center;gap:11px}
.ndrop-item:hover{background:var(--w5)}
.ndrop-ico{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ndrop-ico svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ndrop-item-txt{min-width:0}
.ndrop-item-label{font-size:12px;font-weight:600;color:var(--w);margin-bottom:1px}
.ndrop-item-desc{font-size:11px;color:var(--t2)}
.ncta{padding:8px 18px;font-size:13px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--bl2),var(--bl3));border:none;cursor:pointer;border-radius:6px;transition:all .2s;font-family:var(--ss);box-shadow:0 2px 12px var(--glow)}
.ncta:hover{background:linear-gradient(135deg,var(--bl3),var(--cyan));box-shadow:0 4px 20px var(--glow);transform:translateY(-1px)}

/* ── PAGE SYSTEM ─────────────────────────────────── */
.page{display:none;min-height:100vh}
.page.act{display:block}

/* ── SHARED COMPONENTS ───────────────────────────── */
.eyb{font-family:var(--sm);font-size:29px;text-transform:uppercase;color:var(--cyan)}
.eyb.inv{color:var(--t7)}
.eyb.dk{color:var(--cyan)}
.btn-iv{padding:12px 24px;font-size:14px;font-weight:600;color:#06080E;background:linear-gradient(135deg,#fff,#e8f4ff);border:none;cursor:pointer;border-radius:7px;transition:all .2s;font-family:var(--ss);box-shadow:0 2px 16px rgba(27,52,97,.15);text-decoration:none;display:inline-block}
.btn-iv:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(27,52,97,.25)}
[data-theme="light"] .btn-iv{background:linear-gradient(135deg,var(--bl2),var(--bl3));color:#fff;box-shadow:0 2px 16px rgba(27,52,97,.2)}
.btn-bl{padding:12px 24px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--bl2),var(--bl3));border:none;cursor:pointer;border-radius:7px;transition:all .2s;font-family:var(--ss);box-shadow:0 2px 12px var(--glow)}
.btn-bl:hover{box-shadow:0 4px 20px var(--glow);transform:translateY(-1px)}
.btn-out{padding:11px 22px;font-size:13px;font-weight:500;color:var(--w);background:var(--w5);border:1px solid var(--bord2);cursor:pointer;border-radius:7px;transition:all .2s;font-family:var(--ss)}
.btn-out:hover{background:#ffffff39;border-color:var(--w);box-shadow:0 0 12px var(--glow)}
.btn-tr{font-size:13px;font-weight:500;color:var(--cyan);background:none;border:none;cursor:pointer;font-family:var(--ss);display:inline-flex;align-items:center;gap:5px;transition:color .12s}
.btn-tr:hover{color:var(--w)}

/* ── BADGE ───────────────────────────────────────── */
.badge{font-family:var(--sm);font-size:8px;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:99px;display:inline-flex;align-items:center;gap:5px}
.b-bl{background:rgba(27,52,97,.1);color:var(--cyan)}
.b-ok{background:rgba(13,184,120,.12);color:var(--ok)}
.b-warn{background:rgba(245,158,11,.12);color:var(--warn)}
.b-err{background:rgba(239,68,68,.12);color:var(--err)}
.b-gr{background:var(--w5);color:var(--t2);border:1px solid var(--bord)}

/* ── KOKO BLOCK ──────────────────────────────────── */
.kblock{background:rgba(27,52,97,.06);border:1px solid rgba(27,52,97,.15);border-left:2px solid var(--cyan);padding:10px 14px;display:flex;gap:9px;align-items:flex-start;margin-top:12px;border-radius:4px}
.kbl{font-family:var(--sm);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);white-space:nowrap;margin-top:1px;flex-shrink:0}
.kbt{font-size:11px;font-weight:300;color:var(--t2);line-height:1.65}
.kbt strong{color:var(--t2);font-weight:500}

/* ── CHAT ────────────────────────────────────────── */
.chat{background:var(--bg);border:1px solid var(--bord);border-radius:8px;overflow:hidden;padding:14px;display:flex;flex-direction:column;gap:10px}
.cmsg{display:flex;flex-direction:column;gap:2px}
.cfr{font-family:var(--sm);font-size:7px;letter-spacing:.12em;text-transform:uppercase}
.cfr.u{color:var(--t6)}
.cfr.a{color:var(--cyan)}
.cbub{font-size:12px;font-weight:300;line-height:1.65;padding:9px 12px;border-radius:5px;max-width:95%}
.cmsg.u .cbub{background:var(--w5);color:var(--t8);align-self:flex-end}
.cmsg.a .cbub{background:rgba(27,52,97,.08);border-left:2px solid var(--cyan);color:var(--t9)}
.cin{display:flex;gap:8px;margin-top:4px}
.cinb{flex:1;padding:8px 12px;font-size:11px;border:1px solid var(--bord2);background:var(--w5);color:var(--t6);font-style:italic;border-radius:4px}
.cins{width:30px;height:30px;background:var(--bl2);display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;flex-shrink:0}
.cins svg{width:12px;height:12px;stroke:var(--w);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── APP SHELL MOCKUP ────────────────────────────── */
.app-shell{background:var(--bg);border:1px solid var(--bord2);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:180px 1fr;box-shadow:0 32px 100px rgba(0,0,0,.6),0 0 40px rgba(27,52,97,.08)}
.sol-screen{width:100%;max-width:2340px;display:block; border:1px solid var(--bord2);border-radius:10px;box-shadow:0 32px 100px rgba(0,0,0,.6),0 0 40px rgba(27,52,97,.08)}
/* Arrivée des screens (Cap Table / Fundraising) au scroll */
.feat-img-reveal{opacity:0;transform:translateX(var(--reveal-x,0)) translateY(46px) scale(.94);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1);will-change:opacity,transform}
.feat-img-reveal.in-view{opacity:1;transform:translateX(0) translateY(0) scale(1)}
@media (prefers-reduced-motion:reduce){.feat-img-reveal{opacity:1;transform:none;transition:none}}
.mock-scr{display:block;width:100%}
.scr-light{display:none}
[data-theme="light"] .scr-light{display:block}
[data-theme="light"] .scr-dark{display:none}
.sidebar{background:var(--bg2);border-right:1px solid var(--bord);padding:14px 0;display:flex;flex-direction:column}
.sb-logo{padding:8px 14px 14px;font-weight:700;font-size:13px;letter-spacing:-.025em;display:flex;align-items:center;gap:5px;border-bottom:1px solid var(--bord);margin-bottom:6px}
.ndot{width:5px;height:5px;border-radius:50%;background:var(--cyan);display:inline-block;margin-bottom:1px;box-shadow:0 0 6px var(--cyan)}
.sbi{padding:6px 14px;font-size:11px;color:var(--t3);cursor:default;border-left:2px solid transparent;transition:all .12s}
.sbi.act{color:var(--w);background:rgba(27,52,97,.1);border-left-color:var(--cyan)}
.appmain{background:var(--bg3);padding:18px;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.ahd{font-size:14px;font-weight:600;color:var(--w);margin-bottom:2px}
.asub{font-family:var(--sm);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:8px}

/* Donut */
.drow{display:grid;grid-template-columns:140px 1fr;gap:12px;align-items:center}
.dw{position:relative;width:120px;height:120px}
.dw svg{width:100%;height:100%}
.dc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.dcn{font-family:var(--sm);font-weight:500;font-size:18px;color:var(--w)}
.dcl{font-family:var(--sm);font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3)}
.leg{display:flex;flex-direction:column;gap:5px}
.legi{display:grid;grid-template-columns:10px 1fr auto;gap:6px;align-items:center;font-size:10px}
.legd{width:8px;height:8px;border-radius:2px}
.legn{color:var(--t6)}
.legp{font-family:var(--sm);font-size:10px;color:var(--t2)}

/* Table */
.tbl{background:var(--bg);border:1px solid var(--bord);border-radius:5px;overflow:hidden}
.tblh,.tblr{display:grid;padding:7px 10px;font-size:10px;border-bottom:1px solid var(--bord);align-items:center}
.tblh{background:var(--tbg3)}
.tblh span{font-family:var(--sm);font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--t6)}
.tblr:last-child{border-bottom:none}
.c0{font-weight:500;color:var(--w);font-size:10px}
.c1{font-family:var(--sm);font-size:7px;letter-spacing:.06em;text-transform:uppercase;background:rgba(27,52,97,.12);color:var(--cyan);padding:2px 6px;border-radius:99px;display:inline-block;margin-top:2px}
.c2{font-family:var(--sm);font-size:10px;color:var(--t6);text-align:right}
.c3{font-family:var(--sm);font-size:10px;color:var(--ok);text-align:right}

/* KPIs */
.kpi-row{display:grid;gap:8px}
.kpi-card{background:var(--bg);border:1px solid var(--bord);border-radius:5px;padding:10px 12px}
.kpi-l{font-family:var(--sm);font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:5px}
.kpi-n{font-family:var(--sm);font-weight:500;font-size:18px;color:var(--w);line-height:1}
.kpi-n.ok{color:var(--ok)}.kpi-n.warn{color:var(--warn)}.kpi-n.err{color:var(--err)}
.kpi-sub{font-size:9px;color:var(--t3);margin-top:2px}

/* Fund pipeline */
.fund-bar{height:6px;background:var(--tbg5);border-radius:3px;overflow:hidden;margin:8px 0}
.fund-bf{height:100%;background:var(--bl2);border-radius:3px}
.fund-rh,.fund-rw{display:grid;grid-template-columns:1.4fr .8fr 1fr;padding:7px 0;font-size:10px;border-bottom:1px solid var(--bord)}
.fund-rh{font-family:var(--sm);font-size:7px;letter-spacing:.1em;text-transform:uppercase;color:var(--t6)}
.fund-rw:last-child{border-bottom:none}
.fc0{color:var(--w);font-weight:500}.fc0.m{color:var(--t7)}
.sp{font-family:var(--sm);font-size:7px;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:99px}
.sps{background:rgba(13,184,120,.1);color:var(--ok)}
.spt{background:rgba(27,52,97,.12);color:var(--cyan)}
.spd{background:rgba(245,158,11,.1);color:var(--warn)}
.spc{background:var(--w5);color:var(--t2)}
.fa{font-family:var(--sm);font-size:10px;text-align:right;color:var(--ok)}
.fa.m{color:var(--t6)}

/* Chart SVG */
.chart-svg{width:100%;height:80px}

/* Fund-t */
.fund-t{font-size:12px;font-weight:600;color:var(--w)}
.fund-st{font-family:var(--sm);font-size:8px;background:rgba(245,158,11,.1);color:var(--warn);padding:3px 8px;border-radius:99px}

/* ── HERO ────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:120px 40px 60px;position:relative;overflow:hidden;text-align:center}
/* contenu du hero au-dessus des couches de fond absolues */
.hero>:not(.hero-glow):not(.hero-cols):not(.hero-grid):not(.hero-badges){position:relative;z-index:1}
.hero-glow{  background:
    radial-gradient(40% 50% at 22% 30%,color-mix(in srgb,var(--m-pilot) 68%,transparent),transparent 70%),
    radial-gradient(36% 46% at 78% 24%,color-mix(in srgb,var(--m-fund) 64%,transparent),transparent 70%),
    radial-gradient(44% 52% at 72% 66%,color-mix(in srgb,var(--m-rh) 58%,transparent),transparent 72%),
    radial-gradient(40% 48% at 28% 68%,color-mix(in srgb,var(--m-fin) 58%,transparent),transparent 72%),
    radial-gradient(32% 42% at 50% 46%,color-mix(in srgb,var(--m-cap) 50%,transparent),transparent 70%);
  animation:auroraDrift 20s ease-in-out infinite alternate}
@keyframes auroraDrift{0%{transform:translateX(-50%) translateY(0) scale(1)}50%{transform:translateX(-47%) translateY(-14px) scale(1.06)}100%{transform:translateX(-53%) translateY(10px) scale(1.03)}}
@media (prefers-reduced-motion:reduce){.hero-glow{animation:none}}
/* Colonnes de gradient alternées : couleur→transparent, transparent→couleur */
.hero-cols{position:absolute;inset:0;display:grid;grid-template-columns:repeat(7,1fr);pointer-events:none;opacity:.55;
  mask-image:radial-gradient(ellipse 90% 75% at 50% 35%,black 0%,transparent 85%)}
.hero-cols span{display:block;height:100%;position:relative;overflow:hidden}
.hero-cols span:nth-child(1){background:linear-gradient(to bottom,color-mix(in srgb,var(--m-pilot) 100%,transparent),transparent 100%);color:var(--m-pilot)}
.hero-cols span:nth-child(2){background:linear-gradient(to top,color-mix(in srgb,var(--m-fund) 100%,transparent),transparent 100%);color:var(--m-fund)}
.hero-cols span:nth-child(3){background:linear-gradient(to bottom,color-mix(in srgb,var(--m-rh) 100%,transparent),transparent 75%);color:var(--m-rh)}
.hero-cols span:nth-child(4){background:linear-gradient(to top,color-mix(in srgb,var(--m-cap) 100%,transparent),transparent 100%);color:var(--m-cap)}
.hero-cols span:nth-child(5){background:linear-gradient(to bottom,color-mix(in srgb,var(--m-fin) 100%,transparent),transparent 75%);color:var(--m-fin)}
.hero-cols span:nth-child(6){background:linear-gradient(to top,color-mix(in srgb,var(--m-fund) 100%,transparent),transparent 100%);color:var(--m-fund)}
.hero-cols span:nth-child(7){background:linear-gradient(to bottom,color-mix(in srgb,var(--m-pilot) 100%,transparent),transparent 75%);color:var(--m-pilot)}
/* Graphique de la solution en fond de chaque colonne, alterné haut/bas selon le sens du gradient */
.hero-cols .col-chart{position:absolute;left:50%;transform:translateX(-50%);width:155%;height:auto;opacity:1;top:14%}
.hero-cols span:nth-child(even) .col-chart{top:26%}
.hero-cols .col-chart .shc-grid{stroke:currentColor;stroke-width:1;opacity:.5}
.hero-cols .col-chart .shc-bars{fill:currentColor;opacity:.7}
.hero-cols .col-chart .shc-area{fill:currentColor;opacity:.2}
.hero-cols .col-chart .shc-line{fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.hero-cols .col-chart .shc-dot{fill:currentColor}
.hero-cols .col-chart .shc-stroke{fill:none;stroke:currentColor;stroke-width:2;opacity:.8}
.hero-cols .col-chart .shc-soft{fill:currentColor;opacity:.5}
.hero-cols .col-chart .shc-ring{fill:none;stroke:currentColor;stroke-width:26;stroke-linecap:butt}
.hero-cols .col-chart .shc-track{fill:none;stroke:currentColor;stroke-width:26;opacity:.28}
[data-theme="light"] .hero-cols{opacity:.45}
/* ===== Animation d'entrée du hero ===== */
/* Les colonnes partent du centre et se déploient vers leur position actuelle */
.hero-cols span{animation:heroColSpread .95s cubic-bezier(.22,1,.36,1) both}
.hero-cols span:nth-child(1){--col-from:300%;animation-delay:.18s}
.hero-cols span:nth-child(2){--col-from:200%;animation-delay:.12s}
.hero-cols span:nth-child(3){--col-from:100%;animation-delay:.06s}
.hero-cols span:nth-child(4){--col-from:0%;animation-delay:0s}
.hero-cols span:nth-child(5){--col-from:-100%;animation-delay:.06s}
.hero-cols span:nth-child(6){--col-from:-200%;animation-delay:.12s}
.hero-cols span:nth-child(7){--col-from:-300%;animation-delay:.18s}
@keyframes heroColSpread{from{transform:translateX(var(--col-from))}to{transform:translateX(0)}}
/* Cœur central blanc au départ (hors de .hero-cols pour ne pas être dilué par son opacité/filtre) :
   les autres couleurs semblent surgir de derrière en se déployant. */
.hero::after{content:"";position:absolute;top:0;left:50%;width:14.3%;height:100%;transform:translateX(-50%);z-index:1;background:var(--bg);pointer-events:none;
  -webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 45%,transparent 88%);
  mask-image:linear-gradient(to bottom,#000 0%,#000 45%,transparent 88%);
  animation:heroCenterWhite 1.6s ease-out both}
@keyframes heroCenterWhite{0%{opacity:1;transform:translateX(-50%) scaleX(1.5)}60%{opacity:.6}100%{opacity:0;transform:translateX(-50%) scaleX(1)}}
/* Le screenshot du tableau de bord passe au-dessus du cœur blanc central */
.hero-mockup{z-index:2!important}
/* Couleurs vives au départ, puis retour à l'état actuel */
.hero-cols{animation:heroColsVivid 1.5s ease-out both}
@keyframes heroColsVivid{0%{filter:saturate(3) brightness(1.5)}50%{filter:saturate(2.6) brightness(1.35)}100%{filter:saturate(1) brightness(1)}}
/* Titre, sous-titre et CTA masqués pendant l'animation, révélés à la fin */
.hero-h1,.hero-sub,.hero-acts{animation:heroTextIn .7s cubic-bezier(.22,1,.36,1) both}
.hero-h1{animation-delay:1s}
.hero-sub{animation-delay:1.15s}
.hero-acts{animation-delay:1.3s}
@keyframes heroTextIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion:reduce){
  .hero-cols,.hero-cols span,.hero-h1,.hero-sub,.hero-acts{animation:none!important}
  .hero::after{display:none}
}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(27,52,97,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(27,52,97,.06) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 0%,transparent 80%);pointer-events:none}
[data-theme="light"] .hero-glow{opacity:.92;filter:blur(34px);
  background:
    radial-gradient(40% 50% at 22% 30%,color-mix(in srgb,var(--m-pilot) 44%,transparent),transparent 70%),
    radial-gradient(36% 46% at 78% 24%,color-mix(in srgb,var(--m-fund) 40%,transparent),transparent 70%),
    radial-gradient(44% 52% at 72% 66%,color-mix(in srgb,var(--m-rh) 36%,transparent),transparent 72%),
    radial-gradient(40% 48% at 28% 68%,color-mix(in srgb,var(--m-fin) 36%,transparent),transparent 72%),
    radial-gradient(32% 42% at 50% 46%,color-mix(in srgb,var(--m-cap) 30%,transparent),transparent 70%)}
[data-theme="light"] .hero-grid{background-image:linear-gradient(rgba(27,52,97,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(27,52,97,.06) 1px,transparent 1px)}
/* ── HERO FLOATING BADGES ────────────────────────── */
.hero-badges{position:absolute;inset:0;z-index:2;pointer-events:none}
.hbadge{position:absolute;display:flex;align-items:center;gap:10px;
  padding:9px 14px 9px 10px;border-radius:13px;
  background:color-mix(in srgb,var(--bg2) 86%,transparent);
  border:1px solid var(--bord2);
  box-shadow:0 18px 44px rgba(0,0,0,.30),0 0 0 1px color-mix(in srgb,var(--m) 22%,transparent) inset;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  text-align:left;white-space:nowrap;
  opacity:0;
  transform:translate3d(var(--tx,0px),calc(24px + var(--par,0px)),0) scale(.94);
  transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1);
  animation:hbFloat 7s ease-in-out infinite;
  will-change:transform}
.hero-badges.in .hbadge{opacity:1;transform:translate3d(0,var(--par,0px),0) scale(1)}
.hb-ico{width:30px;height:30px;flex-shrink:0;border-radius:9px;display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb,var(--m) 16%,transparent);color:var(--m)}
.hb-ico svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.hb-ok-ico{color:var(--ok)}
.hb-l{font-size:12px;font-weight:600;color:var(--t1);line-height:1.25}
.hb-v{font-family:var(--sm);font-size:10px;color:var(--t2);line-height:1.3}
.hb-dot{width:9px;height:9px;flex-shrink:0;margin:0 4px 0 6px;border-radius:50%;background:var(--m);
  box-shadow:0 0 0 0 color-mix(in srgb,var(--m) 70%,transparent);animation:hbPulse 1.8s ease-out infinite}
/* positions autour du titre */
.hb-cap {top:20%;  left:13%}
.hb-fin {top:16%;  right:14%}
.hb-koko{top:46%;  left:10%}
.hb-fund{top:52%;  right:11%}
.hb-ok  {top:73%;  left:17%}
/* décalage d'entrée alterné (les badges glissent depuis l'extérieur) */
.hb-cap,.hb-koko,.hb-ok{--tx:-16px}
.hb-fin,.hb-fund{--tx:16px}
.hb-fin {animation-delay:-1.4s}
.hb-koko{animation-delay:-2.6s}
.hb-fund{animation-delay:-3.8s}
.hb-ok  {animation-delay:-5s}
@keyframes hbFloat{0%,100%{translate:0 0}50%{translate:0 -9px}}
@keyframes hbPulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--m) 60%,transparent)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (prefers-reduced-motion:reduce){.hbadge{animation:none}.hb-dot{animation:none}}
@media (max-width:1080px){.hero-badges{display:none}}
/* version téléphone : 2 badges seulement, en haut/bas, plus compacts */
@media (max-width:900px){
  .hero-badges{display:block}
  .hbadge{display:none;padding:7px 12px 7px 8px;border-radius:11px;
    box-shadow:0 12px 30px rgba(0,0,0,.28),0 0 0 1px color-mix(in srgb,var(--m) 20%,transparent) inset}
  .hb-cap,.hb-fund{display:flex}
  .hb-ico{width:26px;height:26px;border-radius:8px}
  .hb-ico svg{width:13px;height:13px}
  .hb-l{font-size:11px}.hb-v{font-size:9px}
  .hb-cap {top:13%;  left:5%;  right:auto}
  .hb-fund{top:auto; bottom:13%; right:5%; left:auto}
}

.hero-live{display:inline-flex;align-items:center;gap:7px;padding:5px 12px 5px 8px;background:rgba(27,52,97,.08);border:1px solid rgba(27,52,97,.25);border-radius:99px;font-size:11px;font-weight:500;color:var(--cyan);margin-bottom:24px}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-h1{font-family:'Boldonse',sans-serif;font-size:clamp(36px,4vw,82px);font-weight:400;line-height:1.2;letter-spacing: -0.02em;margin-bottom:20px;max-width:820px;margin-top: 60px; text-transform: uppercase}
.hero-h1 em{font-family:'Boldonse';font-style:normal;font-weight:600;color:var(--bl)}
.hero-sub{font-size:clamp(15px,1.8vw,19px);font-weight:300;color:var(--t2);line-height:1.5; max-width:520px;margin:0 auto 36px}
.hero-acts{display:flex;gap:10px;justify-content:center;margin-bottom:64px}

/* ── HERO MOCKUP ─────────────────────────────────── */
.hero-mockup{width:100%;max-width:1000px;position:relative}
.mock-win{background:var(--bg3);border:1px solid var(--bord2);border-radius:12px;overflow:hidden;box-shadow:0 48px 120px rgba(0,0,0,.65),0 0 50px rgba(27,52,97,.1)}
.mock-bar{height:34px;background:var(--bg2);border-bottom:1px solid var(--bord);display:flex;align-items:center;padding:0 12px;gap:6px}
.md{width:9px;height:9px;border-radius:50%}
.md1{background:#FF5F57}.md2{background:#FFBD2E}.md3{background:#28CA41}
.mock-url{flex:1;background:var(--tbg2);border-radius:3px;height:18px;display:flex;align-items:center;padding:0 10px;margin:0 12px}
.mock-url span{font-family:var(--sm);font-size:9px;color:var(--t2)}
.mock-body{display:grid;grid-template-columns:200px 1fr;min-height:480px}
.mock-sb{background:var(--bg);border-right:1px solid var(--bord);padding:12px 0;display:flex;flex-direction:column}
.msb-logo{padding:8px 14px 12px;font-weight:700;font-size:13px;letter-spacing:-.025em;border-bottom:1px solid var(--bord);margin-bottom:6px;display:flex;align-items:center;gap:4px}
.msb-sec{padding:4px 14px 2px;font-family:var(--sm);font-size:7px;letter-spacing:.18em;text-transform:uppercase;color:var(--t4);margin-top:4px}
.msb-item{padding:6px 14px;font-size:11px;color:var(--t3);display:flex;align-items:center;gap:7px;border-left:2px solid transparent;cursor:default}
.msb-item svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;opacity:.6;flex-shrink:0}
.msb-item.a{color:var(--w);background:rgba(27,52,97,.08);border-left-color:var(--cyan)}
.msb-item.a svg{opacity:1}
.mock-main{background:var(--bg2);padding:20px;display:flex;flex-direction:column;gap:10px;overflow:hidden}

/* ── STATS ───────────────────────────────────────── */
.stats{background:var(--bg2);border-top:1px solid var(--bord);border-bottom:1px solid var(--bord)}
.stats-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--bord)}
.stat{background:var(--bg2);padding:40px 32px}
.stat-n{font-family:'Boldonse',sans-serif;font-size:clamp(30px,3.6vw,46px);font-weight:400;letter-spacing:-.04em;line-height:1;text-transform:uppercase;margin-bottom:12px}
.stat-n span{color:var(--bord); background:linear-gradient(110deg,hsl(207, 74%, 48%),hsl(228,72%,42%) 45%,hsl(203, 94%, 63%) 75%,hsl(218, 84%, 58%));background-size:300% auto;-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 18px hsla(218,74%,46%,.22))}
.stat-l{font-size:14px;font-weight:300;color:var(--t2);line-height:1.55}

/* ── FEATURES SECTION ────────────────────────────── */
.feat-split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;padding:80px 40px;max-width:1200px;margin:0 auto;border-bottom:1px solid var(--bord)}
.feat-split.rev{direction:rtl}
.feat-split.rev>*{direction:ltr}
.feat-label{font-family:var(--sm);font-size:19px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.feat-label::before{content:'';display:block;width:16px;height:1px;background:var(--cyan)}
.feat-h{font-size:clamp(28px,3.5vw,44px);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:14px}
.feat-body{font-size:15px;font-weight:300;color:var(--t2);line-height:1.75;margin-bottom:24px}
.feat-list{display:flex;flex-direction:column;gap:9px}
.feat-li{font-size:14px;color:var(--t6);display:flex;align-items:flex-start;gap:9px}
.feat-li::before{content:'→';color:var(--cyan);flex-shrink:0;margin-top:1px}

/* ── VIDEO SECTION ───────────────────────────────── */
.video-section{padding:100px 40px;background:var(--bg)}
.video-inner{max-width:1280px;margin:0 auto}
.video-frame{position:relative;width:100%;border-radius:16px;overflow:hidden;border:1px solid rgba(27,52,97,.2);box-shadow:0 60px 140px rgba(0,0,0,.8),0 0 60px rgba(27,52,97,.1),inset 0 1px 0 var(--tbg2)}
.vsim{width:100%;background:var(--bg2);display:flex;flex-direction:column;min-height:640px}
.vsim-topbar{height:40px;background:var(--bg);border-bottom:1px solid var(--bord);display:flex;align-items:center;padding:0 16px;gap:8px;flex-shrink:0}
.vsim-dots{display:flex;gap:5px}
.vtd{width:10px;height:10px;border-radius:50%}
.vtd1{background:#FF5F57}.vtd2{background:#FFBD2E}.vtd3{background:#28CA41}
.vsim-url{flex:1;background:var(--tbg2);border-radius:4px;height:22px;display:flex;align-items:center;padding:0 12px;margin:0 16px;max-width:280px}
.vsim-url span{font-family:var(--sm);font-size:9px;color:var(--t4)}
.vsim-body{display:flex;flex:1;min-height:0;overflow:hidden}
.vsim-sb{width:200px;background:var(--bg);border-right:1px solid var(--bord);padding:14px 0;flex-shrink:0;display:flex;flex-direction:column}
.vsb-logo{padding:8px 16px 14px;font-weight:700;font-size:13px;letter-spacing:-.025em;border-bottom:1px solid var(--bord);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.vsb-sec{padding:4px 16px 2px;font-family:var(--sm);font-size:7px;letter-spacing:.18em;text-transform:uppercase;color:var(--t5);margin-top:5px}
.vsb-item{padding:7px 16px;font-size:11px;color:var(--t4);display:flex;align-items:center;gap:8px;border-left:2px solid transparent;cursor:default}
.vsb-item svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;opacity:.7}
.vsb-item.a{color:var(--w);background:rgba(27,52,97,.08);border-left-color:var(--cyan)}
.vsb-item.warn{color:var(--amber)}
.vsb-item.err{color:var(--err)}
.vsb-item.a svg{opacity:1}
.vsb-koko{margin-top:auto;padding:10px 14px;border-top:1px solid var(--bord)}
.vsb-koko-inner{background:rgba(27,52,97,.06);border:1px solid rgba(27,52,97,.15);border-radius:6px;padding:8px 10px;display:flex;align-items:center;gap:7px}
.vsb-koko-dot{width:5px;height:5px;border-radius:50%;background:var(--ok);flex-shrink:0;animation:blink 2s ease-in-out infinite}
.vsb-koko-txt{font-size:10px;color:var(--t3);line-height:1.4}
.vsb-koko-lbl{font-family:var(--sm);font-size:7px;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);display:block;margin-bottom:2px}
.vsim-main{flex:1;padding:16px;overflow:hidden;display:flex;flex-direction:column;gap:10px;min-width:0}
.vkpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.vkpi{background:var(--bg3);border:1px solid var(--bord);border-radius:6px;padding:12px 14px;position:relative;overflow:hidden}
.vkpi::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;opacity:.6}
.vkpi.ok-accent::before{background:var(--ok)}
.vkpi.warn-accent::before{background:var(--warn)}
.vkpi.bl-accent::before{background:var(--cyan)}
.vkpi-l{font-family:var(--sm);font-size:7px;letter-spacing:.12em;text-transform:uppercase;color:var(--t5);margin-bottom:6px}
.vkpi-n{font-family:var(--sm);font-weight:500;font-size:20px;color:var(--w);line-height:1}
.vkpi-n.ok{color:var(--ok)}.vkpi-n.warn{color:var(--amber)}.vkpi-n.bl{color:var(--cyan)}
.vkpi-delta{font-size:9px;margin-top:4px}
.vkpi-delta.up{color:var(--ok)}.vkpi-delta.dn{color:var(--err)}.vkpi-delta.neu{color:var(--t5)}
.vmid{display:grid;grid-template-columns:1fr .85fr;gap:10px}
.vchart-card{background:var(--bg3);border:1px solid var(--bord);border-radius:6px;padding:14px}
.vchart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.vchart-title{font-size:11px;font-weight:600;color:var(--w)}
.vchart-tabs{display:flex;gap:1px}
.vchart-tab{font-family:var(--sm);font-size:7px;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:3px;cursor:default;color:var(--t5)}
.vchart-tab.a{background:rgba(27,52,97,.12);color:var(--cyan)}
.vpipe-card{background:var(--bg3);border:1px solid var(--bord);border-radius:6px;padding:14px}
.vpipe-head{font-size:11px;font-weight:600;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.vpipe-bar-wrap{height:5px;background:var(--tbg1);border-radius:3px;margin-bottom:12px;overflow:hidden}
.vpipe-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--bl2),var(--cyan))}
.vpipe-rows{display:flex;flex-direction:column;gap:6px}
.vpipe-row{display:grid;grid-template-columns:1.2fr .8fr .7fr;gap:4px;align-items:center}
.vpr-name{font-size:10px;font-weight:500;color:var(--w)}
.vpr-status{font-family:var(--sm);font-size:7px;letter-spacing:.05em;padding:2px 6px;border-radius:99px;white-space:nowrap;display:inline-block}
.vpr-amt{font-family:var(--sm);font-size:10px;text-align:right}
.vbot{display:grid;grid-template-columns:1fr .9fr;gap:10px}
.vcap-card{background:var(--bg3);border:1px solid var(--bord);border-radius:6px;padding:14px}
.vcap-head{font-size:11px;font-weight:600;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.vcap-row{display:grid;grid-template-columns:1.5fr .6fr .6fr .7fr;gap:4px;padding:6px 0;border-bottom:1px solid var(--bord);font-size:10px;align-items:center}
.vcap-row:last-child{border-bottom:none}
.vcap-name{font-weight:500;color:var(--w)}
.vcap-tag{font-family:var(--sm);font-size:7px;text-transform:uppercase;background:rgba(27,52,97,.12);color:var(--cyan);padding:2px 5px;border-radius:99px}
.vcap-pct{font-family:var(--sm);font-size:10px;color:var(--ok)}
.vcap-val{font-family:var(--sm);font-size:10px;color:var(--t3);text-align:right}
.vkoko-card{background:linear-gradient(135deg,rgba(27,52,97,.1),rgba(6,8,14,.85));border:1px solid rgba(27,52,97,.2);border-radius:6px;padding:14px;display:flex;flex-direction:column;gap:10px}
.vkoko-header{display:flex;align-items:center;gap:7px}
.vkoko-pulse{width:6px;height:6px;border-radius:50%;background:var(--ok);flex-shrink:0;animation:blink 2s ease-in-out infinite;position:relative}
.vkoko-pulse::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:1px solid var(--ok);animation:pulse-out 2s ease-out infinite}
@keyframes pulse-out{0%{transform:scale(1);opacity:.6}100%{transform:scale(2.5);opacity:0}}
.vkoko-lbl{font-family:var(--sm);font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan)}
.vkoko-msgs{display:flex;flex-direction:column;gap:7px}
.vkm{display:flex;flex-direction:column;gap:2px}
.vkm-from{font-family:var(--sm);font-size:7px;letter-spacing:.1em;text-transform:uppercase}
.vkm-from.u{color:var(--t5)}
.vkm-from.k{color:var(--cyan)}
.vkm-bub{font-size:10px;font-weight:300;line-height:1.6;padding:7px 10px;border-radius:5px}
.vkm.u .vkm-bub{background:var(--tbg4);color:var(--t7);align-self:flex-end;max-width:90%}
.vkm.k .vkm-bub{background:rgba(27,52,97,.08);border-left:2px solid var(--cyan);color:var(--t8)}
.vkoko-typing{display:flex;align-items:center;gap:5px;padding:4px 0}
.typing-dot{width:5px;height:5px;border-radius:50%;background:var(--cyan);opacity:.4;animation:typing 1.2s ease-in-out infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,80%,100%{opacity:.4;transform:scale(1)}40%{opacity:1;transform:scale(1.2)}}


/* ── MODULES GRID ────────────────────────────────── */
.mods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bord);border-radius:12px;overflow:hidden}
.mod-card{background:var(--bg2);padding:28px;cursor:pointer;transition:background .12s;position:relative;overflow:hidden}
.mod-card:hover{background:var(--bg3)}
.mod-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.mod-icon svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.mod-name{font-size:16px;font-weight:600;letter-spacing:-.02em;margin-bottom:6px}
.mod-desc{font-size:12px;font-weight:300;color:var(--t2);line-height:1.6;margin-bottom:14px}
.mod-tags{display:flex;flex-wrap:wrap;gap:4px}
.mod-tag{font-family:var(--sm);font-size:8px;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:99px;background:var(--w5);color:var(--t7);border:1px solid var(--bord)}
.mod-arr{position:absolute;top:20px;right:20px;font-size:16px;color:var(--t4);transition:all .12s}
.mod-card:hover .mod-arr{color:var(--cyan)}
/* Mot "kokpyt" géant en fond, visible un instant pendant le reveal */
.mods-stage{position:relative}
.mods-bgword{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2;font-family:'GPKN',sans-serif;font-weight:400;letter-spacing:-.02em;font-size:clamp(64px,15vw,220px);color:var(--t1);opacity:0;text-transform:lowercase;white-space:nowrap}
.mods-stage.in-view .mods-bgword{animation:modsBgWord 1s ease forwards}
@keyframes modsBgWord{0%{opacity:0}25%{opacity:.2}60%{opacity:.1}100%{opacity:0}}
/* Reveal : les cases sont zoomées puis dézooment une à une, de gauche à droite, ligne par ligne */
.mods-grid{position:relative;z-index:1}
.mods-grid .mod-card{transform:scale(1.18);opacity:0;transition:transform .55s cubic-bezier(.22,1,.36,1),opacity .45s ease,background .12s}
.mods-grid.in-view .mod-card{transform:scale(1);opacity:1}
.mods-grid.in-view .mod-card:nth-child(1){transition-delay:0s}
.mods-grid.in-view .mod-card:nth-child(2){transition-delay:.08s}
.mods-grid.in-view .mod-card:nth-child(3){transition-delay:.16s}
.mods-grid.in-view .mod-card:nth-child(4){transition-delay:.24s}
.mods-grid.in-view .mod-card:nth-child(5){transition-delay:.32s}
.mods-grid.in-view .mod-card:nth-child(6){transition-delay:.40s}
.mods-grid.in-view .mod-card:nth-child(7){transition-delay:.48s}
.mods-grid.in-view .mod-card:nth-child(8){transition-delay:.56s}
.mods-grid.in-view .mod-card:nth-child(9){transition-delay:.64s}
@media (prefers-reduced-motion:reduce){
  .mods-grid .mod-card{transform:none;opacity:1;transition:background .12s}
}

/* ── KOKO SECTION ────────────────────────────────── */
.koko-section{padding:100px 40px;background:linear-gradient(180deg,var(--bg) 0%,#040810 50%,var(--bg) 100%);position:relative;overflow:hidden}
.koko-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;border-radius:50%;pointer-events:none}
.koko-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.koko-badge-wrap{display:inline-flex;align-items:center;gap:7px;margin-bottom:20px}
.koko-pulse{width:7px;height:7px;border-radius:50%;background:var(--ok);animation:blink 2s ease-in-out infinite}
.koko-label{font-family:var(--sm);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan)}
.koko-h2{font-size:clamp(36px,5vw,66px);font-weight:800;letter-spacing:-.04em;line-height:.97;margin-bottom:18px}
.koko-h2 em{font-family:var(--sf);font-style:normal;font-weight:400;color:var(--cyan)}
.koko-d{font-size:15px;font-weight:300;color:var(--t2);line-height:1.75;max-width:440px;margin-bottom:28px}
.koko-caps{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:28px}
.koko-cap{background:var(--bg2);border:1px solid var(--bord);padding:14px;border-radius:7px}
.koko-cap-n{font-family:var(--sm);font-weight:500;font-size:24px;color:var(--cyan);line-height:1;margin-bottom:4px}
.koko-cap-l{font-size:11px;font-weight:300;color:var(--t2)}
.koko-demos{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.koko-demo{background:var(--bg2);border:1px solid var(--bord);border-radius:8px;padding:14px}
.koko-demo-label{font-family:var(--sm);font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px}

/* ── SOLUTION HERO ───────────────────────────────── */
.sol-hero{background:var(--bg);display:grid;grid-template-columns:1fr 1fr;min-height:100vh;padding-top:60px}
.sol-hero-l{padding:80px 40px 60px;display:flex;flex-direction:column;justify-content:flex-start;padding-top:60px;position:relative;overflow:hidden;border-right:1px solid var(--bord)}
.sol-hero-bg{position:absolute;bottom:0px;left:-30px;font-family:var(--sf);font-weight:900;font-size:min(16vw,220px);line-height:1;color:var(--tbg3);pointer-events:none;user-select:none}
.sol-hero-chart{position:absolute;right:-40px;bottom:16px;width:min(44vw,500px);color:var(--accent,var(--cyan));opacity:.14;pointer-events:none;user-select:none;z-index:0}
.sol-hero-chart svg{width:100%;height:auto;display:block}
.sol-hero-chart .shc-grid{stroke:currentColor;stroke-width:1;opacity:.4}
.sol-hero-chart .shc-bars{fill:currentColor;opacity:.45}
.sol-hero-chart .shc-area{fill:currentColor;opacity:.12}
.sol-hero-chart .shc-line{fill:none;stroke:currentColor;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.sol-hero-chart .shc-dot{fill:currentColor}
.sol-hero-chart .shc-stroke{fill:none;stroke:currentColor;stroke-width:2;opacity:.55}
.sol-hero-chart .shc-soft{fill:currentColor;opacity:.32}
.sol-hero-chart .shc-ring{fill:none;stroke:currentColor;stroke-width:26;stroke-linecap:butt}
.sol-hero-chart .shc-track{fill:none;stroke:currentColor;stroke-width:26;opacity:.18}
[data-theme="light"] .sol-hero-chart{opacity:.1}
.sol-hero-l>*:not(.sol-hero-bg):not(.sol-hero-chart){position:relative;z-index:1}
.sol-h1{font-family: 'Boldonse'; text-decoration: uppercase; font-size:clamp(52px,7vw,96px);font-weight:800;letter-spacing:-.04em;line-height:1.2;margin-bottom:18px; padding-top:60px;position:relative;z-index: 33}
.sol-h1 em{font-family: 'Boldonse'; text-decoration: uppercase;  font-style:normal;font-weight:400;color:var(--cyan)}
.sol-p{font-size:16px;font-weight:300;color:var(--t2);line-height:1.75;max-width:420px;margin-bottom:28px}
.sol-hero-r{background:var(--bg2);display:flex;align-items:center;justify-content:flex-start;padding:0 0 0 44px;overflow:hidden;position:relative}
.sol-hero-r .sol-screen{position:relative;z-index:1;width:120%;max-width:none;border-radius:12px;box-shadow:0 40px 120px rgba(0,0,0,.5),0 0 40px rgba(27,52,97,.1);animation:sol-screen-in 1s cubic-bezier(.16,1,.3,1) both}
@keyframes sol-screen-in{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
@media (prefers-reduced-motion:reduce){.sol-hero-r .sol-screen{animation:none}}
.sol-shot-bg{position:absolute;top:50%;left:100%;width:190%;max-width:none;transform:translate(-50%,-50%);filter:blur(10px) saturate(1.4);opacity:.4;border:0;border-radius:0;box-shadow:none;pointer-events:none;z-index:0}
[data-theme="light"] .sol-hero-r .sol-screen{box-shadow:0 40px 100px rgba(0,0,0,.1),0 0 40px rgba(27,52,97,.06)}
[data-theme="light"] .sol-shot-bg{opacity:.3}

/* ── FEATURES GRID (sol pages) ───────────────────── */
.features-section{padding:80px 40px;max-width:1200px;margin:0 auto}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bord);border-radius:10px;overflow:hidden;margin-top:40px}
.feat{background:var(--bg2);padding:28px;transition:background .12s}
.feat:hover{background:var(--bg3)}
.feat.fi{padding-left:24px}
.feat-n{font-size:40px;font-weight:800;letter-spacing:-.04em;color:var(--cyan);line-height:1;margin-bottom:12px;opacity:.35}
.feat-t{font-size:15px;font-weight:600;letter-spacing:-.01em;margin-bottom:8px}
.feat-d{font-size:12px;font-weight:300;color:var(--t2);line-height:1.65}

/* ── SOLUTION CONTEXT BAND (for whom + result) ───── */
.sol-ctx{max-width:1200px;margin:0 auto;padding:0 40px 80px}
.sol-ctx-inner{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr) minmax(0,1fr);gap:1px;background:var(--bord);border-radius:10px;overflow:hidden}
.sol-ctx-col{background:var(--bg2);padding:36px 32px}
.sol-ctx-media{background:var(--bg2);position:relative;min-height:280px;overflow:hidden}
.sol-ctx-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.sol-ctx-media:hover .sol-ctx-img{transform:scale(1.04)}
.sol-ctx-eyb{font-family:var(--sm);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent,var(--cyan));margin-bottom:18px;display:flex;align-items:center;gap:8px}
.sol-ctx-eyb::before{content:'';display:block;width:16px;height:1px;background:currentColor}
.sol-ctx-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.sol-chip{font-family:var(--sm);font-size:12px;padding:6px 12px;border-radius:20px;background:var(--blg);color:var(--t2);border:1px solid var(--bord)}
.sol-ctx-d{font-size:14px;font-weight:300;color:var(--t2);line-height:1.7;max-width:440px}
.sol-ba{display:flex;flex-direction:column;gap:8px}
.sol-ba-row{display:flex;flex-direction:column;gap:6px;padding:14px 16px;border-radius:8px;background:var(--bg);border:1px solid var(--bord);font-size:14px;color:var(--t2);line-height:1.55}
.sol-ba-tag{font-family:var(--sm);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.sol-ba-row.before .sol-ba-tag{font-family: 'Boldonse'; color:var(--err)}
.sol-ba-row.after{border-color:color-mix(in srgb,var(--ok) 40%,transparent)}
.sol-ba-row.after .sol-ba-tag{font-family: 'Boldonse'; color:var(--ok)}
.sol-ba-arrow{text-align:center;color:var(--accent,var(--cyan));font-size:16px;line-height:1;opacity:.7}
@media(max-width:820px){.sol-ctx-inner{grid-template-columns:1fr}.sol-ctx{padding:0 20px 48px}.sol-ctx-col{padding:28px 22px}.sol-ctx-media{min-height:0;aspect-ratio:4/3}}

/* ── POUR QUI ────────────────────────────────────── */
.pq-tabs{display:flex;gap:1px;background:var(--bord);border-radius:7px;overflow:hidden;display:inline-flex;margin-bottom:44px}
.pq-tab{padding:9px 20px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;background:var(--bg2);transition:all .12s;border:none;font-family:var(--ss)}
.pq-tab.on{background:var(--bl2);color:var(--w)}
.pq-sec{display:none}
.pq-sec.on{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.pq-stages{display:flex;flex-direction:column;gap:3px;margin-top:24px}
.pq-stage{padding:11px 14px;border:1px solid transparent;cursor:pointer;border-radius:6px;transition:all .12s;display:flex;align-items:center;gap:11px}
.pq-stage:hover,.pq-stage.sel{background:rgba(27,52,97,.06);border-color:rgba(27,52,97,.2)}
.pq-stage-dot{width:7px;height:7px;border-radius:50%;border:2px solid var(--t5);flex-shrink:0}
.pq-stage.sel .pq-stage-dot{background:var(--cyan);border-color:var(--cyan);box-shadow:0 0 6px var(--cyan)}
.pq-stage-name{font-size:13px;font-weight:500;color:var(--t2)}
.pq-stage.sel .pq-stage-name{color:var(--w)}
.pq-stage-desc{font-size:10px;color:var(--t6);margin-top:1px}

/* ── PRICING ─────────────────────────────────────── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pricing-grid-5{grid-template-columns:repeat(5,1fr)}
.pc{--accent:var(--bl2);background:var(--bg2);border:1px solid var(--bord);border-radius:14px;padding:30px 26px;position:relative;overflow:hidden;transition:transform .18s cubic-bezier(.2,.7,.3,1),border-color .18s,box-shadow .18s;display:flex;flex-direction:column}
/* Top accent bar */
.pc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:.85}
/* Soft accent glow in the top-right corner */
.pc::after{content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 22%,transparent) 0%,transparent 70%);pointer-events:none;opacity:.7;transition:opacity .18s}
.pc:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--accent) 45%,var(--bord));box-shadow:0 24px 60px rgba(0,0,0,.35),0 0 30px color-mix(in srgb,var(--accent) 12%,transparent)}
.pc:hover::after{opacity:1}
.pc.pop{border-color:color-mix(in srgb,var(--accent) 40%,var(--bord));background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 8%,var(--bg2)) 0%,var(--bg2) 60%);box-shadow:0 0 40px color-mix(in srgb,var(--accent) 14%,transparent)}
.pc.pop::before{opacity:1;height:4px}
.pc-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;background:color-mix(in srgb,var(--accent) 88%,transparent);box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 30%,transparent),inset 0 1px 0 rgba(255,255,255,.18)}
.pc-ico svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.pc-pop-badge{position:absolute;top:18px;right:18px;font-family:var(--sm);font-size:7px;letter-spacing:.12em;text-transform:uppercase;background:var(--accent);color:#fff;padding:4px 10px;border-radius:99px;box-shadow:0 4px 12px color-mix(in srgb,var(--accent) 40%,transparent)}
.pc-plan{font-family:var(--sm);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 80%,var(--t2));margin-bottom:12px}
.pc-price{font-size:46px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:6px}
.pc-price span{font-size:16px;font-weight:300;color:var(--t2)}
.pc-desc{font-size:13px;font-weight:300;color:var(--t2);margin-bottom:22px;line-height:1.6}
.pc-div{height:1px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 40%,transparent),var(--bord) 60%,transparent);margin-bottom:20px}
.pc-feats{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.pc-feat{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--t6)}
.pc-feat::before{content:'✓';color:var(--accent);font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}
.pc-feat.na{color:var(--t4)}
.pc-feat.na::before{content:'—';color:var(--t5)}
.pc-cta{width:100%;padding:12px 8px;font-size:12px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .15s;font-family:var(--ss);white-space:nowrap;text-align:center;display:block;text-decoration:none}
.pc-cta.ghost{background:var(--w5);color:var(--w);border:1px solid var(--bord2)}
.pc-cta.ghost:hover{background:var(--w4);border-color:color-mix(in srgb,var(--accent) 50%,var(--bord2))}
.pc-cta.main{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 65%,#fff));color:#fff;box-shadow:0 4px 16px color-mix(in srgb,var(--accent) 35%,transparent)}
.pc-cta.main:hover{transform:translateY(-1px);box-shadow:0 6px 22px color-mix(in srgb,var(--accent) 45%,transparent)}

/* ── TESTIMONIAL ─────────────────────────────────── */
.testim-area{display:grid;grid-template-columns:auto 1fr;gap:64px;align-items:center;max-width:1200px;margin:0 auto}
.testim-q{font-family:var(--sf);font-size:clamp(64px,10vw,140px);color:var(--tbg5);line-height:1;flex-shrink:0;margin-top:-20px}
.testim-txt{font-family:var(--sf);font-style:normal;font-weight:400;font-size:clamp(20px,2.5vw,30px);line-height:1.45;color:var(--t1);margin-bottom:24px}
.testim-author{display:flex;align-items:center;gap:12px}
.testim-av{width:36px;height:36px;border-radius:50%;background:var(--bl2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:var(--w);flex-shrink:0}
.testim-name{font-size:14px;font-weight:600}
.testim-role{font-size:11px;color:var(--t2);margin-top:1px}

/* ── CTA SECTION ─────────────────────────────────── */
.cta-section{padding:120px 40px;text-align:center;position:relative;overflow:hidden}
.cta-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;border-radius:50%;border:1px solid rgba(27,52,97,.08);pointer-events:none}
.cta-ring::before{content:'';position:absolute;inset:-40px;border-radius:50%;border:1px solid rgba(27,52,97,.04)}
.cta-eyb{font-family:var(--sm);font-size:19px;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);margin-bottom:14px;position:relative;z-index:1}
.cta-h2{font-family:'Boldonse',sans-serif;font-size:clamp(26px,4vw,52px);font-weight:400;letter-spacing:-.02em;line-height:1.15;margin-bottom:20px;position:relative;z-index:1;text-transform: uppercase;}
.cta-h2 em{font-family:'Boldonse';font-style:normal;font-weight:400;color:var(--cyan)}
.cta-acts{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;z-index:1}
.cta-note{font-size:12px;color:var(--t4);letter-spacing:.04em}

/* ── FOOTER ──────────────────────────────────────── */
footer{padding:60px 40px 36px;border-top:1px solid var(--bord);background:var(--bg2);position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:2;background:linear-gradient(90deg,var(--m-pilot),var(--m-koko),var(--m-rh),var(--m-cap),var(--m-fin),var(--m-fund),var(--m-pilot));background-size:200% auto;animation:koko-shine 8s linear infinite}
footer::after{content:'';position:absolute;left:0;right:0;bottom:0;height:320px;pointer-events:none;z-index:0;
  background:
    radial-gradient(40% 80% at 22% 100%,color-mix(in srgb,var(--m-pilot) 40%,transparent),transparent 70%),
    radial-gradient(36% 80% at 78% 100%,color-mix(in srgb,var(--m-fund) 38%,transparent),transparent 70%),
    radial-gradient(44% 90% at 72% 100%,color-mix(in srgb,var(--m-rh) 32%,transparent),transparent 72%),
    radial-gradient(40% 85% at 28% 100%,color-mix(in srgb,var(--m-fin) 32%,transparent),transparent 72%),
    radial-gradient(32% 80% at 50% 100%,color-mix(in srgb,var(--m-cap) 28%,transparent),transparent 70%);
  mask-image:linear-gradient(to top,#000 0%,transparent 100%)}
[data-theme="light"] footer::after{opacity:.5}
/* Dégradé multicolore du footer concentré en bas du texte, estompé vers le haut */
.grad-foot{
  background:
    linear-gradient(to top,transparent 5%,var(--w) 50%),
    linear-gradient(90deg,var(--m-pilot),var(--m-fund),var(--m-rh),var(--m-cap),var(--m-fin),var(--m-fund));
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent}
.footer-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.fl{display:flex;flex-direction:column;gap:0}
.fl-logo{font-weight:700;font-size:16px;letter-spacing:-.025em;cursor:pointer;margin-bottom:6px;display:flex;align-items:center;gap:4px}
.fl-tag{font-size:13px;font-style:italic;color:var(--t3);margin-bottom:12px}
.fl-legal{font-size:11px;color:var(--t5);line-height:1.7}
.fc h4{font-family:var(--sm);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--t6);margin-bottom:14px}
.fc button,.fc a{display:block;font-size:13px;color:var(--t7);background:none;border:none;cursor:pointer;padding:0;margin-bottom:9px;font-family:var(--ss);text-align:left;text-decoration:none;transition:color .12s}
.fc button:hover,.fc a:hover{color:var(--w)}
.fbot{border-top:1px solid var(--bord);padding-top:20px;display:flex;align-items:center;gap:8px;font-size:11px;color:var(--t5)}

/* ── ABOUT ───────────────────────────────────────── */
.manifesto{font-size:clamp(18px,2.5vw,28px);font-weight:700;letter-spacing:-.02em;color:var(--t1);line-height:1.45}
.manifesto em{font-family:var(--sf);font-style:normal;font-weight:400;color:var(--cyan);opacity:.85}
.tx-wrap{padding:40px 0;overflow:hidden;border-top:1px solid var(--bord);border-bottom:1px solid var(--bord)}
.tx{display:inline-block;font-family:var(--sf);font-weight:900;font-size:min(5vw,52px);line-height:1.1;color:var(--tb5);white-space:nowrap;letter-spacing:-.02em;user-select:none;will-change:transform;animation:tx-scroll 24s linear infinite}
@keyframes tx-scroll{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}
@media (prefers-reduced-motion:reduce){.tx{animation:none}}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--bord);border-radius:10px;overflow:hidden}
.team-card{background:var(--bg2);padding:36px 32px}
.team-init{font-family:var(--sf);font-weight:900;font-size:52px;color:var(--cyan);line-height:1;margin-bottom:12px;opacity:.15}
.team-name{font-size:18px;font-weight:600;letter-spacing:-.02em;margin-bottom:4px}
.team-role{font-family:var(--sm);font-size:8px;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:12px}
.team-bio{font-size:13px;font-weight:300;color:var(--t2);line-height:1.7}

/* ── IMAGES ──────────────────────────────────────── */
.team-photo{width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:12px;border:2px solid var(--bord2)}
.testim-photo{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}
.pq-photo{width:100%;border-radius:10px;object-fit:cover;aspect-ratio:3/2;margin-bottom:20px;border:1px solid var(--bord)}
.cta-photo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;object-fit:cover;opacity:.08;pointer-events:none;z-index:0}

/* ── THEME TOGGLE ────────────────────────────────── */
.theme-toggle{position:fixed;bottom:24px;right:24px;z-index:300;width:44px;height:44px;border-radius:50%;border:1px solid var(--bord2);background:var(--bg2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.theme-toggle:hover{transform:scale(1.08);box-shadow:0 4px 24px var(--glow);border-color:var(--cyan)}
.theme-toggle svg{width:18px;height:18px;stroke:var(--cyan);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .3s}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="light"] .theme-toggle .icon-sun{display:block}
[data-theme="light"] .theme-toggle .icon-moon{display:none}
[data-theme="light"] .theme-toggle{background:var(--bg2);border-color:var(--bord2);box-shadow:0 4px 20px rgba(0,0,0,.08)}
[data-theme="light"] .theme-toggle svg{stroke:var(--bl3)}

/* ── LANG TOGGLE ───────────────────────────────────── */
.lang-toggle{position:fixed;bottom:24px;right:78px;z-index:300;width:44px;height:44px;border-radius:50%;border:1px solid var(--bord2);background:var(--bg2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 20px rgba(0,0,0,.3);font-family:var(--sm);font-size:11px;letter-spacing:.05em;font-weight:500;color:var(--cyan)}
.lang-toggle:hover{transform:scale(1.08);box-shadow:0 4px 24px var(--glow);border-color:var(--cyan)}
[data-theme="light"] .lang-toggle{background:var(--bg2);border-color:var(--bord2);box-shadow:0 4px 20px rgba(0,0,0,.08);color:var(--bl3)}

/* ── LIGHT THEME OVERRIDES ───────────────────────── */
[data-theme="light"] .mobile-menu{background:rgba(244,246,250,.97)}
[data-theme="light"] .mobile-menu .nlink,[data-theme="light"] .mobile-menu .ndrop-btn{color:var(--w3)}
[data-theme="light"] .pc{background:var(--bg2);border-color:var(--bord)}
[data-theme="light"] .pc.pop{border-color:color-mix(in srgb,var(--accent) 40%,var(--bord));background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 6%,var(--bg2)) 0%,var(--bg2) 60%)}
[data-theme="light"] .pc:hover{box-shadow:0 24px 60px rgba(17,24,39,.12),0 0 30px color-mix(in srgb,var(--accent) 10%,transparent)}
[data-theme="light"] .mod-card{background:var(--bg2)}
[data-theme="light"] .mod-card:hover{background:var(--bg3)}
[data-theme="light"] .stat{background:var(--bg2)}
[data-theme="light"] .stats{background:var(--bg2);border-color:var(--bord)}
[data-theme="light"] .team-card{background:var(--bg2)}
[data-theme="light"] .feat{background:var(--bg2)}
[data-theme="light"] .feat:hover{background:var(--bg3)}
[data-theme="light"] .koko-section{background:linear-gradient(180deg,var(--bg) 0%,#E8ECF4 50%,var(--bg) 100%)}
[data-theme="light"] footer{background:var(--bg2)}
[data-theme="light"] .mock-win{box-shadow:0 48px 120px rgba(0,0,0,.1),0 0 40px rgba(27,52,97,.06)}
[data-theme="light"] .video-frame{border-color:var(--bord2);box-shadow:0 40px 100px rgba(0,0,0,.08)}
[data-theme="light"] .app-shell{box-shadow:0 32px 80px rgba(0,0,0,.08)}
[data-theme="light"] .sol-screen{box-shadow:0 32px 80px rgba(0,0,0,.08)}
[data-theme="light"] .kpi-card{background:var(--bg2)}
[data-theme="light"] .tbl{background:var(--bg2)}
[data-theme="light"] .chat{background:var(--bg2)}
[data-theme="light"] .ndrop-menu{background:var(--bg2);box-shadow:0 20px 60px rgba(0,0,0,.1)}
[data-theme="light"] .sidebar{background:var(--bg3)}
[data-theme="light"] .mock-sb{background:var(--bg3)}
[data-theme="light"] .koko-cap{background:var(--bg3)}
[data-theme="light"] .koko-demo{background:var(--bg3)}
[data-theme="light"] .pq-tab{background:var(--bg3)}
[data-theme="light"] .pq-tab.on{background:var(--bl2);color:#fff}
[data-theme="light"] .testim-av{background:var(--bl2)}
[data-theme="light"] .btn-ghost{color:var(--w)}
[data-theme="light"] .ncta{color:#fff}
[data-theme="light"] .hamburger span{background:var(--t3)}
[data-theme="light"] .sol-hero-bg{color:rgba(17,24,39,.03)}
[data-theme="light"] .tx{color:var(--tbg5)}
[data-theme="light"] .sol-hero-r{background:var(--bg3)}
[data-theme="light"] .mock-bar{background:var(--bg3)}
[data-theme="light"] .mock-main{background:var(--bg)}
[data-theme="light"] .vsim-topbar{background:var(--bg3)}
[data-theme="light"] .vsim-sb{background:var(--bg3)}
[data-theme="light"] .vsim-main{background:var(--bg)}
[data-theme="light"] .vsim{background:var(--bg2)}
[data-theme="light"] .vkpi{background:var(--bg2)}
[data-theme="light"] .vchart-card{background:var(--bg2)}
[data-theme="light"] .vpipe-card{background:var(--bg2)}
[data-theme="light"] .vcap-card{background:var(--bg2)}
[data-theme="light"] .vkoko-card{background:linear-gradient(135deg,rgba(27,52,97,.06),var(--bg2));border-color:rgba(27,52,97,.15)}
[data-theme="light"] .kblock{background:rgba(27,52,97,.04);border-color:rgba(27,52,97,.12);border-left-color:var(--bl3)}
[data-theme="light"] .cmsg.a .cbub{background:rgba(27,52,97,.06);border-left-color:var(--bl3)}
[data-theme="light"] .vkm.k .vkm-bub{background:rgba(27,52,97,.06);border-left-color:var(--bl3)}
[data-theme="light"] .pc-cta.main{color:#fff}
[data-theme="light"] .testim-txt{color:var(--t1)}
[data-theme="light"] .manifesto{color:var(--t1)}
[data-theme="light"] .pc-feat::before{color:var(--ok)}
[data-theme="light"] .live-dot{background:var(--ok)}
[data-theme="light"] .stats-inner{background:var(--bord)}
[data-theme="light"] .mods-grid{background:var(--bord)}
[data-theme="light"] .features-grid{background:var(--bord)}
[data-theme="light"] .team-grid{background:var(--bord)}

/* ── UTILS ───────────────────────────────────────── */
.section-wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.pad-section{padding:80px 40px}
.pad-section-lg{padding:100px 40px}
.text-center{text-align:center}
.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-10{margin-bottom:40px}.mb-14{margin-bottom:56px}.mb-16{margin-bottom:64px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float{animation:float 5s ease-in-out infinite}

/* ════════════════════════════════════════════════════
   RESPONSIVE — TABLET (≤ 1024px)
════════════════════════════════════════════════════ */
@media (max-width:1024px) {
  nav{padding:0 24px}
  .nlinks{gap:16px}
  .ndrop-btn,.nlink{font-size:12px}

  .hero{padding:100px 24px 48px}
  .hero-mockup{max-width:100%;transform:none!important}
  .mock-body{grid-template-columns:140px 1fr;min-height:360px}
  .mock-sidebar{display:none}

  .feat-split{grid-template-columns:1fr;gap:40px;padding:60px 24px}
  .feat-split.rev{direction:ltr}
  /* Captures en pleine largeur : pas de décalage horizontal (reveal) ni de perspective 3D
     qui élargiraient le document au-delà de l'écran. */
  .feat-img-reveal{--reveal-x:0px}
  .feat-split .sol-screen{transform:none!important;width:100%;max-width:100%}

  .stats-inner{grid-template-columns:repeat(2,1fr)}

  .mods-grid{grid-template-columns:repeat(2,1fr)}

  .koko-inner{grid-template-columns:1fr;gap:40px}

  .pricing-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .pricing-grid-5{grid-template-columns:repeat(3,1fr);max-width:760px}

  .sol-hero{grid-template-columns:1fr;min-height:auto}
  .sol-hero-r{display:none}

  .features-grid{grid-template-columns:repeat(2,1fr)}

  .pq-section .section-wrap > div{grid-template-columns:1fr!important;gap:48px!important}
  /* Hero hub cards — 2 columns on tablet */
  .pq-hero div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr!important}

  .testim-area{grid-template-columns:auto 1fr;gap:32px}

  .ft{grid-template-columns:1fr 1fr;gap:28px}
  .ft > .fl{grid-column:1/-1}

  .about-hero{grid-template-columns:1fr;gap:40px}
  .team-grid{grid-template-columns:1fr}

  .vsim-sb{display:none}
  .vkpi-row{grid-template-columns:repeat(3,1fr)}
  .vmid{grid-template-columns:1fr}
  .vbot{grid-template-columns:1fr}
  .vsim-main{padding:12px}
  .vsim{min-height:auto}

  .section-wrap{padding:0 24px}
  .pad-section{padding:60px 24px}
  .pad-section-lg{padding:80px 24px}
}

/* ════════════════════════════════════════════════════
   RESPONSIVE — MOBILE (≤ 768px)
════════════════════════════════════════════════════ */
@media (max-width:768px) {
  /* Nav — hamburger */
  nav{padding:0 20px;height:56px}
  .nlinks{display:none}
  .ncta{padding:7px 14px;font-size:12px}

  /* Hero */
  .hero{padding:90px 20px 40px;text-align:center}
  .hero-h1{font-size:clamp(22px,6vw,34px);}
  .hero-sub{font-size:14px;max-width:100%}
  .hero-acts{flex-direction:column;align-items:center;gap:10px}
  .hero-acts .btn-iv,.hero-acts .btn-out{width:100%;max-width:280px;text-align:center}
  /* Hide app mockup on mobile — too small */
  .hero-mockup{display:none}

  /* Stats */
  .stats-inner{grid-template-columns:1fr 1fr;gap:1px}
  .stat{padding:24px 20px}
  .stat-n{font-size:clamp(24px,6vw,36px)}

  /* Video section */
  .video-section{padding:60px 20px}
  .vsim-sb{display:none}
  .vsim-topbar{padding:0 10px}
  .vsim-body{flex-direction:column}
  .vsim-main{padding:10px}
  .vkpi-row{grid-template-columns:repeat(2,1fr);gap:6px}
  .vkpi{padding:10px 12px}
  .vkpi-n{font-size:18px}
  .vmid{display:none}
  .vbot{display:none}
  .vsim{min-height:auto}
  .video-frame canvas{min-height:220px}
  #kokpyt-anim{min-height:220px}

  /* Features */
  .feat-split{padding:48px 20px;gap:32px}
  .feat-h{font-size:clamp(24px,6vw,36px)}
  .feat-visual{display:none}

  /* Modules */
  .mods-grid{grid-template-columns:1fr;border-radius:8px}
  .mod-card{padding:20px}

  /* KOKO */
  .koko-section{padding:60px 20px}
  .koko-inner{grid-template-columns:1fr;gap:32px}
  .koko-h2{font-size:clamp(30px,8vw,48px)}
  .koko-demos{grid-template-columns:1fr}
  .koko-caps{grid-template-columns:1fr 1fr}

  /* Pricing */
  .pricing-grid{grid-template-columns:1fr;gap:12px}
  .pricing-grid-5{grid-template-columns:repeat(2,1fr);max-width:480px}
  .pc{padding:20px}

  /* Sol pages */
  .sol-hero{padding-top:70px}
  .sol-hero-l{padding:48px 20px 40px}
  .sol-hero-chart{display:none}
  .sol-h1{font-size:clamp(40px,10vw,64px)}
  .sol-hero-r{display:none}
  .features-section{padding:48px 20px}
  .features-grid{grid-template-columns:1fr}

  /* Pour qui */
  .pq-hero{padding:84px 20px 40px!important;min-height:auto!important}
  .pourqui{padding:80px 20px}
  .pq-photo{aspect-ratio:16/9;margin-bottom:0}
  .pq-tabs{flex-wrap:wrap;width:100%}
  .pq-tab{flex:1;font-size:11px;padding:8px 10px;text-align:center}
  .pq-sec.on{grid-template-columns:1fr}
  .pq-stages{margin-top:16px}

  /* Detail sections — stack to one column (text then photo),
     hide the detailed app mockups (illegible at this size) but keep the photo */
  #pq-fondateurs,#pq-accelerateurs,#pq-experts,#pq-investisseurs{padding:48px 20px}
  .pq-section .pq-photo + div{display:none}

  /* Pour qui hub grid → 2 columns */
  .pq-hub-card{padding:20px 16px}
  [onclick^="selectPQ"]{font-size:14px}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr!important}

  /* Testimonial */
  .testim-area{grid-template-columns:1fr;gap:16px}
  .testim-q{font-size:60px;display:none}
  .testim-txt{font-size:clamp(16px,4vw,22px)}

  /* CTA */
  .cta-section{padding:80px 20px}
  .cta-h2{font-size:clamp(22px,6vw,34px)}
  .cta-acts{align-items:center}
  .btn-iv{width:100%;max-width:280px;text-align:center}

  /* Footer */
  footer{padding:48px 20px 32px}
  .ft{grid-template-columns:1fr;gap:28px}
  .ft > .fl{grid-column:auto}

  /* About */
  .about-hero{padding:96px 20px 40px;grid-template-columns:1fr}
  .about-hero > div:last-child{display:none}
  .team-grid{grid-template-columns:1fr}
  div[style*="grid-template-columns:repeat(4,1fr"];{ display:grid;grid-template-columns:1fr 1fr!important}

  /* KOKO page */
  #p-koko section{padding:96px 20px 40px}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr 1fr!important}
  div[style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr!important}

  /* Sol pages */
  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;display:block}

  /* Pricing page */
  #p-tarifs section{padding:96px 20px 40px}

  /* Pour qui hub */
  [id^="pqhub"]{padding:20px 16px}

  /* Stats on pricing */
  div[style*="grid-template-columns:repeat(4,1fr"];{ grid-template-columns:1fr 1fr}

  /* General section padding */
  .section-wrap{padding:0 20px}
  .pad-section{padding:48px 20px}
  .pad-section-lg{padding:60px 20px}
}

/* ════════════════════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (≤ 480px)
════════════════════════════════════════════════════ */
@media (max-width:480px) {
  .hero-h1{font-size:24px}
  .sol-h1{font-size:38px}
  .cta-h2{font-size:24px}
  .stat-n{font-size:24px}
  .koko-h2{font-size:30px}
  .section-h2,.feat-h{font-size:26px}
  .pq-hero h1{font-size:30px!important;line-height:1.2!important}
  .vkpi-row{grid-template-columns:1fr 1fr}
  .koko-caps{grid-template-columns:1fr}
  .pricing-grid-5{grid-template-columns:1fr;max-width:360px}

  /* Nav on tiny screens */
  .ncta{display:none}
}

/* ════════════════════════════════════════════════════
   HAMBURGER MENU (mobile nav)
════════════════════════════════════════════════════ */
.hamburger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:4px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--t2);border-radius:1px;transition:all .2s}
.mobile-menu{display:none}
@media (max-width:768px){
  .hamburger{display:flex}
  .mobile-menu{display:flex;position:fixed;top:56px;left:0;right:0;background:rgba(6,8,14,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--tbg5);padding:20px;flex-direction:column;gap:4px;z-index:199;transform:translateY(-110%);transition:transform .3s ease}
  .mobile-menu.open{transform:translateY(0)}
  .mobile-menu .nlink,.mobile-menu .ndrop-btn{font-size:15px;color:var(--t2);padding:12px 0;border-bottom:1px solid var(--tbg1);text-align:left;width:100%;display:block}
  .mobile-menu .ncta{width:100%;text-align:center;margin-top:8px;padding:12px}
  .ndrop-menu{position:static;display:none;flex-direction:column;background:transparent;border:none;padding:0 0 0 16px;box-shadow:none}
}
.page-content{display:block;min-height:100vh}

/* ── VIDEO RESPONSIVE ─────────────────────────────── */
.video-frame-wrap{aspect-ratio:16/9}
@media (max-width:768px){
  .video-frame-wrap{aspect-ratio:auto;height:340px}
  .kokpyt-canvas{width:100%!important;height:100%!important}
}
@media (max-width:480px){
  .video-frame-wrap{height:260px}
}

@media (max-width:900px){
  .hero-mockup{display:none}
  .hero{justify-content:center}
}

/* ════════════════════════════════════════════════════
   COULEURS DE MODULE — accent par page (aligné app)
   Chaque page pose --accent sur <body> ; défaut = navy.
════════════════════════════════════════════════════ */
:root{
  --m-pilot:hsl(218,70%,45%);   /* Dashboard / Business Plan */
  --m-fin:hsl(160,60%,40%);     /* Financial Plan */
  --m-fund:hsl(250,55%,52%);    /* Fundraising / Pitch */
  --m-cap:hsl(43,85%,48%);      /* Cap Table */
  --m-rh:hsl(200,72%,46%);      /* RH */
  --m-koko:hsl(258,85%,62%);    /* KOKO AI */
  --m-legal:hsl(0,58%,48%);
  --m-drive:hsl(150,48%,42%);
  --m-outils:hsl(0,0%,42%);
}

/* Éléments qui adoptent l'accent de la page (fallback navy) */
.eyb,.eyb.dk,
.feat-label,
.feat-n,
.sol-h1 em,
.hero-h1 em,
.koko-label,.koko-h2 em,.koko-cap-n,.koko-demo-label,
.cta-eyb,.cta-h2 em{color:var(--accent,var(--cyan))}
.feat-label::before{background:var(--accent,var(--cyan))}
.feat-li::before{color:var(--accent,var(--cyan))}

/* Section KOKO AI → accent violet (comme koko-chat) */
.koko-section{--accent:var(--m-koko)}
.koko-section .cfr.a{color:var(--accent)}
.koko-section .cmsg.a .cbub{border-left-color:var(--accent);background:color-mix(in srgb,var(--accent) 9%,transparent)}

/* ════ KOKO sections — décorations violettes & animations (toutes pages) ════ */
/* Orbes aurora floutées en fond */
.koko-section::before,.koko-section::after{content:'';position:absolute;border-radius:50%;filter:blur(70px);pointer-events:none;z-index:0}
.koko-section::before{width:520px;height:520px;top:-90px;left:-70px;background:radial-gradient(circle,hsla(262,92%,66%,.30),transparent 70%);animation:koko-orbA 17s ease-in-out infinite}
.koko-section::after{width:480px;height:480px;bottom:-110px;right:-70px;background:radial-gradient(circle,hsla(282,92%,70%,.26),transparent 70%);animation:koko-orbB 21s ease-in-out infinite}
@keyframes koko-orbA{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(40px,30px) scale(1.08)}}
@keyframes koko-orbB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-40px,-26px) scale(1.06)}}
/* Anneau central : halo + pulsation douce */
.koko-ring{box-shadow:inset 0 0 120px hsla(262, 92%, 66%, 0.041),0 0 60px hsla(262,92%,66%,.08);animation:koko-ringPulse 7s ease-in-out infinite}
@keyframes koko-ringPulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.8}50%{transform:translate(-50%,-50%) scale(1.05);opacity:1}}
/* Badge pilule lumineuse + point pulsé violet */
.koko-section .koko-badge-wrap{padding:7px 16px;border-radius:99px;background:hsla(262,92%,66%,.08);box-shadow:0 0 30px hsla(262,92%,66%,.16)}
.koko-section .koko-pulse{background:var(--accent);box-shadow:0 0 12px var(--accent)}
.koko-section .koko-label{text-shadow:0 0 22px hsla(262,92%,66%,.45)}
/* Titre — "em" en dégradé violet animé */
.koko-section .koko-h2 em{background:linear-gradient(110deg,hsl(278,94%,74%),hsl(262,92%,66%) 45%,hsl(244,88%,60%) 75%,hsl(278,94%,74%));background-size:300% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:koko-shine 6s linear infinite;filter:drop-shadow(0 0 22px hsla(262,92%,66%,.35))}
@keyframes koko-shine{to{background-position:300% center}}
/* Cartes stats : survol violet */
.koko-cap{transition:transform .3s,border-color .3s,box-shadow .3s}
.koko-cap:hover{transform:translateY(-4px);border-color:hsla(262,92%,66%,.45);box-shadow:0 12px 30px hsla(262,80%,42%,.22)}
/* Cartes démo : liseré haut + survol lift & halo */
.koko-demo{position:relative;overflow:hidden;transition:transform .35s,border-color .35s,box-shadow .35s}
.koko-demo::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5;transition:opacity .35s;z-index:1}
.koko-demo:hover{transform:translateY(-5px);border-color:hsla(262,92%,66%,.45);box-shadow:0 14px 38px hsla(262,80%,42%,.22)}
.koko-demo:hover::before{opacity:1}
@media (prefers-reduced-motion:reduce){.koko-section::before,.koko-section::after,.koko-ring,.koko-section .koko-h2 em{animation:none!important}}

/* Dégradé de fond de page teinté par l'accent (comme ModuleLayout app) */
.sol-hero{background:linear-gradient(180deg,var(--bg) 0%,color-mix(in srgb,var(--accent,var(--cyan)) 9%,var(--bg)) 100%)}
.sol-hero-r{background:linear-gradient(180deg,var(--bg2) 0%,color-mix(in srgb,var(--accent,var(--cyan)) 13%,var(--bg2)) 100%)}
.sol-hero-bg{color:color-mix(in srgb,var(--accent,var(--cyan)) 10%,transparent)}

/* Anneaux/halos des sections KOKO & CTA teintés par l'accent */
.koko-ring{border-color:color-mix(in srgb,var(--accent,var(--cyan)) 12%,transparent)}
.cta-ring{border-color:color-mix(in srgb,var(--accent,var(--cyan)) 20%,transparent)}
.cta-ring::before{border-color:color-mix(in srgb,var(--accent,var(--cyan)) 10%,transparent)}

/* Boutons "ivory" CTA des pages solution → accent de la page */
[style*="--accent"] .btn-iv{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%,#000));color:#fff;box-shadow:0 4px 20px color-mix(in srgb,var(--accent) 30%,transparent)}
[style*="--accent"] .btn-iv:hover{box-shadow:0 6px 26px color-mix(in srgb,var(--accent) 45%,transparent)}

/* ════ POUR QUI — hub 4 profils (chaque profil a sa couleur d'accent) ════ */
.pq-hub-card{position:relative;background:var(--bg2);padding:32px 26px;cursor:pointer;transition:background .18s,box-shadow .18s}
.pq-hub-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent,var(--bl3));transform:scaleX(0);transform-origin:left;transition:transform .22s ease}
.pq-hub-card:hover{background:color-mix(in srgb,var(--accent,var(--bl3)) 6%,var(--bg2))}
.pq-hub-card:hover::before{transform:scaleX(1)}
.pq-hub-card.active{background:color-mix(in srgb,var(--accent,var(--bl3)) 11%,var(--bg2))}
.pq-hub-card.active::before{transform:scaleX(1)}
.pqh-num{font-family:var(--sm);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent,var(--t3));margin-bottom:16px}
.pqh-name{font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:10px}
.pqh-desc{font-size:13px;font-weight:300;color:var(--t2);line-height:1.65;margin-bottom:24px}
.pqh-explore{font-size:13px;font-weight:600;color:var(--accent,var(--t1));display:inline-flex;align-items:center;gap:6px;transition:gap .18s}
.pq-hub-card:hover .pqh-explore,.pq-hub-card.active .pqh-explore{gap:10px}
/* Eyebrow & filets des sections profil teintés par l'accent */
.pq-section .eyb{color:var(--accent,var(--bl3))!important}

/* ════════════════════════════════════════════════════
   HOME — mise en couleur (toutes les couleurs de modules)
════════════════════════════════════════════════════ */
/* Titre hero : "Série A." en dégradé bleu animé (même animation que KOKO, couleurs hero) */
.hero-h1 em,.grad-title em{font-style:normal;background:linear-gradient(110deg,hsl(212,82%,68%),hsl(222, 63%, 51%) 45%,hsl(200, 100%, 73%) 75%,hsl(212,82%,68%));background-size:300% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:koko-shine 6s linear infinite;filter:drop-shadow(0 0 22px hsla(218,82%,58%,.30))}
[data-theme="light"] .hero-h1 em,[data-theme="light"] .grad-title em{background:linear-gradient(110deg,hsl(207, 74%, 48%),hsl(228,72%,42%) 45%,hsl(203, 94%, 63%) 75%,hsl(218, 84%, 58%));background-size:300% auto;-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 18px hsla(218,74%,46%,.22))}
@media (prefers-reduced-motion:reduce){.hero-h1 em{animation:none!important}}

/* Grille de modules : barre d'accent + hover coloré par tuile */
.mod-card[style*="--accent"]::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:.85;z-index:1}
.mod-card[style*="--accent"]:hover{background:color-mix(in srgb,var(--accent) 8%,var(--bg2))}
.mod-card[style*="--accent"]:hover .mod-name{color:var(--accent)}
.mod-card[style*="--accent"]:hover .mod-arr{color:var(--accent)}
.mod-card[style*="--accent"] .mod-name{transition:color .15s}
.mod-card[style*="--accent"] .mod-tag{border-color:color-mix(in srgb,var(--accent) 22%,var(--bord));color:color-mix(in srgb,var(--accent) 55%,var(--t7))}

/* Sections "feat-split" thématiques : fond dégradé à la couleur du module
   (comme la page solution correspondante). Le --accent est posé inline sur le bloc. */
.feat-bg{
  background:
    radial-gradient(60% 90% at 0% 0%,color-mix(in srgb,var(--accent) 20%,transparent),transparent 70%),
    linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,var(--bg)) 0%,var(--bg) 60%);
}
.feat-bg.rev{
  background:
    radial-gradient(60% 90% at 100% 0%,color-mix(in srgb,var(--accent) 20%,transparent),transparent 70%),
    linear-gradient(225deg,color-mix(in srgb,var(--accent) 12%,var(--bg)) 0%,var(--bg) 60%);
}
