/* =========================================================================
   Sygnara — design system « salle de contrôle / radar de signaux ».
   DA : nuit encre profonde, accent signal cyan, signaux chauds en ambre.
   Typo maison forgée (Sygnara Orbit / Text / Mono). Mobile-first.
   ========================================================================= */

/* ---------- fonts forgées (self-hostées, OFL) ---------- */
@font-face{font-family:"Sygnara Orbit";src:url("/fonts/sygnara-orbit.woff2") format("woff2");font-weight:600 720;font-display:swap;font-style:normal}
@font-face{font-family:"Sygnara Text";src:url("/fonts/sygnara-text.woff2") format("woff2");font-weight:400;font-display:swap;font-style:normal}
@font-face{font-family:"Sygnara Text";src:url("/fonts/sygnara-text-medium.woff2") format("woff2");font-weight:500 600;font-display:swap;font-style:normal}
@font-face{font-family:"Sygnara Mono";src:url("/fonts/sygnara-mono.woff2") format("woff2");font-weight:400 520;font-display:swap;font-style:normal}

/* ---------- tokens ---------- */
:root{
  --ink:#070b14;            /* fond nuit encre */
  --ink-2:#0a0e1a;
  --panel:#0d1322;          /* surface carte */
  --panel-2:#111a2e;        /* surface élevée */
  --panel-3:#16223a;
  --line:rgba(132,164,214,.14);
  --line-2:rgba(132,164,214,.08);
  --grid:rgba(110,231,255,.05);
  --signal:#6ee7ff;         /* cyan signal */
  --signal-deep:#39c6ec;
  --signal-glow:rgba(110,231,255,.35);
  --hot:#ffb27a;            /* ambre signaux chauds */
  --hot-glow:rgba(255,178,122,.30);
  --warn:#f8d57e;
  --text:#e8eefb;
  --text-2:#aebbd6;
  --muted:#7f8fb0;
  --muted-2:#5d6a87;
  --ok:#7af2c4;
  --bad:#ff8da3;
  --radius:16px;
  --radius-sm:11px;
  --radius-lg:24px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --font-display:"Sygnara Orbit","Sygnara Text",system-ui,sans-serif;
  --font-text:"Sygnara Text",system-ui,-apple-system,sans-serif;
  --font-mono:"Sygnara Mono",ui-monospace,"SFMono-Regular",monospace;
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --shadow-glow:0 0 0 1px var(--line),0 20px 50px -24px rgba(0,0,0,.8);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font-text);color:var(--text);background:var(--ink);
  font-size:16px;line-height:1.6;font-weight:400;letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* atmosphère : halos radar + grain */
  background-image:
    radial-gradient(900px 600px at 78% -8%, rgba(110,231,255,.10), transparent 60%),
    radial-gradient(700px 520px at 8% 12%, rgba(57,198,236,.06), transparent 55%),
    radial-gradient(1100px 700px at 50% 120%, rgba(255,178,122,.05), transparent 60%);
  background-attachment:fixed;
}
/* grain subtil global */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.05;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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img,svg,canvas{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:660;line-height:1.04;letter-spacing:-.02em}
p{margin:0}
:focus-visible{outline:2px solid var(--signal);outline-offset:3px;border-radius:6px}
::selection{background:var(--signal);color:var(--ink)}
.mono{font-family:var(--font-mono);font-feature-settings:"tnum" 1,"ss01" 1}

/* ---------- layout helpers ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(18px,4vw,36px)}
.section{padding-block:clamp(64px,9vw,128px);position:relative}
.kicker{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--signal);display:inline-flex;align-items:center;gap:.6em;margin-bottom:18px}
.kicker::before{content:"";width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--signal))}
.lead{color:var(--text-2);font-size:clamp(1.02rem,1.6vw,1.22rem);line-height:1.6;max-width:62ch}
.muted{color:var(--muted)}
.eyebrow-center{text-align:center;display:flex;flex-direction:column;align-items:center}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:.92em 1.5em;border-radius:999px;font-family:var(--font-text);font-weight:600;font-size:.96rem;
  letter-spacing:.01em;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s;
  will-change:transform;white-space:nowrap}
.btn svg{width:1.05em;height:1.05em;flex:none}
.btn-primary{background:linear-gradient(180deg,var(--signal),var(--signal-deep));color:#021018;
  box-shadow:0 10px 30px -10px var(--signal-glow),inset 0 1px 0 rgba(255,255,255,.45)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 44px -12px var(--signal-glow),inset 0 1px 0 rgba(255,255,255,.5)}
.btn-ghost{background:rgba(132,164,214,.06);color:var(--text);box-shadow:inset 0 0 0 1px var(--line)}
.btn-ghost:hover{background:rgba(132,164,214,.12);transform:translateY(-2px);box-shadow:inset 0 0 0 1px rgba(110,231,255,.4)}
.btn-hot{background:linear-gradient(180deg,var(--hot),#f59a5c);color:#2a1404;box-shadow:0 10px 30px -10px var(--hot-glow)}
.btn-hot:hover{transform:translateY(-2px)}
.btn-sm{padding:.6em 1em;font-size:.85rem}
.btn-block{width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none!important}

/* magnétisme léger (motion.js ajoute --mx/--my) */
.btn[data-magnetic]{transform:translate(var(--mx,0),var(--my,0))}

/* ---------- topbar (pages publiques) ---------- */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(7,11,20,.92),rgba(7,11,20,.6));
  border-bottom:1px solid var(--line-2)}
.topbar .wrap{display:flex;align-items:center;gap:20px;height:70px}
.brand{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-display);font-weight:660;
  font-size:1.22rem;letter-spacing:-.01em;color:var(--text)}
.brand .logo{width:30px;height:30px}
.brand small{font-family:var(--font-mono);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);display:block;margin-top:2px}
.topnav{margin-left:auto;display:flex;align-items:center;gap:6px}
.topnav a{padding:.5em .85em;border-radius:999px;color:var(--text-2);font-size:.92rem;transition:color .2s,background .2s}
.topnav a:hover{color:var(--text);background:rgba(132,164,214,.08)}
.topnav a.cta{color:var(--signal)}
.lang-btn{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;padding:.45em .7em;border-radius:8px;
  box-shadow:inset 0 0 0 1px var(--line);color:var(--text-2);transition:.2s}
.lang-btn:hover{color:var(--signal);box-shadow:inset 0 0 0 1px var(--signal)}
.nav-toggle{display:none;width:42px;height:42px;border-radius:10px;box-shadow:inset 0 0 0 1px var(--line);align-items:center;justify-content:center}
.nav-toggle svg{width:20px;height:20px}

/* ---------- HERO ---------- */
.hero{position:relative;padding-top:clamp(40px,7vw,90px);padding-bottom:clamp(50px,8vw,110px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:center}
.hero h1{font-size:clamp(2.3rem,5.6vw,4.5rem);line-height:1.0;margin:.35em 0 .55em}
.hero h1 .accent{color:transparent;background:linear-gradient(120deg,var(--signal),#bdf3ff 60%,var(--signal));-webkit-background-clip:text;background-clip:text}
.hero h1 .hot{color:var(--hot)}
.hero .lead{margin-bottom:30px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(18px,4vw,42px);margin-top:42px;padding-top:30px;border-top:1px solid var(--line-2)}
.stat{display:flex;flex-direction:column;gap:2px}
.stat b{font-family:var(--font-mono);font-size:clamp(1.5rem,3vw,2.1rem);font-weight:520;color:var(--text);letter-spacing:-.01em}
.stat span{font-size:.82rem;color:var(--muted);letter-spacing:.02em}

/* ---------- RADAR (signature) ---------- */
.radar-stage{position:relative;aspect-ratio:1;width:100%;max-width:520px;margin-inline:auto}
.radar-stage canvas{position:absolute;inset:0;width:100%;height:100%}
.radar-frame{position:absolute;inset:0;border-radius:50%;
  box-shadow:inset 0 0 0 1px var(--line),0 0 80px -10px var(--signal-glow);pointer-events:none}
.radar-badge{position:absolute;left:50%;bottom:6%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);
  padding:.5em .9em;border-radius:999px;background:rgba(7,11,20,.7);box-shadow:inset 0 0 0 1px var(--line);backdrop-filter:blur(6px)}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--signal);box-shadow:0 0 0 0 var(--signal-glow);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 var(--signal-glow)}70%{box-shadow:0 0 0 11px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media (prefers-reduced-motion:reduce){.live-dot{animation:none}}

/* ---------- reveal au scroll ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.08s}
[data-reveal][data-delay="2"]{transition-delay:.16s}
[data-reveal][data-delay="3"]{transition-delay:.24s}
[data-reveal][data-delay="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important;transition:none}}

/* ---------- section titles ---------- */
.sec-head{max-width:64ch;margin-bottom:clamp(34px,5vw,56px)}
.sec-head h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:16px}

/* ---------- 7 signaux : grille « fiches instrument » ---------- */
.signal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:16px}
.sig-card{position:relative;padding:26px 24px;border-radius:var(--radius);background:
  linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow);overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.sig-card::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(0deg,transparent 0 22px,var(--grid) 22px 23px);opacity:.6;pointer-events:none}
.sig-card:hover{transform:translateY(-5px);box-shadow:0 0 0 1px rgba(110,231,255,.35),0 28px 56px -22px rgba(0,0,0,.85)}
.sig-card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:18px;
  background:rgba(110,231,255,.1);box-shadow:inset 0 0 0 1px var(--line);color:var(--signal)}
.sig-card.warm .ic{background:rgba(255,178,122,.12);color:var(--hot)}
.sig-card .ic svg{width:22px;height:22px}
.sig-card h3{font-size:1.12rem;margin-bottom:8px;letter-spacing:-.01em}
.sig-card p{color:var(--text-2);font-size:.94rem;position:relative}
.sig-num{position:absolute;top:18px;right:20px;font-family:var(--font-mono);font-size:.72rem;color:var(--muted-2)}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:step}
.step{position:relative;padding:30px 26px;border-radius:var(--radius);background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2)}
.step .n{font-family:var(--font-mono);font-size:.8rem;color:var(--signal);letter-spacing:.2em;margin-bottom:16px;display:flex;align-items:center;gap:.6em}
.step .n::before{counter-increment:step;content:"0" counter(step);font-size:1.7rem;color:var(--text);letter-spacing:0}
.step h3{font-size:1.2rem;margin-bottom:10px}
.step p{color:var(--text-2);font-size:.95rem}
.step::after{content:"";position:absolute;right:-10px;top:50%;width:20px;height:1px;background:var(--line)}
.step:last-child::after{display:none}

/* ---------- proof ---------- */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px}
.proof-card{padding:28px 26px;border-radius:var(--radius);background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow)}
.proof-card .ic{color:var(--signal);margin-bottom:16px}
.proof-card .ic svg{width:26px;height:26px}
.proof-card h3{font-size:1.12rem;margin-bottom:8px}
.proof-card p{color:var(--text-2);font-size:.93rem}

/* ---------- comparatif ---------- */
.cmp{width:100%;border-collapse:collapse;font-size:.94rem;background:var(--panel);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-glow)}
.cmp th,.cmp td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line-2)}
.cmp thead th{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(132,164,214,.04)}
.cmp thead th:first-child{color:var(--text-2)}
.cmp tbody td:first-child{color:var(--text-2)}
.cmp .col-sy{color:var(--text);font-weight:600;background:rgba(110,231,255,.05)}
.cmp thead .col-sy{color:var(--signal)}
.cmp .yes{color:var(--signal)}
.cmp .no{color:var(--muted-2)}
.cmp .partial{color:var(--warn)}
.cmp-quote{margin-top:26px;font-family:var(--font-display);font-size:clamp(1.3rem,3vw,2rem);color:var(--text);text-align:center;letter-spacing:-.01em}
.cmp-quote span{color:var(--signal)}

/* ---------- bande CTA finale ---------- */
.cta-band{position:relative;border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);text-align:center;overflow:hidden;
  background:linear-gradient(140deg,#0c1426,#0a1322);box-shadow:var(--shadow-glow)}
.cta-band::before{content:"";position:absolute;inset:-2px;background:
  radial-gradient(420px 240px at 50% -10%,var(--signal-glow),transparent 60%);pointer-events:none}
.cta-band h2{font-size:clamp(1.8rem,4vw,3rem);margin-bottom:16px;position:relative}
.cta-band .lead{margin:0 auto 30px;position:relative}
.cta-band .hero-cta{justify-content:center;position:relative}

/* ---------- footer ---------- */
.site-foot{border-top:1px solid var(--line-2);padding-block:54px 40px;margin-top:40px;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px}
.foot-grid p{color:var(--muted);font-size:.92rem;max-width:42ch;margin-top:14px}
.foot-col h4{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-2);margin-bottom:14px}
.foot-col a{display:block;color:var(--muted);font-size:.93rem;padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--signal)}
.foot-bottom{margin-top:40px;padding-top:22px;border-top:1px solid var(--line-2);color:var(--muted-2);font-size:.84rem;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}

/* ============ pages SEO server-rendered (.seo) ============ */
body.seo{background-attachment:fixed}
.seo-nav{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:18px;padding:18px clamp(18px,4vw,36px);
  backdrop-filter:blur(12px);background:rgba(7,11,20,.85);border-bottom:1px solid var(--line-2)}
.seo-nav .brand{font-size:1.2rem}.seo-nav nav{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
.seo-nav nav a{padding:.5em .8em;border-radius:999px;color:var(--text-2);font-size:.9rem}
.seo-nav nav a:hover{background:rgba(132,164,214,.08);color:var(--text)}
.seo-nav nav a.cta{color:var(--signal)}
.seo-main{max-width:860px;margin:0 auto;padding:clamp(40px,7vw,80px) clamp(18px,4vw,36px)}
.seo-main .hero{padding:0 0 40px;display:block}
.seo-main h1{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:20px}
.seo-main h2{font-size:clamp(1.4rem,3vw,2rem);margin:48px 0 18px}
.seo-main p{color:var(--text-2);margin-bottom:14px}
.seo-main .lead{font-size:1.15rem;color:var(--text-2)}
.seo-main a.cta{display:inline-flex;margin-top:10px;color:var(--signal);font-weight:600}
.seo-main ul.signals{list-style:none;padding:0;display:grid;gap:12px}
.seo-main ul.signals li{padding:16px 18px;border-radius:12px;background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2)}
.seo-main ul.signals li strong{color:var(--text)}
.seo-main ol{color:var(--text-2);padding-left:1.2em}.seo-main ol li{margin-bottom:10px}
.seo-main .tags{line-height:2.2}.seo-main .tags a{color:var(--signal);padding:.2em .5em;border-radius:6px;background:rgba(110,231,255,.06)}
.seo-foot{border-top:1px solid var(--line-2);padding:40px clamp(18px,4vw,36px);color:var(--muted);font-size:.9rem;text-align:center}
.seo-foot nav{margin-top:14px}.seo-foot nav a{color:var(--text-2)}.seo-foot nav a:hover{color:var(--signal)}

/* ============================== APP ============================== */
.app-shell{display:grid;grid-template-columns:268px 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:8px;padding:24px 18px;
  background:linear-gradient(180deg,var(--ink-2),var(--ink));border-right:1px solid var(--line-2);z-index:30}
.sidebar .brand{padding:6px 10px 22px}
.side-nav{display:flex;flex-direction:column;gap:4px}
.side-nav a{display:flex;align-items:center;gap:.8em;padding:.78em 1em;border-radius:11px;color:var(--text-2);
  font-size:.95rem;font-weight:500;transition:background .2s,color .2s;position:relative}
.side-nav a svg{width:19px;height:19px;flex:none;opacity:.85}
.side-nav a:hover{background:rgba(132,164,214,.07);color:var(--text)}
.side-nav a.active{color:var(--signal);background:rgba(110,231,255,.08)}
.side-nav a.active::before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:3px;background:var(--signal);box-shadow:0 0 12px var(--signal-glow)}
.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:18px;border-top:1px solid var(--line-2)}
.plan-chip{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:.7em .9em;border-radius:11px;background:rgba(132,164,214,.06);font-size:.85rem;box-shadow:inset 0 0 0 1px var(--line-2)}
.plan-chip b{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--signal);font-size:.78rem}
.plan-chip.free b{color:var(--hot)}
.app-main{min-width:0;padding:clamp(22px,3.4vw,44px);max-width:1100px}
.app-topbar{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.app-topbar .page-h{flex:1;min-width:0}
.app-topbar h1{font-size:clamp(1.5rem,3vw,2.1rem);letter-spacing:-.02em}
.app-topbar .sub{color:var(--muted);font-size:.95rem;margin-top:4px}
.mobile-bar{display:none}

/* brief du jour (IA) */
.brief-card{display:flex;gap:18px;align-items:flex-start;padding:22px 24px;margin-bottom:20px;border-radius:var(--radius);
  background:linear-gradient(120deg,#0e1830,#0c1322);box-shadow:0 0 0 1px rgba(110,231,255,.25),0 20px 50px -28px rgba(0,0,0,.8);position:relative;overflow:hidden}
.brief-card::before{content:"";position:absolute;inset:0;background:radial-gradient(280px 120px at 0 0,var(--signal-glow),transparent 60%);opacity:.5;pointer-events:none}
.brief-ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;color:var(--signal);background:rgba(110,231,255,.1);box-shadow:inset 0 0 0 1px var(--line);position:relative}
.brief-ic svg{width:22px;height:22px}
.brief-body{position:relative;min-width:0}
.brief-lab{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);display:block;margin-bottom:6px}
.brief-text{color:var(--text);font-size:1rem;line-height:1.55}

/* constructeur d'ICP par IA */
.ai-builder{padding:16px 18px;border-radius:14px;background:rgba(110,231,255,.05);box-shadow:inset 0 0 0 1px rgba(110,231,255,.22);display:flex;flex-direction:column;gap:10px}
.ai-head{display:flex;align-items:center;gap:.5em;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--signal)}
.ai-head svg{width:16px;height:16px}
.ai-builder textarea{width:100%;padding:.7em .9em;border-radius:10px;background:var(--ink-2);box-shadow:inset 0 0 0 1px var(--line);color:var(--text);font:inherit;font-size:.92rem;resize:vertical;min-height:56px}
.ai-builder textarea:focus{outline:none;box-shadow:inset 0 0 0 1.5px var(--signal)}
.btn-ai{align-self:flex-start;background:linear-gradient(180deg,rgba(110,231,255,.16),rgba(110,231,255,.06));color:var(--signal);box-shadow:inset 0 0 0 1px rgba(110,231,255,.4)}
.btn-ai:hover{background:rgba(110,231,255,.2);transform:translateY(-2px)}
.why-points{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.why-points li{position:relative;padding-left:22px;color:var(--text-2);font-size:.93rem;line-height:1.5}
.why-points li::before{content:"";position:absolute;left:4px;top:8px;width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 8px var(--signal-glow)}

/* cartes stat dashboard */
.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}
.stat-card{padding:22px 24px;border-radius:var(--radius);background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow);position:relative;overflow:hidden}
.stat-card .lab{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.stat-card .val{font-family:var(--font-mono);font-size:2.3rem;font-weight:520;color:var(--text);letter-spacing:-.02em;margin-top:6px;line-height:1}
.stat-card.hot .val{color:var(--hot)}
.stat-card .hint{font-size:.8rem;color:var(--muted-2);margin-top:6px}
.stat-card .spark{position:absolute;right:-6px;bottom:-6px;width:80px;height:80px;opacity:.25;color:var(--signal)}

.panel{padding:24px;border-radius:var(--radius);background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2)}
.panel h2,.panel h3{font-size:1.05rem;margin-bottom:16px;font-family:var(--font-display);letter-spacing:-.01em}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-dash{display:grid;grid-template-columns:1.3fr 1fr;gap:16px;align-items:start}

/* barres de distribution */
.bars{display:flex;flex-direction:column;gap:12px}
.bar-row{display:grid;grid-template-columns:130px 1fr 42px;gap:12px;align-items:center;font-size:.88rem}
.bar-row .lab{color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:9px;border-radius:6px;background:rgba(132,164,214,.1);overflow:hidden}
.bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--signal-deep),var(--signal));transform-origin:left;transform:scaleX(0);transition:transform 1s var(--ease-out);box-shadow:0 0 14px -2px var(--signal-glow)}
.bar-fill.hot{background:linear-gradient(90deg,#f59a5c,var(--hot))}
.bar-row .n{font-family:var(--font-mono);color:var(--text);text-align:right;font-size:.85rem}
@media (prefers-reduced-motion:reduce){.bar-fill{transition:none}}

.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.quick{display:flex;flex-direction:column;gap:10px;padding:20px;border-radius:var(--radius);background:rgba(132,164,214,.05);box-shadow:inset 0 0 0 1px var(--line-2);transition:.25s var(--ease)}
.quick:hover{background:rgba(110,231,255,.07);transform:translateY(-3px);box-shadow:inset 0 0 0 1px rgba(110,231,255,.4)}
.quick svg{width:24px;height:24px;color:var(--signal)}
.quick b{font-size:.98rem}

.mini-radar{position:relative;aspect-ratio:1;max-width:240px;margin:6px auto 0}
.mini-radar canvas{width:100%;height:100%}

/* ---------- toolbar (filtres) ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:22px}
.toolbar .spacer{flex:1}
.seg{display:inline-flex;background:rgba(132,164,214,.06);border-radius:999px;padding:4px;box-shadow:inset 0 0 0 1px var(--line-2);gap:2px;flex-wrap:wrap}
.seg button{padding:.5em .95em;border-radius:999px;font-size:.86rem;color:var(--text-2);font-weight:500;transition:.2s}
.seg button.active{background:var(--signal);color:var(--ink)}
.seg button:not(.active):hover{color:var(--text)}
.field-inline{display:inline-flex;align-items:center;gap:8px}
.select,select.select{appearance:none;padding:.6em 2.2em .6em 1em;border-radius:10px;background:var(--panel-2);
  box-shadow:inset 0 0 0 1px var(--line);color:var(--text);font-size:.9rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%237f8fb0' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7em center;background-size:16px}

/* ---------- FICHE RADAR (match) ---------- */
.matches{display:flex;flex-direction:column;gap:14px}
.fiche{position:relative;display:grid;grid-template-columns:96px 1fr;gap:22px;padding:22px 24px;border-radius:var(--radius);
  background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.fiche:hover{transform:translateY(-3px);box-shadow:0 0 0 1px rgba(110,231,255,.28),0 26px 50px -24px rgba(0,0,0,.85)}
.fiche.is-hot{background:linear-gradient(180deg,#1a1626,var(--panel))}
.fiche.is-hot::after{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:3px;background:var(--hot);box-shadow:0 0 16px var(--hot-glow)}
.fiche.dim{opacity:.55}

/* jauge de score (anneau) */
.gauge{position:relative;width:88px;height:88px;align-self:start}
.gauge svg{transform:rotate(-90deg);width:100%;height:100%}
.gauge .track{stroke:rgba(132,164,214,.14)}
.gauge .arc{stroke:var(--signal);stroke-linecap:round;filter:drop-shadow(0 0 6px var(--signal-glow));transition:stroke-dashoffset 1.1s var(--ease-out)}
.gauge.hot .arc{stroke:var(--hot);filter:drop-shadow(0 0 6px var(--hot-glow))}
.gauge .num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge .num b{font-family:var(--font-mono);font-size:1.6rem;font-weight:520;color:var(--text);line-height:1}
.gauge .num small{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media (prefers-reduced-motion:reduce){.gauge .arc{transition:none}}

.fiche-body{min-width:0}
.fiche-top{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:6px}
.fiche-top h3{font-size:1.18rem;letter-spacing:-.01em}
.fiche-meta{color:var(--muted);font-size:.86rem;display:flex;flex-wrap:wrap;gap:.4em .9em;margin-bottom:14px}
.fiche-meta .mono{color:var(--text-2)}
.badge{display:inline-flex;align-items:center;gap:.4em;padding:.34em .7em;border-radius:999px;font-size:.74rem;font-weight:600;
  font-family:var(--font-mono);letter-spacing:.04em;box-shadow:inset 0 0 0 1px var(--line)}
.badge.intent{color:var(--signal);background:rgba(110,231,255,.08)}
.badge.type{color:var(--text-2);background:rgba(132,164,214,.07)}
.badge.fresh{color:var(--ink);background:var(--signal)}
.badge.fresh.recent{background:var(--hot);color:#2a1404}
.badge.fresh.old{background:transparent;color:var(--muted);box-shadow:inset 0 0 0 1px var(--line)}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.signal-line{display:flex;align-items:flex-start;gap:.6em;font-size:.95rem;color:var(--text);margin-bottom:10px}
.signal-line svg{width:17px;height:17px;color:var(--signal);flex:none;margin-top:3px}
.dirigeant-line{display:flex;flex-wrap:wrap;align-items:center;gap:.5em .9em;font-size:.88rem;color:var(--text-2);margin-bottom:14px}
.dirigeant-line .who{color:var(--text);font-weight:500}
.dirigeant-line a{display:inline-flex;align-items:center;gap:.35em;color:var(--signal);font-size:.82rem;padding:.25em .55em;border-radius:7px;background:rgba(110,231,255,.06);transition:.2s}
.dirigeant-line a:hover{background:rgba(110,231,255,.14)}
.dirigeant-line a svg{width:13px;height:13px}
.angle{position:relative;padding:14px 16px 14px 18px;border-radius:12px;background:rgba(110,231,255,.05);box-shadow:inset 0 0 0 1px var(--line-2);margin-bottom:16px}
.angle::before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:2px;border-radius:2px;background:var(--signal)}
.angle .lab{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--signal);display:block;margin-bottom:6px}
.angle p{color:var(--text-2);font-size:.92rem;line-height:1.55}
.fiche-actions{display:flex;flex-wrap:wrap;gap:8px}
.act{display:inline-flex;align-items:center;gap:.45em;padding:.55em .9em;border-radius:9px;font-size:.84rem;font-weight:500;
  color:var(--text-2);box-shadow:inset 0 0 0 1px var(--line-2);transition:.2s;background:rgba(132,164,214,.04)}
.act svg{width:15px;height:15px}
.act:hover{color:var(--text);box-shadow:inset 0 0 0 1px var(--line);background:rgba(132,164,214,.1)}
.act.primary{color:var(--signal);box-shadow:inset 0 0 0 1px rgba(110,231,255,.35);background:rgba(110,231,255,.07)}
.act.primary:hover{background:rgba(110,231,255,.15)}
.act.done{color:var(--ok)}

/* ---------- paywall ---------- */
.paywall{position:relative;margin-top:18px;padding:32px;border-radius:var(--radius);text-align:center;overflow:hidden;
  background:linear-gradient(160deg,#13182a,#0c1322);box-shadow:var(--shadow-glow)}
.paywall::before{content:"";position:absolute;inset:0;background:radial-gradient(300px 160px at 50% 0,var(--hot-glow),transparent 60%);pointer-events:none}
.paywall h3{font-size:1.35rem;margin-bottom:10px;position:relative}
.paywall p{color:var(--text-2);max-width:48ch;margin:0 auto 20px;position:relative}

/* ---------- empty states ---------- */
.empty{text-align:center;padding:60px 24px;border-radius:var(--radius);background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2)}
.empty .ic{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px;
  background:rgba(110,231,255,.06);box-shadow:inset 0 0 0 1px var(--line);color:var(--signal)}
.empty .ic svg{width:30px;height:30px}
.empty h3{font-size:1.2rem;margin-bottom:8px}
.empty p{color:var(--muted);max-width:44ch;margin:0 auto}
.skeleton{border-radius:var(--radius);background:linear-gradient(100deg,var(--panel) 30%,var(--panel-2) 50%,var(--panel) 70%);background-size:200% 100%;animation:sk 1.4s infinite;height:140px}
@keyframes sk{to{background-position:-200% 0}}
@media (prefers-reduced-motion:reduce){.skeleton{animation:none}}

/* ---------- ICP ---------- */
.icp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,330px),1fr));gap:16px}
.icp-card{padding:22px 24px;border-radius:var(--radius);background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow);display:flex;flex-direction:column;gap:12px}
.icp-card h3{font-size:1.12rem}
.icp-card .pitch{color:var(--text-2);font-size:.92rem}
.icp-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}
.tag{font-family:var(--font-mono);font-size:.72rem;padding:.3em .6em;border-radius:7px;background:rgba(132,164,214,.08);color:var(--text-2)}
.icp-card .icp-actions{display:flex;gap:8px;margin-top:8px}
.icp-add{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;min-height:200px;cursor:pointer;
  border-radius:var(--radius);box-shadow:inset 0 0 0 1.5px var(--line);background:rgba(132,164,214,.03);color:var(--text-2);transition:.25s}
.icp-add:hover{box-shadow:inset 0 0 0 1.5px var(--signal);color:var(--signal);background:rgba(110,231,255,.05)}
.icp-add svg{width:32px;height:32px}

/* ---------- forms ---------- */
.form-grid{display:grid;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.84rem;color:var(--text-2);font-weight:500}
.field .hint{font-size:.78rem;color:var(--muted-2)}
.input,.field input,.field textarea,.field select{width:100%;padding:.78em 1em;border-radius:11px;background:var(--ink-2);
  box-shadow:inset 0 0 0 1px var(--line);color:var(--text);font-size:.95rem;transition:box-shadow .2s,background .2s}
.field textarea{resize:vertical;min-height:84px}
.input:focus,.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:inset 0 0 0 1.5px var(--signal);background:#0b1322}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:.5em .85em;border-radius:999px;font-size:.85rem;color:var(--text-2);box-shadow:inset 0 0 0 1px var(--line);cursor:pointer;transition:.2s;user-select:none}
.chip:hover{color:var(--text)}
.chip.on{background:var(--signal);color:var(--ink);box-shadow:none;font-weight:600}
.chip.on.hot{background:var(--hot);color:#2a1404}

/* ---------- modal ---------- */
.modal-back{position:fixed;inset:0;z-index:100;background:rgba(4,7,14,.72);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-back.open{opacity:1;pointer-events:auto}
.modal{width:min(620px,100%);max-height:90vh;overflow:auto;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:0 40px 90px -30px #000,inset 0 0 0 1px var(--line);
  transform:translateY(20px) scale(.98);transition:transform .35s var(--ease-out)}
.modal-back.open .modal{transform:none}
.modal-head{display:flex;align-items:flex-start;gap:14px;padding:24px 26px 18px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--panel-2);z-index:2}
.modal-head h3{font-size:1.25rem}
.modal-head p{color:var(--muted);font-size:.88rem;margin-top:4px}
.modal-close{margin-left:auto;width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:var(--text-2);box-shadow:inset 0 0 0 1px var(--line-2);flex:none;transition:.2s}
.modal-close:hover{color:var(--text);box-shadow:inset 0 0 0 1px var(--signal)}
.modal-body{padding:22px 26px 26px}
.modal-tabs{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:rgba(132,164,214,.06);box-shadow:inset 0 0 0 1px var(--line-2);margin-bottom:18px}
.modal-tabs button{padding:.5em 1em;border-radius:999px;font-size:.86rem;color:var(--text-2);font-weight:500}
.modal-tabs button.active{background:var(--signal);color:var(--ink)}
.out-block{margin-bottom:16px}
.out-block .lab{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.out-block .lab button{margin-left:auto;color:var(--signal);font-size:.72rem;padding:.3em .6em;border-radius:7px;background:rgba(110,231,255,.07)}
.out-text{padding:14px 16px;border-radius:11px;background:var(--ink-2);box-shadow:inset 0 0 0 1px var(--line-2);color:var(--text-2);font-size:.92rem;white-space:pre-wrap;line-height:1.6}

/* ---------- pricing ---------- */
.price-toggle{display:inline-flex;align-items:center;gap:4px;padding:4px;border-radius:999px;background:rgba(132,164,214,.06);box-shadow:inset 0 0 0 1px var(--line-2);margin:0 auto}
.price-toggle button{padding:.6em 1.2em;border-radius:999px;font-size:.9rem;color:var(--text-2);font-weight:500;transition:.2s}
.price-toggle button.active{background:var(--signal);color:var(--ink)}
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px;align-items:stretch}
.tier{position:relative;display:flex;flex-direction:column;gap:8px;padding:30px 28px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow)}
.tier.pop{box-shadow:0 0 0 1.5px var(--signal),0 30px 70px -28px var(--signal-glow)}
.tier-tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--signal);padding:.4em .9em;border-radius:999px}
.tier h3{font-size:1.3rem}
.tier .desc{color:var(--muted);font-size:.9rem;min-height:2.6em}
.tier .price{display:flex;align-items:baseline;gap:.3em;margin:10px 0 4px}
.tier .price b{font-family:var(--font-mono);font-size:2.8rem;font-weight:520;color:var(--text);letter-spacing:-.02em}
.tier .price span{color:var(--muted);font-size:.9rem}
.tier .billed{font-size:.78rem;color:var(--muted-2);min-height:1.2em}
.tier ul{list-style:none;padding:0;margin:18px 0 24px;display:flex;flex-direction:column;gap:11px;flex:1}
.tier li{display:flex;align-items:flex-start;gap:.6em;font-size:.92rem;color:var(--text-2)}
.tier li svg{width:18px;height:18px;color:var(--signal);flex:none;margin-top:2px}
.tier.pop li svg{color:var(--signal)}
.price-table{width:100%;border-collapse:collapse;margin-top:30px;font-size:.92rem;background:var(--panel);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-glow)}
.price-table th,.price-table td{padding:14px 16px;text-align:center;border-bottom:1px solid var(--line-2)}
.price-table th:first-child,.price-table td:first-child{text-align:left;color:var(--text-2)}
.price-table thead th{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.price-table .col-pro{background:rgba(110,231,255,.05);color:var(--text)}
.price-table thead .col-pro{color:var(--signal)}
.price-table svg{width:17px;height:17px;color:var(--signal)}
.price-table .x{color:var(--muted-2)}
.faq{display:grid;gap:12px;margin-top:30px;max-width:780px}
.faq details{padding:18px 22px;border-radius:var(--radius);background:var(--panel);box-shadow:inset 0 0 0 1px var(--line-2);transition:.2s}
.faq details[open]{box-shadow:inset 0 0 0 1px var(--line)}
.faq summary{font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;gap:.6em;font-size:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"+";font-family:var(--font-mono);color:var(--signal);font-size:1.3rem;transition:transform .25s}
.faq details[open] summary::before{transform:rotate(45deg)}
.faq p{color:var(--text-2);margin-top:12px;font-size:.94rem}

/* ---------- diagnostic ---------- */
.diag-card{max-width:540px;margin:0 auto;padding:32px;border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--panel-2),var(--panel));box-shadow:var(--shadow-glow)}
.diag-results{margin-top:30px;display:grid;gap:12px}
.diag-total{text-align:center;font-family:var(--font-mono);color:var(--signal);font-size:.95rem;margin-bottom:6px}
.diag-total b{font-size:1.6rem}
.diag-sig{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;padding:16px 18px;border-radius:12px;background:rgba(132,164,214,.05);box-shadow:inset 0 0 0 1px var(--line-2)}
.diag-sig .badge{align-self:start}
.diag-sig .co{font-weight:600;color:var(--text)}
.diag-sig .meta{color:var(--muted);font-size:.84rem}
.diag-sig .tt{color:var(--text-2);font-size:.9rem;margin-top:3px}

/* ---------- toast ---------- */
.toast-wrap{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}
.toast{padding:.8em 1.3em;border-radius:999px;background:var(--panel-2);box-shadow:0 16px 40px -16px #000,inset 0 0 0 1px var(--line);
  color:var(--text);font-size:.9rem;display:flex;align-items:center;gap:.6em;opacity:0;transform:translateY(12px);transition:.3s var(--ease-out)}
.toast.show{opacity:1;transform:none}
.toast svg{width:17px;height:17px;color:var(--signal)}
.toast.err svg{color:var(--bad)}

/* ---------- utilitaire ---------- */
.hidden{display:none!important}
.center{text-align:center}
.mt-l{margin-top:42px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ============================ responsive ============================ */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:34px}
  .radar-stage{max-width:380px}
  .hero .hero-cta{justify-content:flex-start}
  .steps,.proof-grid,.quick-grid,.tiers{grid-template-columns:1fr}
  .step::after{display:none}
  .grid-dash,.grid-2{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;transform:translateX(-105%);transition:transform .3s var(--ease);box-shadow:0 0 80px #000}
  .sidebar.open{transform:none}
  .mobile-bar{display:flex;align-items:center;gap:12px;padding:14px 16px;position:sticky;top:0;z-index:25;
    background:rgba(7,11,20,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-2)}
  .mobile-bar .brand{font-size:1.1rem}
  .menu-btn{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--line)}
  .menu-btn svg{width:20px;height:20px}
  .scrim{position:fixed;inset:0;background:rgba(4,7,14,.6);z-index:20;opacity:0;pointer-events:none;transition:.3s}
  .scrim.show{opacity:1;pointer-events:auto}
  .app-main{padding:18px}
  .topnav{display:none;position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;gap:4px;padding:14px;
    background:rgba(7,11,20,.98);border-bottom:1px solid var(--line);backdrop-filter:blur(14px)}
  .topnav.open{display:flex}
  .topnav a{padding:.8em 1em}
  .nav-toggle{display:flex;margin-left:auto}
  .fiche{grid-template-columns:1fr}
  .gauge{width:74px;height:74px}
  .fiche .gauge{justify-self:start}
}
@media (max-width:480px){
  .foot-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
  .bar-row{grid-template-columns:96px 1fr 36px}
}
