/* ============================================================
   SYNET — design system v5 « NEURAL » (2026)
   Dark bleu profond · réseau de neurones interactif
   Inspiration n8n : nav pilule, grandes cartes arrondies,
   typographie ample et douce, accents électriques lumineux
   Polices auto-hébergées (RGPD) : Exo 2 + Roboto Mono
   ============================================================ */

@font-face{
  font-family:'Exo 2';
  src:url('fonts/exo2-var.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Roboto Mono';
  src:url('fonts/robotomono-var.woff2') format('woff2');
  font-weight:100 700;font-style:normal;font-display:swap;
}

:root{
  --bg:#06080f;
  --bg-2:#0a0e1a;
  --card:rgba(15,21,40,.72);
  --card-solid:#0d1226;
  --border:rgba(125,150,255,.13);
  --border-strong:rgba(125,150,255,.30);
  --ink:#eef1fb;
  --muted:#98a4c6;
  --electric:#41c8ff;
  --electric-deep:#2f9bff;
  --indigo:#5b6cff;
  --glow:rgba(65,200,255,.45);
  --ok:#42d392;
  --warn:#ffc955;
  --radius:20px;
  --radius-s:11px;
  --maxw:1200px;
  --font:'Exo 2','Segoe UI',system-ui,sans-serif;
  --mono:'Roboto Mono',ui-monospace,'Cascadia Code',Consolas,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--font);
  background:var(--bg);color:var(--ink);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;
}
a{color:inherit;text-decoration:none}
img,svg,canvas{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;position:relative;z-index:2}
.mono{font-family:var(--mono)}
::selection{background:rgba(65,200,255,.35);color:#fff}

.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--electric-deep);color:#fff;padding:10px 18px;border-radius:0 0 12px 0;font-weight:600}
.skip-link:focus{left:0}

/* ---------- Fond : réseau de neurones plein écran ---------- */
#net{position:fixed;inset:0;z-index:0;pointer-events:none}
.bg-glow{position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 500px at 75% -5%,rgba(47,155,255,.13),transparent 70%),
    radial-gradient(700px 460px at 8% 35%,rgba(91,108,255,.09),transparent 70%),
    radial-gradient(900px 500px at 50% 110%,rgba(65,200,255,.07),transparent 70%);
}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse 120% 90% at 50% 40%,transparent 55%,rgba(4,6,12,.7) 100%)}

/* ---------- Barre de progression ---------- */
#progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:60;background:linear-gradient(90deg,var(--electric),var(--indigo));box-shadow:0 0 14px var(--glow)}

/* ---------- Nav pilule flottante (n8n style) ---------- */
.navbar{position:sticky;top:14px;z-index:50;padding:0 16px}
.nav-pill{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  background:rgba(10,14,28,.78);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid var(--border);border-radius:18px;padding:10px 14px 10px 12px;
  box-shadow:0 18px 50px rgba(0,0,0,.45)}
.logo{display:flex;align-items:center;gap:10px}
.logo img{height:52px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a:not(.btn){color:var(--muted);font-size:.93rem;font-weight:500;transition:color .2s;position:relative;padding:4px 2px}
.nav-links a:not(.btn):hover,.nav-links a:not(.btn).active{color:var(--ink)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;border-radius:2px;background:var(--electric);transition:width .25s}
.nav-links a:not(.btn):hover::after,.nav-links a:not(.btn).active::after{width:100%}
.nav-toggle{display:none;background:none;border:1px solid var(--border-strong);color:var(--ink);font-size:1.25rem;cursor:pointer;line-height:1;padding:8px 12px;border-radius:10px}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:var(--radius-s);
  font-weight:600;font-size:.95rem;color:#fff;border:none;cursor:pointer;
  background:linear-gradient(120deg,var(--electric-deep),var(--indigo));
  box-shadow:0 8px 30px rgba(47,155,255,.35);
  transition:transform .2s,box-shadow .25s,filter .2s;position:relative;overflow:hidden}
.btn::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.25) 50%,transparent 60%);transform:translateX(-130%);transition:transform .5s}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(65,200,255,.5);filter:brightness(1.06)}
.btn:hover::after{transform:translateX(130%)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn-ghost{background:rgba(255,255,255,.04);border:1px solid var(--border-strong);box-shadow:none;color:var(--ink)}
.btn-ghost:hover{border-color:var(--electric);box-shadow:0 0 26px rgba(65,200,255,.22)}
.btn:focus-visible,a:focus-visible,summary:focus-visible,input:focus-visible{outline:2px solid var(--electric);outline-offset:3px}

/* ---------- Étiquettes de section ---------- */
.sec-label{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--electric);margin-bottom:20px;
  border:1px solid rgba(65,200,255,.25);background:rgba(65,200,255,.07);padding:7px 16px;border-radius:999px}
.sec-label i{width:7px;height:7px;border-radius:50%;background:var(--electric);box-shadow:0 0 10px var(--glow)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:92px 0 70px;min-height:88vh;display:flex;align-items:center}
.hero-inner{width:100%}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);line-height:1.07;font-weight:300;letter-spacing:-.02em;margin-bottom:22px;color:#dfe6fa}
.hero h1 b{font-weight:700;color:#fff}
.hero h1 .grad{background:linear-gradient(100deg,var(--electric),var(--indigo));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
.hero p.lead{font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--muted);max-width:560px;margin-bottom:34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .coords{position:absolute;top:24px;right:28px;font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;color:rgba(152,164,198,.65);text-align:right}
.hero.centered{text-align:center;min-height:auto;padding:110px 0 80px}
.hero.centered p.lead{margin-left:auto;margin-right:auto}
.hero.centered .hero-cta{justify-content:center}

.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#bfe9ff;border:1px solid rgba(65,200,255,.3);background:rgba(65,200,255,.08);padding:8px 18px;border-radius:999px;margin-bottom:28px}
.kicker .pulse{width:8px;height:8px;border-radius:50%;background:var(--electric);box-shadow:0 0 0 0 rgba(65,200,255,.55);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(65,200,255,.55)}70%{box-shadow:0 0 0 10px rgba(65,200,255,0)}100%{box-shadow:0 0 0 0 rgba(65,200,255,0)}}
@media(prefers-reduced-motion:reduce){.kicker .pulse{animation:none}}

/* ---------- Console agent interactive ---------- */
.agent-card{background:linear-gradient(180deg,rgba(16,23,46,.92),rgba(10,14,28,.92));
  border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.55),0 0 60px rgba(47,155,255,.12);
  backdrop-filter:blur(14px)}
.agent-card .abar{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.025)}
.agent-card .abar .dot{width:9px;height:9px;border-radius:50%;background:#27314f}
.agent-card .abar .dot.on{background:var(--electric);box-shadow:0 0 10px var(--glow);animation:pulse 2.4s infinite}
.agent-card .abar span{margin-left:6px;color:var(--muted);font-family:var(--mono);font-size:.72rem;letter-spacing:.1em}
.agent-card .abar .state{margin-left:auto;color:var(--ok);font-family:var(--mono);font-size:.66rem;letter-spacing:.14em}
.agent-log{padding:18px 20px;min-height:240px;max-height:300px;overflow-y:auto;font-size:.92rem;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:rgba(125,150,255,.3) transparent}
.msg{max-width:92%;padding:11px 15px;border-radius:14px;line-height:1.55;white-space:pre-wrap}
.msg.user{align-self:flex-end;background:linear-gradient(120deg,rgba(47,155,255,.25),rgba(91,108,255,.25));border:1px solid rgba(91,140,255,.35);border-bottom-right-radius:4px}
.msg.bot{align-self:flex-start;background:rgba(255,255,255,.04);border:1px solid var(--border);border-bottom-left-radius:4px;color:#d9e1f8}
.msg.bot .c{color:var(--electric)}
.msg.think{align-self:flex-start;color:var(--muted);font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;background:none;border:none;padding:2px 4px}
.msg.think i{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--electric);margin-right:4px;animation:blinkdot 1s infinite}
.msg.think i:nth-child(2){animation-delay:.2s}
.msg.think i:nth-child(3){animation-delay:.4s}
@keyframes blinkdot{0%,100%{opacity:.2}50%{opacity:1}}
.agent-form{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--border);background:rgba(255,255,255,.02)}
.agent-form input{flex:1;background:rgba(6,9,18,.8);border:1px solid var(--border-strong);border-radius:var(--radius-s);color:var(--ink);padding:13px 16px;font-family:var(--font);font-size:.95rem;transition:border-color .2s,box-shadow .2s}
.agent-form input::placeholder{color:rgba(152,164,198,.6)}
.agent-form input:focus{border-color:var(--electric);box-shadow:0 0 0 3px rgba(65,200,255,.15);outline:none}
.agent-form button{padding:13px 20px}
.agent-chips{display:flex;gap:8px;flex-wrap:wrap;padding:0 16px 16px;background:rgba(255,255,255,.02)}
.agent-chips button{font-family:var(--mono);font-size:.68rem;letter-spacing:.05em;color:var(--muted);background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:999px;padding:7px 14px;cursor:pointer;transition:all .2s}
.agent-chips button:hover{color:#bfe9ff;border-color:rgba(65,200,255,.45);background:rgba(65,200,255,.08)}

/* ---------- Stats ---------- */
.stat-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:58px}
.stat{flex:1;min-width:150px;padding:22px 24px;background:var(--card);border:1px solid var(--border);border-radius:16px;backdrop-filter:blur(10px);transition:border-color .25s,transform .25s}
.stat:hover{border-color:rgba(65,200,255,.4);transform:translateY(-3px)}
.stat b{display:block;font-size:2.1rem;font-weight:800;font-family:var(--mono);letter-spacing:-.02em;line-height:1.15;background:linear-gradient(120deg,var(--electric),var(--indigo));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--muted);font-size:.8rem;letter-spacing:.04em}

/* ---------- Bandeau marquee ---------- */
.chips{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0;overflow:hidden;position:relative;z-index:2;background:rgba(8,11,22,.6);backdrop-filter:blur(8px)}
.chips .track{display:flex;width:max-content;animation:marquee 34s linear infinite}
.chips:hover .track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.chips .track{animation:none;flex-wrap:wrap;width:auto;justify-content:center}}
.chip{display:inline-flex;align-items:center;gap:11px;padding:15px 26px;font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--muted);white-space:nowrap}
.chip i{width:7px;height:7px;border-radius:50%;background:var(--electric);box-shadow:0 0 8px var(--glow);display:inline-block}

/* ---------- Sections ---------- */
section.block{padding:104px 0;position:relative}
.h2{font-size:clamp(1.9rem,4vw,3rem);font-weight:300;letter-spacing:-.02em;margin-bottom:18px;line-height:1.12;color:#dfe6fa}
.h2 b{font-weight:700;color:#fff}
.h2 .grad{background:linear-gradient(100deg,var(--electric),var(--indigo));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
.section-intro{max-width:660px;color:var(--muted);font-size:1.05rem;margin-bottom:52px}
.center{text-align:center;margin-left:auto;margin-right:auto}

/* ---------- Cartes (n8n style : grandes, arrondies, douces) ---------- */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:34px 30px;backdrop-filter:blur(10px);transition:transform .25s,border-color .25s,box-shadow .3s;overflow:hidden}
.card::before{content:"";position:absolute;inset:0;border-radius:var(--radius);background:radial-gradient(420px 200px at var(--mx,50%) var(--my,0%),rgba(65,200,255,.1),transparent 65%);opacity:0;transition:opacity .3s}
.card:hover{transform:translateY(-5px);border-color:rgba(65,200,255,.38);box-shadow:0 20px 60px rgba(0,0,0,.4),0 0 40px rgba(47,155,255,.1)}
.card:hover::before{opacity:1}
.ico{width:52px;height:52px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(65,200,255,.14),rgba(91,108,255,.1));border:1px solid rgba(125,150,255,.28);margin-bottom:22px;color:var(--electric);border-radius:14px}
.ico svg{width:26px;height:26px}
.card h3{font-size:1.16rem;margin-bottom:10px;font-weight:700}
.card p{color:var(--muted);font-size:.94rem;position:relative}
.card .tag{position:absolute;top:18px;right:18px;font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;color:rgba(65,200,255,.6)}
.card .flag{display:inline-block;font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:#bfe9ff;background:rgba(65,200,255,.12);border:1px solid rgba(65,200,255,.3);padding:4px 12px;font-weight:600;margin-bottom:14px;border-radius:999px}

/* ---------- Versus ---------- */
.versus{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.vs-col{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:38px 34px;backdrop-filter:blur(10px)}
.vs-col.win{background:linear-gradient(160deg,rgba(47,155,255,.16),rgba(13,18,38,.9));border-color:rgba(65,200,255,.4);box-shadow:0 0 60px rgba(47,155,255,.15)}
.vs-col h3{font-size:1.25rem;margin-bottom:4px;font-weight:700}
.vs-col .sub{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.vs-col ul{list-style:none}
.vs-col li{display:flex;gap:13px;padding:10px 0;font-size:.95rem;border-bottom:1px solid var(--border);color:var(--muted)}
.vs-col.win li{color:#dce5fa}
.vs-col li:last-child{border-bottom:none}
.vs-col li .x,.vs-col li .v{flex:0 0 22px;height:22px;display:grid;place-items:center;font-family:var(--mono);font-size:.72rem;font-weight:700;margin-top:1px;border-radius:50%}
.vs-col li .x{background:rgba(255,99,99,.13);color:#ff9b9b}
.vs-col li .v{background:rgba(66,211,146,.15);color:var(--ok)}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.split.rev .col-text{order:2}
.split.rev .col-viz{order:1}
.pillars{margin-top:8px;list-style:none}
.pillars li{display:flex;gap:18px;padding:19px 0;border-bottom:1px solid var(--border)}
.pillars li:last-child{border-bottom:none}
.pillars .pin{flex:0 0 46px;height:46px;background:linear-gradient(135deg,rgba(65,200,255,.13),rgba(91,108,255,.09));border:1px solid rgba(125,150,255,.28);display:grid;place-items:center;color:var(--electric);border-radius:13px}
.pillars .pin svg{width:22px;height:22px}
.pillars b{display:block;margin-bottom:3px;font-size:1.02rem;font-weight:700}
.pillars small{color:var(--muted);font-size:.92rem}

.orbit,.fed{aspect-ratio:1/1;position:relative;display:grid;place-items:center}
#orbit-canvas,#fed-canvas{position:absolute;inset:0;width:100%;height:100%}

/* ---------- Flow ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:ph}
.step{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 26px;position:relative;backdrop-filter:blur(10px);transition:transform .25s,border-color .25s;counter-increment:ph}
.step:hover{transform:translateY(-4px);border-color:rgba(65,200,255,.35)}
.step .num{font-family:var(--mono);font-weight:700;font-size:.66rem;color:var(--electric);letter-spacing:.2em;margin-bottom:16px;display:block;text-transform:uppercase}
.step::before{content:counter(ph,decimal-leading-zero);position:absolute;top:20px;right:22px;font-family:var(--mono);font-size:2.2rem;font-weight:700;color:transparent;-webkit-text-stroke:1px rgba(125,150,255,.3);line-height:1}
.step .bar{height:3px;width:38px;border-radius:3px;background:linear-gradient(90deg,var(--electric),var(--indigo));margin-bottom:18px}
.step h4{margin:0 0 8px;font-size:1.08rem;font-weight:700}
.step p{color:var(--muted);font-size:.9rem}

/* ---------- Terminal ---------- */
.terminal{background:#04060d;border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;font-family:var(--mono);font-size:.83rem;box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 50px rgba(47,155,255,.08)}
.terminal .tbar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.03)}
.terminal .tbar i{width:10px;height:10px;border-radius:50%;display:inline-block;background:#222c4a}
.terminal .tbar i.on{background:var(--electric);box-shadow:0 0 9px var(--glow)}
.terminal .tbar span{margin-left:8px;color:var(--muted);font-size:.72rem;letter-spacing:.08em}
.terminal .tbody{padding:20px 22px;line-height:1.9;overflow-x:auto;white-space:pre-wrap;color:#c9d6f2}
.terminal .p{color:var(--electric)}
.terminal .c{color:#5e6b8f}
.terminal .o{color:#e8eefc}
.terminal .ok{color:var(--ok)}
.terminal .gold{color:var(--warn)}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{background:var(--card);border:1px solid var(--border);border-radius:16px;backdrop-filter:blur(10px);overflow:hidden;transition:border-color .25s}
.faq details[open]{border-color:rgba(65,200,255,.4)}
.faq summary{cursor:pointer;padding:20px 24px;font-weight:600;font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:1.35rem;color:var(--electric);transition:transform .25s;flex:0 0 auto;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 24px 22px;color:var(--muted);font-size:.95rem;max-width:660px}

/* ---------- CTA ---------- */
.cta{position:relative;margin:24px auto 0;border:1px solid var(--border-strong);border-radius:26px;padding:72px 44px;text-align:center;overflow:hidden;
  background:linear-gradient(180deg,rgba(17,25,50,.85),rgba(8,11,22,.85));backdrop-filter:blur(12px)}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 260px at 50% -5%,rgba(47,155,255,.3),transparent 70%)}
.cta h2{position:relative;font-size:clamp(1.9rem,4vw,2.8rem);font-weight:300;margin-bottom:14px;letter-spacing:-.02em;color:#dfe6fa}
.cta h2 b{font-weight:700;color:#fff}
.cta h2 .grad{background:linear-gradient(100deg,var(--electric),var(--indigo));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}
.cta p{position:relative;color:var(--muted);max-width:560px;margin:0 auto 34px}
.cta .hero-cta{position:relative;justify-content:center}
.cta .small-print{position:relative;margin-top:26px;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;color:rgba(152,164,198,.7)}

/* ---------- Footer ---------- */
footer{border-top:1px solid var(--border);background:rgba(6,8,15,.85);backdrop-filter:blur(10px);color:var(--muted);padding:60px 0 38px;position:relative;z-index:2;margin-top:90px}
.foot-grid{display:flex;justify-content:space-between;gap:44px;flex-wrap:wrap;margin-bottom:40px}
.foot-col img{height:54px;width:auto;margin-bottom:16px}
.foot-col h5{color:var(--ink);font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}
.foot-col a{display:block;color:var(--muted);font-size:.9rem;padding:4px 0;transition:color .2s}
.foot-col a:hover{color:var(--electric)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;border-top:1px solid var(--border);padding-top:26px;text-transform:uppercase;color:rgba(152,164,198,.7)}
.eu-stars{display:inline-flex;gap:3px;vertical-align:-2px;margin:0 4px}
.eu-stars i{width:3px;height:3px;border-radius:50%;background:var(--warn);display:inline-block}

/* ---------- Légal ---------- */
.legal{max-width:840px;margin:0 auto;padding-top:24px}
.legal h1{font-size:clamp(2.2rem,4.4vw,3.2rem);font-weight:300;letter-spacing:-.02em;margin-bottom:10px;color:#dfe6fa}
.legal h1 b{font-weight:700;color:#fff}
.legal .updated{color:var(--muted);font-size:.74rem;margin-bottom:44px;font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase}
.legal section{margin-bottom:36px;padding-bottom:36px;border-bottom:1px solid var(--border)}
.legal section:last-child{border-bottom:none}
.legal h2{font-size:1.3rem;font-weight:700;margin-bottom:14px;display:flex;align-items:baseline;gap:14px}
.legal h2 .n{font-family:var(--mono);font-size:.85rem;color:var(--electric)}
.legal p{color:var(--muted);margin-bottom:12px}
.legal ul{color:var(--muted);margin:0 0 12px 20px}
.legal li{margin-bottom:6px}
.legal strong{color:var(--ink);font-weight:700}
.legal a{color:var(--electric);text-decoration:underline;text-underline-offset:3px}
.idcard{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px 28px;margin-top:6px;backdrop-filter:blur(10px)}
.idcard div{display:flex;gap:10px;padding:7px 0;flex-wrap:wrap;border-bottom:1px dashed var(--border)}
.idcard div:last-child{border-bottom:none}
.idcard .k{color:var(--muted);min-width:200px;font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;padding-top:3px}
.idcard .v{color:var(--ink);font-weight:600}

/* ---------- Reveal ---------- */
.rv{opacity:0;transform:translateY(26px)}
.rv.in{opacity:1;transform:none;transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}}

/* ---------- Responsive ---------- */
@media(max-width:1020px){
  .hero{min-height:auto}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:880px){
  .navbar{top:10px}
  .logo img{height:38px}
  .nav-links{position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:0;background:rgba(8,11,22,.97);border:1px solid var(--border);border-radius:16px;max-height:0;overflow:hidden;transition:max-height .3s;padding:0 20px}
  .nav-links.open{max-height:440px;padding:12px 20px}
  .nav-links a{padding:13px 0;width:100%;border-bottom:1px solid var(--border)}
  .nav-links a:last-child{border-bottom:none}
  .nav-toggle{display:block}
  .grid-3,.grid-2,.grid-4,.flow,.split,.versus{grid-template-columns:1fr}
  .split{gap:44px}
  .split.rev .col-text{order:1}
  .split.rev .col-viz{order:2}
  .orbit,.fed{max-width:380px;margin:0 auto;width:100%}
  .hero .coords{display:none}
  .agent-log{min-height:200px}
}
