/* Solvenda — DA "terminal de vigilance". Self-hosted, zero CDN. */
@font-face{font-family:"Solvenda Display";font-style:normal;font-weight:400 700;font-display:swap;src:url("/assets/fonts/solvenda-display.woff2") format("woff2");}
@font-face{font-family:"Solvenda Text";font-style:normal;font-weight:300 600;font-display:swap;src:url("/assets/fonts/solvenda-text.woff2") format("woff2");}

:root{
  /* DA "Midnight & Laiton" : encre de minuit + accent laiton/champagne. Couleur ailleurs = uniquement les 3 signaux de risque. */
  --ink:#0B1220; --ink-2:#0E1626; --panel:#121D31; --line:rgba(201,162,75,.14); --line-2:rgba(201,162,75,.26);
  --txt:#ECE7DA; --muted:#9AA3B2; --dim:#5E6776;
  --paper:#F4F0E6; --paper-ink:#12161D; --paper-muted:#5C6678; --paper-line:rgba(18,22,29,.12);
  --brass:#C9A24B; --brass-2:#E0BE6A; --brass-deep:#A9863A;
  --signal:#C9A24B; --signal-2:#E0BE6A; --calm:#C9A24B;
  --sev-liq:#E5533D; --sev-red:#E0902E; --sev-sau:#5B9DFF; --sev-clo:#7C8BA3; --ok:#5BC98C;
  --display:"Solvenda Display",Georgia,serif; --text:"Solvenda Text",system-ui,sans-serif;
  --mono:ui-monospace,"SF Mono","Cascadia Mono",Menlo,Consolas,monospace;
  --maxw:1180px; --r:14px; --r-s:9px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--ink);color:var(--txt);font-family:var(--text);font-weight:350;line-height:1.6;
  font-size:17px;letter-spacing:.005em;overflow-x:hidden;
  background-image:radial-gradient(1100px 560px at 78% -12%,rgba(201,162,75,.13),transparent 60%),radial-gradient(900px 520px at 8% 4%,rgba(38,58,104,.22),transparent 58%);}
/* grain */
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
/* fond WebGL signature (derriere tout ; fallback = gradient body) */
#bg-gl{position:fixed;inset:0;width:100%;height:100%;z-index:-1;display:block;pointer-events:none}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.015em;margin:0 0 .4em}
h1{font-size:clamp(2.6rem,6.6vw,5.4rem)}
/* hero : revelation clip-path (multi-lignes safe, sans JS) + lead/cta en cascade */
.js .hero h1{clip-path:inset(0 0 100% 0);transform:translateY(14px);animation:heroIn 1s var(--ease) .15s forwards}
.js .hero .lead{opacity:0;animation:fadeUp .8s var(--ease) .6s forwards}
.js .hero-cta{opacity:0;animation:fadeUp .8s var(--ease) .78s forwards}
.js .hero .trust{opacity:0;animation:fadeUp .8s var(--ease) .92s forwards}
@keyframes heroIn{to{clip-path:inset(0 0 -8% 0);transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.js .hero h1,.js .hero .lead,.js .hero-cta,.js .hero .trust{clip-path:none;opacity:1;transform:none;animation:none}}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:1.32rem;letter-spacing:-.01em}
p{margin:0 0 1em;color:#CdD7E6;color:#CCD6E5}
a{color:var(--calm);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0}
.kicker{font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--signal-2)}
.muted{color:var(--muted)}
section{padding:clamp(64px,9vw,120px) 0;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:.4em .9em}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(54,211,153,.7);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(54,211,153,.6)}70%{box-shadow:0 0 0 8px rgba(54,211,153,0)}100%{box-shadow:0 0 0 0 rgba(54,211,153,0)}}

/* header */
header.nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);background:rgba(11,18,32,.78);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:18px;height:64px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:600;font-size:1.28rem;letter-spacing:-.01em;color:var(--txt)}
.brand:hover{text-decoration:none}
.brand svg{width:26px;height:26px;display:block}
.nav nav{margin-left:auto;display:flex;align-items:center;gap:26px}
.nav nav a{color:var(--muted);font-size:.95rem}
.nav nav a:hover{color:var(--txt);text-decoration:none}
.nav .lang{font-family:var(--mono);font-size:.78rem;color:var(--dim);border:1px solid var(--line);border-radius:7px;padding:.25em .5em}
@media(max-width:860px){.nav nav .hide-sm{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--text);font-weight:500;font-size:.98rem;
  padding:.78em 1.3em;border-radius:var(--r-s);border:1px solid transparent;cursor:pointer;transition:transform .25s var(--ease),background .25s,box-shadow .25s;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--signal);color:#1a0c08;font-weight:600;box-shadow:0 10px 30px -10px rgba(201,162,75,.6)}
.btn-primary:hover{background:var(--signal-2);box-shadow:0 16px 40px -12px rgba(201,162,75,.7)}
.btn-ghost{border-color:var(--line-2);color:var(--txt);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--brass);background:rgba(201,162,75,.10)}
.btn-block{width:100%;justify-content:center}

/* hero */
.hero{padding-top:clamp(40px,7vw,84px);position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:36px}}
.hero h1 .em{color:var(--signal)}
.hero .lead{font-size:1.18rem;max-width:46ch;color:#C7D2E2}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.trust{margin-top:22px;font-family:var(--mono);font-size:.8rem;color:var(--dim);display:flex;gap:18px;flex-wrap:wrap}

/* live tape (signature move) */
.tape{border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--panel),var(--ink-2));overflow:hidden;box-shadow:0 40px 90px -50px rgba(0,0,0,.9)}
.tape-head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.tape-head .live{width:8px;height:8px;border-radius:50%;background:var(--signal);animation:pulse 2s infinite}
.tape-count{margin-left:auto;color:var(--txt)}
.tape-count b{font-family:var(--mono);font-size:1.05rem;color:var(--signal-2)}
.tape-body{position:relative;height:340px;overflow:hidden;mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent)}
.tape-track{display:flex;flex-direction:column;gap:0;will-change:transform}
.js .tape-track.run{animation:tapescroll 46s linear infinite}
.tape-body:hover .tape-track.run{animation-play-state:paused}
@keyframes tapescroll{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.tape-row{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line);font-size:.92rem}
.tape-row .siren{font-family:var(--mono);font-size:.8rem;color:var(--dim)}
.tape-row .nom{color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chip{font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;padding:.3em .6em;border-radius:6px;white-space:nowrap;border:1px solid}
.chip.liq{color:var(--sev-liq);border-color:rgba(255,77,61,.4);background:rgba(255,77,61,.08)}
.chip.red{color:var(--sev-red);border-color:rgba(245,165,36,.4);background:rgba(245,165,36,.08)}
.chip.sau{color:var(--sev-sau);border-color:rgba(91,157,255,.4);background:rgba(91,157,255,.08)}
.chip.clo,.chip.autre,.chip.plan{color:var(--sev-clo);border-color:rgba(124,139,163,.4);background:rgba(124,139,163,.08)}

/* reveal (state final visible sans JS) */
.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js [data-reveal].in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .js [data-reveal]{opacity:1!important;transform:none!important;transition:none}
  .tape-track{animation:none!important}
  .eyebrow .dot,.tape-head .live{animation:none}
}

/* cards / grids */
.grid{display:grid;gap:20px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}
.card{border:1px solid var(--line);border-radius:var(--r);padding:26px;background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));transition:border-color .3s,transform .3s var(--ease)}
.card:hover{border-color:var(--line-2);transform:translateY(-3px)}
.card .ico{width:38px;height:38px;margin-bottom:14px;color:var(--signal-2)}
.card h3{margin-bottom:.3em}
.card p{font-size:.97rem;color:var(--muted);margin:0}

/* section heading */
.sec-head{max-width:62ch;margin-bottom:48px}
.sec-head h2{margin-bottom:.25em}
.sec-head p{font-size:1.1rem;color:var(--muted)}

/* comparatif */
.cmp{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
@media(max-width:680px){.cmp{grid-template-columns:1fr}}
.cmp .col{padding:30px}
.cmp .today{background:var(--ink-2)}
.cmp .with{background:linear-gradient(180deg,rgba(201,162,75,.06),transparent);border-left:1px solid var(--line)}
.cmp h4{font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin:0 0 18px;color:var(--muted)}
.cmp .with h4{color:var(--signal-2)}
.cmp ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.cmp li{display:flex;gap:12px;align-items:flex-start;font-size:.98rem}
.cmp li .mk{flex:none;width:20px;height:20px;margin-top:2px}
.cmp .today li{color:var(--dim)}

/* demo */
.demo-box{border:1px solid var(--line-2);border-radius:var(--r);background:var(--panel);padding:28px;max-width:680px;margin:0 auto}
.demo-input{display:flex;gap:10px;flex-wrap:wrap}
.demo-input input{flex:1;min-width:200px;font-family:var(--mono);font-size:1.05rem;letter-spacing:.04em;padding:.8em 1em;border-radius:var(--r-s);border:1px solid var(--line-2);background:var(--ink);color:var(--txt)}
.demo-input input:focus{outline:none;border-color:var(--signal)}
.demo-picks{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.demo-picks button{font-family:var(--mono);font-size:.78rem;color:var(--muted);background:var(--ink-2);border:1px solid var(--line);border-radius:7px;padding:.4em .7em;cursor:pointer}
.demo-picks button:hover{border-color:var(--calm);color:var(--txt)}
.demo-result{margin-top:20px;min-height:10px}
.result-card{border:1px solid var(--line-2);border-radius:var(--r-s);padding:18px;background:var(--ink-2);animation:rise .5s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.result-card .top{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:8px}
.result-card .nom{font-family:var(--display);font-size:1.2rem}
.result-card .meta{font-family:var(--mono);font-size:.82rem;color:var(--muted);display:flex;gap:16px;flex-wrap:wrap}
.deadline{font-family:var(--mono);font-size:.85rem;margin-top:10px;padding:8px 12px;border-radius:7px;border:1px solid}
.deadline.urgent{color:var(--sev-liq);border-color:rgba(255,77,61,.4);background:rgba(255,77,61,.07)}
.deadline.ouvert{color:var(--ok);border-color:rgba(54,211,153,.35);background:rgba(54,211,153,.06)}
.deadline.forclos{color:var(--sev-clo);border-color:var(--line-2)}

/* stats counters */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
@media(max-width:620px){.stats{grid-template-columns:1fr}}
.stat .n{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem);color:var(--txt);line-height:1}
.stat .l{font-family:var(--mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* pricing */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
@media(max-width:860px){.plans{grid-template-columns:1fr}}
.plan{border:1px solid var(--line);border-radius:var(--r);padding:28px;display:flex;flex-direction:column;background:var(--ink-2)}
.plan.feat{border-color:var(--signal);box-shadow:0 30px 80px -50px rgba(201,162,75,.6);position:relative}
.plan.feat::after{content:"★";position:absolute;top:-12px;right:24px;background:var(--signal);color:#1a0c08;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:.8rem}
.plan .pname{font-family:var(--mono);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.plan .price{font-family:var(--display);font-size:2.8rem;margin:14px 0 2px}
.plan .price small{font-size:.95rem;font-family:var(--text);color:var(--muted)}
.plan .yr{font-family:var(--mono);font-size:.78rem;color:var(--dim);min-height:1.2em}
.plan .pd{color:var(--muted);font-size:.96rem;margin:16px 0 22px;flex:1}
.plan .btn{margin-top:auto}

/* light section (le registre) */
/* section "registre" : document securise (guilloche laiton type billet), pas de papier chaud */
.paper{background:var(--ink-2);color:var(--txt);position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.paper::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:repeating-radial-gradient(circle at 30% 20%,rgba(201,162,75,.05) 0,rgba(201,162,75,.05) 1px,transparent 1px,transparent 14px),repeating-radial-gradient(circle at 75% 70%,rgba(201,162,75,.04) 0,rgba(201,162,75,.04) 1px,transparent 1px,transparent 16px)}
.paper .wrap{position:relative}
.paper h2,.paper h3{color:var(--txt)}
.paper p{color:var(--muted)}
.paper .kicker{color:var(--brass-2)}
.ledger{font-family:var(--mono);font-size:.86rem;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;background:rgba(8,12,22,.6)}
.ledger .lrow{display:grid;grid-template-columns:120px 1fr 130px;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line)}
.ledger .lrow:last-child{border-bottom:none}
.ledger .lrow.h{background:rgba(201,162,75,.08);color:var(--brass-2);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}
.hash{color:var(--dim)}
.hash{color:#8a8071;word-break:break-all}

/* HERO IMMERSIF plein ecran (carte = heros, texte en surimpression) */
.hero-im{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;overflow:hidden;padding:88px 0 72px}
.hero-im-map{position:absolute;top:50%;right:max(-6vw,-120px);left:auto;transform:translateY(-50%);width:min(96vh,760px);height:auto;aspect-ratio:1/1;opacity:.92;pointer-events:none;filter:drop-shadow(0 0 70px rgba(201,162,75,.18))}
@media(max-width:900px){.hero-im-map{right:50%;transform:translate(50%,-50%);opacity:.5}}
.hero-im-scrim{position:absolute;inset:0;background:linear-gradient(90deg,var(--ink) 8%,rgba(11,18,32,.55) 44%,rgba(11,18,32,0) 78%),linear-gradient(0deg,var(--ink) 1%,transparent 30%)}
/* bulles vivantes : battement continu (en plus du pop-in) */
.fr-bubble>circle:first-child{transform-box:fill-box;transform-origin:center;animation:breathe 3.5s var(--ease) infinite;animation-delay:calc(var(--i,0)*80ms)}
@keyframes breathe{0%,100%{opacity:.85}50%{opacity:.45}}
@media(prefers-reduced-motion:reduce){.fr-bubble>circle:first-child{animation:none}}
.hero-im-inner{position:relative;z-index:3;max-width:760px}
.hero-im-h1{font-size:clamp(2.8rem,8vw,7rem);line-height:.98;letter-spacing:-.025em;margin:18px 0 .35em}
.hero-im-h1 .em{color:var(--brass-2)}
.hero-im .lead{font-size:clamp(1.05rem,1.5vw,1.3rem);max-width:54ch}
.hero-im-cockpit{position:absolute;right:clamp(20px,5vw,52px);bottom:104px;z-index:3;background:rgba(8,12,22,.72);backdrop-filter:blur(10px);border:1px solid var(--line-2);border-radius:var(--r-s);padding:16px 18px;max-width:300px}
.hero-im-cockpit .cockpit-sub b{color:var(--brass-2)}
@media(max-width:900px){.hero-im-cockpit{display:none}.hero-im-map{opacity:.4}}
.hero-im-scroll{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);z-index:3;width:26px;height:42px;border:1px solid var(--line-2);border-radius:14px;display:grid;justify-items:center;padding-top:8px}
.hero-im-scroll span{width:3px;height:8px;border-radius:2px;background:var(--brass);animation:scrolldot 1.7s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}100%{opacity:0;transform:translateY(11px)}}
.js .hero-im-h1{clip-path:inset(0 0 100% 0);animation:heroIn 1s var(--ease) .15s forwards}
.js .hero-im .lead,.js .hero-im .hero-cta{opacity:0;animation:fadeUp .8s var(--ease) forwards}
.js .hero-im .lead{animation-delay:.55s}.js .hero-im .hero-cta{animation-delay:.72s}
@media(prefers-reduced-motion:reduce){.hero-im-scroll span{animation:none}.js .hero-im-h1{clip-path:none}.js .hero-im .lead,.js .hero-im .hero-cta{opacity:1;animation:none}}

/* hero "Hexagone vivant" */
.france-wrap{position:relative}
.france-card{position:relative;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--panel),var(--ink-2));padding:16px;box-shadow:0 50px 110px -60px rgba(0,0,0,.95),inset 0 1px 0 rgba(201,162,75,.08)}
.france-head{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.france-head .live{width:8px;height:8px;border-radius:50%;background:var(--brass);animation:pulse 2s infinite}
.france-cov{margin-left:auto;color:var(--dim)}
.france-cov b{color:var(--brass-2)}
.france-svg{width:100%;height:auto;display:block;aspect-ratio:1/1}
.hexagon{filter:drop-shadow(0 0 18px rgba(201,162,75,.12))}
.bubbles{transition:transform .25s var(--ease)}
.js .hexagon{opacity:0;animation:fadein 1s var(--ease) .1s forwards}
@keyframes fadein{to{opacity:1}}
.fr-bubble{transform-box:fill-box;transform-origin:center}
.js .fr-bubble{opacity:0;animation:pop .6s var(--ease) forwards;animation-delay:calc(.3s + var(--i)*38ms)}
@keyframes pop{0%{opacity:0;transform:scale(.2)}70%{opacity:1;transform:scale(1.18)}100%{opacity:1;transform:scale(1)}}
.france-card .cockpit{position:absolute;left:24px;bottom:24px;background:rgba(8,12,22,.82);backdrop-filter:blur(8px);border:1px solid var(--line-2);border-radius:var(--r-s);padding:14px 16px;min-width:200px}
.cockpit-k{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cockpit-v{font-family:var(--display);font-size:1.9rem;color:var(--brass-2);line-height:1.1;margin:2px 0}
.cockpit-sub{font-family:var(--mono);font-size:.7rem;color:var(--dim)}
@media(max-width:520px){.france-card .cockpit{left:16px;bottom:16px;min-width:0}}

/* ticker "pouls national" */
.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2);overflow:hidden;white-space:nowrap;padding:11px 0}
.ticker-track{display:inline-block;white-space:nowrap;will-change:transform;font-family:var(--mono);font-size:.8rem;color:var(--muted)}
.js .ticker-track{animation:tick 80s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tk{padding:0 4px}.tk b{color:var(--dim);font-weight:400}
.tk i{font-style:normal;font-size:.72rem}
.tk-liq{color:var(--sev-liq)}.tk-red{color:var(--sev-red)}.tk-sau{color:var(--sev-sau)}.tk-clo{color:var(--sev-clo)}
.tk-sep{color:var(--brass);opacity:.4;padding:0 10px}
@media(prefers-reduced-motion:reduce){.js .fr-bubble{animation:none;opacity:1}.js .hexagon{animation:none;opacity:1}.js .ticker-track{animation:none}.france-head .live{animation:none}}

/* demo : centrage bulletproof via flex sur la section + boite centree */
#demo>.wrap{display:flex;flex-direction:column;align-items:center}
#demo .sec-head,#demo .demo-box{width:100%}
.demo-c{text-align:center;margin-left:auto;margin-right:auto}
.demo-c form{max-width:540px;margin:0 auto}
.demo-c .demo-input{justify-content:center}
.demo-c .demo-input input{flex:0 1 320px}
.demo-c .demo-picks{justify-content:center}
.demo-c .demo-result{text-align:left;max-width:540px;margin:18px auto 0}

/* barre de progression scroll */
.scrollbar{position:fixed;top:0;left:0;height:2px;width:0;background:linear-gradient(90deg,var(--brass),var(--brass-2));z-index:200;transition:width .08s linear}
@media(prefers-reduced-motion:reduce){.scrollbar{display:none}}

/* boutons magnetiques (translate via JS, base) */
.btn{will-change:transform}

/* split "bruit -> clarte" (signature, demontre le 10x) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;align-items:stretch}
@media(max-width:760px){.split{grid-template-columns:1fr}}
.split .noise{background:var(--ink-2);padding:24px;position:relative;max-height:360px;overflow:hidden}
.split .noise::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,var(--ink-2))}
.split .noise .nl{font-family:var(--mono);font-size:.62rem;color:var(--dim);opacity:.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.9}
.split .clear{background:linear-gradient(180deg,rgba(201,162,75,.06),transparent);padding:30px;border-left:1px solid var(--line-2);display:flex;flex-direction:column;justify-content:center}
.split .tag{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.split .clear .tag{color:var(--brass-2)}
.split .alert{border:1px solid var(--line-2);border-radius:var(--r-s);padding:18px;background:var(--ink-2)}
.split .alert .nom{font-family:var(--display);font-size:1.25rem}
.split .alert .meta{font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:8px;display:flex;gap:14px;flex-wrap:wrap}

/* comparatif concurrents */
.versus{width:100%;border-collapse:collapse;font-size:.92rem;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.versus th,.versus td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:center}
.versus th:first-child,.versus td:first-child{text-align:left;color:var(--muted)}
.versus thead th{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--ink-2)}
.versus thead th.us{color:var(--brass-2)}
.versus td.us{background:rgba(201,162,75,.06);color:var(--txt);font-weight:600}
.versus .yes{color:var(--ok)}.versus .no{color:var(--dim)}
.versus tr:last-child td{border-bottom:none}

/* features en registre editorial (anti-grille-de-cartes-IA) */
/* panneaux 2x2 a filets, gros chiffre laiton en filigrane (composition, pas liste plate) */
.feat-list{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-top:8px}
@media(max-width:720px){.feat-list{grid-template-columns:1fr}}
.feat-item{position:relative;display:block;padding:38px 34px 34px;background:var(--ink-2);overflow:hidden;transition:background .35s var(--ease)}
.feat-item::before{content:"";position:absolute;top:0;left:0;width:42px;height:3px;background:var(--brass);opacity:.8}
.feat-item .fx{position:absolute;top:14px;right:26px;font-family:var(--display);font-size:5.2rem;line-height:1;color:var(--brass);opacity:.13;font-variant-numeric:tabular-nums;pointer-events:none;transition:opacity .35s var(--ease)}
.feat-item h3{margin:0 0 .4em;font-size:1.32rem;position:relative}
.feat-item p{margin:0;color:var(--muted);max-width:46ch;position:relative}
.feat-item:hover{background:linear-gradient(180deg,rgba(201,162,75,.06),var(--ink-2))}
.feat-item:hover .fx{opacity:.28}
.js .feat-item{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease),background .35s var(--ease)}
.js .feat-item.in{opacity:1;transform:none}
@media(max-width:720px){.feat-item{padding:30px 24px}.feat-item .fx{font-size:3.6rem}}
@media(prefers-reduced-motion:reduce){.js .feat-item{opacity:1;transform:none}}
/* statement editorial (probleme) */
.statement{font-family:var(--display);font-size:clamp(1.7rem,3.4vw,2.8rem);line-height:1.12;letter-spacing:-.015em;max-width:20ch;margin:0}
.statement .stress{color:var(--brass-2)}
.lede-2col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:820px){.lede-2col{grid-template-columns:1fr;gap:22px}}

/* palette de commande ⌘K (signature power-user) */
.cmdk{position:fixed;inset:0;z-index:300;display:none;align-items:flex-start;justify-content:center;padding-top:14vh;background:rgba(6,9,16,.6);backdrop-filter:blur(6px)}
.cmdk.open{display:flex}
.cmdk-panel{width:min(560px,92vw);background:var(--ink-2);border:1px solid var(--line-2);border-radius:var(--r);box-shadow:0 40px 100px -40px rgba(0,0,0,.9);overflow:hidden;animation:rise .25s var(--ease)}
.cmdk-panel input{width:100%;border:none;border-bottom:1px solid var(--line);background:transparent;color:var(--txt);font-family:var(--text);font-size:1.15rem;padding:18px 20px;outline:none}
.cmdk-list{max-height:320px;overflow:auto;padding:8px}
.cmdk-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--r-s);cursor:pointer;color:var(--muted);font-size:.95rem}
.cmdk-item .k{font-family:var(--mono);font-size:.72rem;color:var(--dim);margin-left:auto}
.cmdk-item.on,.cmdk-item:hover{background:rgba(201,162,75,.10);color:var(--txt)}
.cmdk-item b{color:var(--brass-2);font-family:var(--mono)}
.cmdk-hint{display:none}
@media(min-width:900px){.cmdk-hint{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.7rem;color:var(--dim);border:1px solid var(--line);border-radius:6px;padding:.25em .5em;margin-left:4px}}

/* F11 timeline judiciaire (parcours d'une procedure par SIREN) */
.timeline{position:relative;margin:8px 0 0;padding-left:30px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,var(--brass),var(--line))}
.tl-item{position:relative;padding:0 0 26px 22px}
.tl-item::before{content:"";position:absolute;left:-30px;top:3px;width:16px;height:16px;border-radius:50%;background:var(--ink);border:2px solid var(--brass);box-shadow:0 0 0 4px var(--ink-2)}
.tl-item.liq::before{border-color:var(--sev-liq)}.tl-item.red::before{border-color:var(--sev-red)}.tl-item.sau::before{border-color:var(--sev-sau)}
.tl-date{font-family:var(--mono);font-size:.78rem;color:var(--brass-2)}
.tl-item h4{margin:.2em 0 .3em;font-family:var(--display);font-size:1.1rem;font-weight:600}
.tl-item p{margin:0;color:var(--muted);font-size:.92rem;max-width:62ch}

/* charts observatoire */
.bars{display:flex;flex-direction:column;gap:11px}
.bar-row{display:grid;grid-template-columns:160px 1fr 44px;gap:12px;align-items:center;font-size:.9rem}
.bar-lbl{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:12px;background:rgba(255,255,255,.05);border-radius:6px;overflow:hidden}
.bar-fill{display:block;height:100%;width:var(--w);border-radius:6px}
.js .bar-fill{width:0;animation:grow .9s var(--ease) forwards;animation-delay:var(--d,0ms)}
@keyframes grow{to{width:var(--w)}}
.bar-val{text-align:right;color:var(--txt)}
.spark{width:100%;height:130px;display:block}
@media(max-width:520px){.bar-row{grid-template-columns:110px 1fr 38px}}
@media(prefers-reduced-motion:reduce){.js .bar-fill{animation:none;width:var(--w)}}

/* footer */
footer{border-top:1px solid var(--line);padding:54px 0 40px;color:var(--muted);font-size:.92rem}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;margin-bottom:34px}
@media(max-width:760px){footer .cols{grid-template-columns:1fr}}
footer a{color:var(--muted);display:block;margin:.35em 0}
footer a:hover{color:var(--txt)}
.credit{font-family:var(--mono);font-size:.76rem;color:var(--dim);border-top:1px solid var(--line);padding-top:20px;line-height:1.7}
.disclaimer{font-size:.8rem;color:var(--dim);max-width:80ch;margin-top:10px}

/* app shell */
.app-wrap{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
@media(max-width:820px){.app-wrap{grid-template-columns:1fr}}
.side{border-right:1px solid var(--line);padding:22px 18px;background:var(--ink-2)}
.side .brand{margin-bottom:26px}
.side a{display:flex;align-items:center;gap:10px;color:var(--muted);padding:.6em .8em;border-radius:8px;margin:.2em 0;font-size:.96rem}
.side a.on,.side a:hover{background:rgba(255,255,255,.04);color:var(--txt);text-decoration:none}
.main{padding:30px clamp(20px,4vw,44px)}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}
@media(max-width:680px){.kpis{grid-template-columns:1fr}}
.kpi{border:1px solid var(--line);border-radius:var(--r);padding:20px;background:var(--ink-2)}
.kpi .n{font-family:var(--display);font-size:2.2rem}
.kpi .l{font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.kpi.alert .n{color:var(--signal)}
table.list{width:100%;border-collapse:collapse;font-size:.94rem}
table.list th{text-align:left;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--line-2)}
table.list td{padding:13px 12px;border-bottom:1px solid var(--line)}
table.list tr:hover td{background:rgba(255,255,255,.02)}
.flash{padding:12px 16px;border-radius:8px;margin-bottom:18px;font-size:.94rem}
.flash.ok{background:rgba(54,211,153,.1);border:1px solid rgba(54,211,153,.3);color:var(--ok)}
.flash.err{background:rgba(255,77,61,.1);border:1px solid rgba(255,77,61,.3);color:var(--sev-liq)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:6px}
.field input,.field textarea{width:100%;padding:.75em 1em;border-radius:var(--r-s);border:1px solid var(--line-2);background:var(--ink);color:var(--txt);font-family:var(--text);font-size:1rem}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--signal)}
.auth-card{max-width:440px;margin:8vh auto;border:1px solid var(--line);border-radius:var(--r);padding:34px;background:var(--ink-2)}
.center{text-align:center}
.mt{margin-top:18px}
