/* ===========================================================
   QTECO — WEBSITE V2 · "Spectacular" dark-first edition
   Levend netwerk, NOC-panelen, ecosysteem, AI-console.
   Brand: Indigo + Signal Red · Space Grotesk / IBM Plex
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --indigo-950:#100D29; --indigo-900:#17133F; --indigo-800:#1E1A54;
  --indigo-700:#262262; --indigo-600:#322C7F; --indigo-500:#423B9E;
  --indigo-400:#5C54C0; --indigo-300:#867FD7; --indigo-200:#B4AFE8;
  --indigo-100:#E0DEF5; --indigo-50:#F1F0FB;
  --red:#E11B2E; --red-bright:#FF3349; --red-dark:#B5121F;
  --green:#2EBD7B;
  --fd:'Space Grotesk', Arial, sans-serif;
  --fs:'IBM Plex Sans', Calibri, Arial, sans-serif;
  --fm:'IBM Plex Mono', Consolas, monospace;
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* dark-first tokens */
  --bg:#0B0921; --bg-2:#0F0C2B; --bg-3:#141038;
  --panel:rgba(255,255,255,.04); --panel-2:rgba(255,255,255,.07);
  --bd:rgba(255,255,255,.09); --bd-2:rgba(255,255,255,.16);
  --heading:#F2F1FA; --text:rgba(234,233,245,.78); --soft:rgba(234,233,245,.55); --mute:rgba(234,233,245,.36);
  --accent:#FF3349; --accent-soft:rgba(225,27,46,.16);
  --glow-indigo:rgba(92,84,192,.34); --glow-red:rgba(225,27,46,.22);
  --card-shadow:0 24px 60px rgba(0,0,0,.42);
  --nav-bg:rgba(11,9,33,.72);
  --term-bg:#08061B;
}
:root[data-theme="light"]{
  --bg:#FFFFFF; --bg-2:#F4F4F8; --bg-3:#ECEBF4;
  --panel:#FFFFFF; --panel-2:#F7F6FB;
  --bd:#E5E4EE; --bd-2:#CDCBE0;
  --heading:#262262; --text:#3A384A; --soft:#5A5870; --mute:#8C8AA0;
  --accent:#E11B2E; --accent-soft:rgba(225,27,46,.09);
  --glow-indigo:rgba(92,84,192,.16); --glow-red:rgba(225,27,46,.10);
  --card-shadow:0 18px 48px rgba(16,13,41,.12);
  --nav-bg:rgba(255,255,255,.82);
  --term-bg:#0C0A22;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-padding-top:90px;}
body{font-family:var(--fs);color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden;transition:background .35s var(--ease),color .35s var(--ease);}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
section{position:relative;}
::selection{background:var(--indigo-500);color:#fff;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 44px;}

/* ---------- shared type ---------- */
.eyebrow{font-family:var(--fm);font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:11px;}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent);display:inline-block;}
h1,h2,h3,h4{font-family:var(--fd);color:var(--heading);font-weight:600;letter-spacing:-.02em;line-height:1.05;}
.h-sec{font-size:clamp(34px,4.4vw,58px);letter-spacing:-.03em;}
.lead{font-size:clamp(16px,1.5vw,19px);line-height:1.65;color:var(--soft);max-width:60ch;}
.mono{font-family:var(--fm);}

/* ---------- buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:10px;font-family:var(--fd);font-weight:600;font-size:15px;border-radius:12px;padding:15px 26px;border:1.5px solid transparent;cursor:pointer;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s,border-color .2s,color .2s;white-space:nowrap;overflow:hidden;}
.btn .arr{transition:transform .22s var(--ease);}
.btn:hover .arr{transform:translateX(5px);}
.btn-cta{background:var(--red);color:#fff;box-shadow:0 10px 32px rgba(225,27,46,.35),inset 0 1px 0 rgba(255,255,255,.18);}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(225,27,46,.45),inset 0 1px 0 rgba(255,255,255,.18);background:var(--red-bright);}
.btn-ghost{background:transparent;color:var(--heading);border-color:var(--bd-2);}
.btn-ghost:hover{border-color:var(--heading);background:var(--panel-2);transform:translateY(-2px);}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s var(--ease),box-shadow .3s var(--ease),border-color .3s;border-bottom:1px solid transparent;}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:18px 44px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.nav .brand img{height:30px;}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--soft);transition:color .15s;letter-spacing:-.005em;white-space:nowrap;position:relative;}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--accent);transition:right .25s var(--ease);}
.nav-links a:hover{color:var(--heading);}
.nav-links a:hover::after{right:0;}
.nav.scrolled{background:var(--nav-bg);backdrop-filter:saturate(160%) blur(18px);-webkit-backdrop-filter:saturate(160%) blur(18px);border-bottom-color:var(--bd);box-shadow:0 8px 32px rgba(0,0,0,.18);}
.nav-actions{display:flex;align-items:center;gap:11px;}
.nav-support{display:inline-flex;align-items:center;gap:8px;font-family:var(--fd);font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;background:transparent;border:1px solid var(--bd-2);color:var(--heading);transition:all .18s;white-space:nowrap;flex-shrink:0;}
.nav-support svg{width:16px;height:16px;}
.nav-support:hover{background:var(--panel-2);border-color:var(--heading);transform:translateY(-1px);}
.lang-switch{display:flex;align-items:center;border:1px solid var(--bd-2);border-radius:10px;overflow:hidden;height:40px;flex-shrink:0;}
.lang-switch button{appearance:none;border:0;background:transparent;color:var(--mute);font-family:var(--fd);font-weight:600;font-size:13px;padding:0 12px;height:100%;cursor:pointer;transition:background .16s,color .16s;}
.lang-switch button.active{background:var(--panel-2);color:var(--heading);}
.lang-switch button:not(.active):hover{color:var(--heading);}
.theme-toggle{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--bd-2);color:var(--heading);cursor:pointer;transition:all .18s;flex-shrink:0;}
.theme-toggle:hover{background:var(--panel-2);}
.theme-toggle svg{width:18px;height:18px;}
.theme-toggle .moon{display:none;}
:root:not([data-theme="light"]) .theme-toggle .sun{display:none;}
:root:not([data-theme="light"]) .theme-toggle .moon{display:block;}
.nav-cta{font-family:var(--fd);font-weight:600;font-size:14px;padding:11px 20px;border-radius:10px;background:var(--red);border:1px solid var(--red);color:#fff;transition:all .18s;white-space:nowrap;box-shadow:0 6px 20px rgba(225,27,46,.3);}
.nav-cta:hover{background:var(--red-bright);transform:translateY(-1px);box-shadow:0 10px 28px rgba(225,27,46,.4);}

/* ---------- HERO ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:140px 0 40px;}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 900px 600px at 75% 15%,var(--glow-indigo),transparent 60%),radial-gradient(ellipse 700px 500px at 10% 90%,var(--glow-red),transparent 60%);pointer-events:none;}
#net{position:absolute;inset:0;width:100%;height:100%;opacity:.85;}
.hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1.08fr .92fr;gap:64px;align-items:center;flex:1;}
.hero-copy .eyebrow{margin-bottom:28px;}
.hero h1{font-size:clamp(40px,5.2vw,74px);letter-spacing:-.04em;line-height:.99;white-space:nowrap;}
.hero h1 .br{color:var(--indigo-300);}
.hero h1 .line{display:block;overflow:hidden;}
.hero h1 .line span{display:inline-block;transform:translateY(110%);animation:rise .9s var(--ease-out) forwards;}
.hero h1 .line:nth-child(2) span{animation-delay:.12s;}
@keyframes rise{to{transform:none;}}
.hero .pos{font-family:var(--fd);font-weight:500;font-size:clamp(18px,2vw,24px);color:var(--soft);margin-top:28px;letter-spacing:-.01em;}
.hero .pos .a{color:var(--accent);}
.hero .actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap;}
.hero .trust{display:flex;gap:38px;margin-top:52px;flex-wrap:wrap;}
.hero .trust .ti{display:flex;flex-direction:column;gap:5px;}
.hero .trust .tk{font-family:var(--fd);font-weight:600;font-size:30px;color:var(--heading);letter-spacing:-.02em;font-variant-numeric:tabular-nums;}
.hero .trust .tk em{font-style:normal;color:var(--accent);}
.hero .trust .tl{font-family:var(--fm);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--mute);}

/* NOC panel */
.noc{position:relative;}
.noc-photo{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--bd);box-shadow:var(--card-shadow);aspect-ratio:4/4.6;}
.noc-photo img{width:100%;height:100%;object-fit:cover;}
.noc-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,13,41,.05),rgba(11,9,33,.42) 88%);}
.glass{position:absolute;background:rgba(17,14,44,.66);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 20px 50px rgba(0,0,0,.4);z-index:5;}
:root[data-theme="light"] .glass{background:rgba(255,255,255,.88);border-color:rgba(38,34,98,.12);box-shadow:0 20px 50px rgba(16,13,41,.18);}
.glass .gk{font-family:var(--fd);font-weight:600;font-size:15px;color:var(--heading);line-height:1.15;}
.glass .gl{font-family:var(--fm);font-size:9.5px;letter-spacing:.11em;text-transform:uppercase;color:var(--mute);margin-top:4px;}
.g-status{top:22px;left:-30px;padding:16px 19px;display:flex;align-items:center;gap:13px;}
.pulse{width:11px;height:11px;border-radius:50%;background:var(--green);position:relative;flex-shrink:0;}
.pulse::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid rgba(46,189,123,.45);animation:pulse 2s var(--ease) infinite;}
@keyframes pulse{0%{transform:scale(.65);opacity:.95;}100%{transform:scale(1.55);opacity:0;}}
.g-spark{bottom:96px;right:-34px;padding:16px 19px 13px;width:218px;}
.g-spark canvas{width:100%;height:44px;margin-top:9px;display:block;}
.g-threat{bottom:22px;left:-30px;padding:16px 19px;display:flex;align-items:center;gap:13px;}
.g-threat .shield{width:34px;height:34px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0;}
.g-threat .shield svg{width:18px;height:18px;}

/* ---------- ticker ---------- */
.ticker{border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--bg-2);overflow:hidden;padding:13px 0;position:relative;z-index:4;}
.ticker .track{display:flex;gap:0;width:max-content;animation:tick 36s linear infinite;}
.ticker:hover .track{animation-play-state:paused;}
@keyframes tick{to{transform:translateX(-50%);}}
.ticker .ti{display:inline-flex;align-items:center;gap:10px;font-family:var(--fm);font-size:12px;letter-spacing:.06em;color:var(--soft);padding:0 30px;white-space:nowrap;}
.ticker .ti .d{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;}
.ticker .ti b{color:var(--heading);font-weight:600;}
.ticker .ti .ok{color:var(--green);}

/* ---------- sections ---------- */
.sec{padding:130px 0;}
.sec-head{max-width:780px;margin-bottom:64px;}
.sec-head .eyebrow{margin-bottom:22px;}
.sec-head .lead{margin-top:20px;}
.sec.alt{background:var(--bg-2);}

/* ---------- statement ---------- */
.statement{padding:150px 0;text-align:center;}
.statement .st{font-family:var(--fd);font-weight:600;font-size:clamp(30px,4.6vw,62px);letter-spacing:-.03em;line-height:1.12;color:var(--mute);max-width:22ch;margin:0 auto;}
.statement .st .w{transition:color .5s var(--ease);}
.statement .st .w.on{color:var(--heading);}
.statement .st .hl.on{color:var(--accent);}

/* ---------- ecosystem ---------- */
.eco .wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.orbit{position:relative;aspect-ratio:1;max-width:560px;margin:0 auto;width:100%;}
.orbit svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;}
.orbit .ring-l{fill:none;stroke:var(--bd);stroke-width:1;}
.orbit .link{fill:none;stroke:var(--bd-2);stroke-width:1.2;stroke-dasharray:4 7;animation:dashmove 22s linear infinite;}
.orbit .link.hot{stroke:var(--accent);stroke-width:1.6;filter:drop-shadow(0 0 6px var(--glow-red));}
@keyframes dashmove{to{stroke-dashoffset:-440;}}
.core{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:128px;height:128px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--indigo-500),var(--indigo-800));border:1px solid var(--bd-2);box-shadow:0 0 70px var(--glow-indigo),inset 0 2px 14px rgba(255,255,255,.14);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;z-index:4;}
.core .q{font-family:var(--fd);font-weight:700;font-size:36px;color:#fff;line-height:1;}
.core .q i{font-style:normal;color:var(--red-bright);}
.core .cl{font-family:var(--fm);font-size:7.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.62);}
.node{position:absolute;width:96px;height:96px;margin:-48px 0 0 -48px;border-radius:50%;background:var(--panel);backdrop-filter:blur(8px);border:1px solid var(--bd);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:transform .25s var(--ease),border-color .25s,box-shadow .25s,background .25s;z-index:5;}
:root[data-theme="light"] .node{background:#fff;box-shadow:0 10px 26px rgba(16,13,41,.10);}
.node svg{width:26px;height:26px;color:var(--indigo-300);transition:color .25s;}
:root[data-theme="light"] .node svg{color:var(--indigo-600);}
.node .nl{font-family:var(--fm);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);text-align:center;line-height:1.3;padding:0 6px;}
.node:hover{transform:scale(1.09);border-color:var(--bd-2);}
.node.on{background:var(--accent-soft);border-color:var(--accent);box-shadow:0 0 36px var(--glow-red);transform:scale(1.12);}
.node.on svg{color:var(--accent);}
.node.on .nl{color:var(--heading);}
.eco-detail{position:relative;min-height:380px;}
.eco-pane{position:absolute;inset:0;opacity:0;transform:translateY(14px);transition:opacity .4s var(--ease),transform .4s var(--ease);pointer-events:none;}
.eco-pane.on{opacity:1;transform:none;pointer-events:auto;position:relative;}
.eco-pane .ico{width:54px;height:54px;border-radius:14px;background:var(--panel-2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:22px;}
.eco-pane .ico svg{width:27px;height:27px;}
.eco-pane h3{font-size:clamp(24px,2.4vw,32px);margin-bottom:14px;}
.eco-pane p{font-size:15.5px;color:var(--soft);line-height:1.66;margin-bottom:22px;max-width:48ch;}
.eco-pane .feats{display:flex;flex-direction:column;gap:11px;}
.eco-pane .feats span{display:flex;align-items:center;gap:11px;font-size:14px;color:var(--text);}
.eco-pane .feats span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0;}
.eco-tabs{display:none;gap:8px;flex-wrap:wrap;margin-bottom:26px;}
.eco-tabs button{font-family:var(--fm);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:9px 14px;border-radius:999px;background:var(--panel);border:1px solid var(--bd);color:var(--soft);cursor:pointer;transition:all .2s;}
.eco-tabs button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--heading);}

/* ---------- AI console ---------- */
.ai .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:70px;align-items:center;}
.term{background:var(--term-bg);border:1px solid var(--bd);border-radius:18px;overflow:hidden;box-shadow:var(--card-shadow);}
.term .bar{display:flex;align-items:center;gap:7px;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);}
.term .bar i{width:11px;height:11px;border-radius:50%;display:block;}
.term .bar .t{margin-left:12px;font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.48);letter-spacing:.1em;}
.term .bar .live{margin-left:auto;display:flex;align-items:center;gap:7px;font-family:var(--fm);font-size:9.5px;letter-spacing:.14em;color:var(--green);}
.term .bar .live i{width:7px;height:7px;background:var(--green);animation:blink 1.6s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.25;}}
.term .scr{padding:22px 22px 26px;font-family:var(--fm);font-size:13px;line-height:2.05;min-height:330px;color:rgba(255,255,255,.78);}
.term .ln{display:block;white-space:pre-wrap;}
.term .ts{color:rgba(255,255,255,.34);}
.term .sys{color:#9089DC;}
.term .warn{color:#F4BF4F;}
.term .ok{color:#3DBB7E;}
.term .crit{color:#FF5A6B;}
.term .cur{display:inline-block;width:8px;height:15px;background:var(--red-bright);vertical-align:-2px;animation:blink 1s infinite;}
.ai-points{display:flex;flex-direction:column;gap:2px;margin-top:10px;}
.ai-point{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid var(--bd);}
.ai-point:last-child{border-bottom:0;}
.ai-point .n{font-family:var(--fm);font-size:12px;color:var(--accent);letter-spacing:.1em;padding-top:4px;flex-shrink:0;}
.ai-point h4{font-size:19px;margin-bottom:7px;}
.ai-point p{font-size:14.5px;color:var(--soft);line-height:1.6;}

/* ---------- stats band ---------- */
.stats{border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--bg-2);}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);}
.stat{padding:54px 30px;text-align:center;border-left:1px solid var(--bd);}
.stat:first-child{border-left:0;}
.stat .k{font-family:var(--fd);font-weight:600;font-size:clamp(34px,3.4vw,52px);color:var(--heading);letter-spacing:-.03em;font-variant-numeric:tabular-nums;}
.stat .k em{font-style:normal;color:var(--accent);}
.stat .l{font-family:var(--fm);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-top:10px;}

/* ---------- MCP ---------- */
.mcp .wrap{display:grid;grid-template-columns:1.02fr .98fr;gap:70px;align-items:center;}
.feat-list{display:flex;flex-direction:column;gap:18px;margin-top:30px;list-style:none;}
.feat-list li{display:flex;gap:15px;}
.feat-list .ck{width:27px;height:27px;border-radius:9px;background:var(--panel-2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.feat-list .ck svg{width:14px;height:14px;stroke:var(--accent);}
.feat-list h5{font-family:var(--fd);font-weight:600;font-size:16px;color:var(--heading);margin-bottom:3px;}
.feat-list p{font-size:13.5px;color:var(--soft);}
.codecard{background:var(--term-bg);border:1px solid var(--bd);border-radius:16px;overflow:hidden;box-shadow:var(--card-shadow);}
.codecard .bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02);}
.codecard .bar i{width:11px;height:11px;border-radius:50%;display:block;}
.codecard .bar .t{margin-left:12px;font-family:var(--fm);font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.08em;}
.codecard pre{margin:0;padding:22px 22px 26px;font-family:var(--fm);font-size:13.5px;line-height:1.95;color:rgba(255,255,255,.8);overflow-x:auto;}
.codecard .pr{color:var(--indigo-300);}
.codecard .cmd{color:#fff;}
.codecard .url{color:#9089DC;}
.codecard .ok{color:#3DBB7E;}
.codecard .tl2{color:rgba(255,255,255,.64);}
.codecard .mut{color:rgba(255,255,255,.4);}

/* ---------- approach / steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;position:relative;}
.steps .prog{position:absolute;top:1px;left:0;right:0;height:3px;background:var(--bd);border-radius:2px;overflow:hidden;}
.steps .prog i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--red),var(--red-bright));transition:width 1.6s var(--ease-out);}
.step{padding-top:34px;}
.step .num{font-family:var(--fm);font-size:12px;letter-spacing:.16em;color:var(--accent);margin-bottom:15px;}
.step h4{font-size:19px;margin-bottom:10px;}
.step p{font-size:13.5px;color:var(--soft);line-height:1.6;}

/* ---------- values ---------- */
.val-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.val{background:var(--panel);border:1px solid var(--bd);border-radius:18px;padding:30px 28px;transition:transform .25s var(--ease),box-shadow .25s,border-color .25s,background .25s;}
.val:hover{transform:translateY(-6px);border-color:var(--bd-2);background:var(--panel-2);box-shadow:var(--card-shadow);}
.val .ic{width:46px;height:46px;border-radius:13px;background:var(--panel-2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.val h4{font-size:18px;margin-bottom:9px;}
.val p{font-size:13.5px;color:var(--soft);line-height:1.58;}

/* ---------- Brainport radar ---------- */
.region .wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;}
.radar{position:relative;aspect-ratio:1;max-width:520px;margin:0 auto;width:100%;border-radius:50%;}
.radar .rring{position:absolute;border-radius:50%;border:1px solid var(--bd);top:50%;left:50%;transform:translate(-50%,-50%);}
.radar .sweep{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,rgba(225,27,46,.0) 0deg,rgba(225,27,46,.16) 56deg,transparent 60deg);animation:sweep 6.5s linear infinite;}
@keyframes sweep{to{transform:rotate(360deg);}}
.radar .cdot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:15px;height:15px;border-radius:50%;background:var(--red-bright);box-shadow:0 0 26px var(--glow-red);z-index:3;}
.radar .cdot::after{content:"";position:absolute;inset:-9px;border-radius:50%;border:2px solid rgba(225,27,46,.4);animation:pulse 2.4s var(--ease) infinite;}
.radar .clabel{position:absolute;top:calc(50% + 16px);left:50%;transform:translateX(-50%);font-family:var(--fm);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--heading);background:var(--panel-2);border:1px solid var(--bd);padding:5px 11px;border-radius:999px;z-index:3;white-space:nowrap;}
.radar .pdot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--indigo-300);opacity:0;animation:pop 5s var(--ease) infinite;}
@keyframes pop{0%,12%{opacity:0;transform:scale(.4);}20%,72%{opacity:.95;transform:scale(1);}84%,100%{opacity:0;transform:scale(.4);}}

/* ---------- quote ---------- */
.quote{padding:150px 0;text-align:center;background:var(--bg-2);}
.quote blockquote{max-width:980px;margin:0 auto;font-family:var(--fd);font-weight:600;font-size:clamp(28px,3.8vw,50px);line-height:1.16;letter-spacing:-.025em;color:var(--heading);}
.quote blockquote .a{color:var(--accent);}
.quote .src{margin-top:32px;font-family:var(--fm);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);}

/* ---------- CTA ---------- */
.cta{overflow:hidden;padding:130px 0;background:var(--indigo-700);}
.cta::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(225,27,46,.32),transparent 42%),radial-gradient(circle at 12% 92%,rgba(92,84,192,.55),transparent 48%),linear-gradient(150deg,var(--indigo-800),var(--indigo-900));z-index:0;}
.cta .dotgrid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.10) 1.3px,transparent 1.3px);background-size:30px 30px;z-index:1;}
.cta .wrap{position:relative;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;}
.cta h2{color:#fff;font-size:clamp(32px,4.2vw,54px);}
.cta p{color:rgba(255,255,255,.78);margin-top:16px;font-size:17px;max-width:46ch;}
.cta .actions{display:flex;gap:14px;flex-wrap:wrap;}
.cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.34);}
.cta .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);}

/* ---------- contact ---------- */
.contact{padding:130px 0;}
.contact .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:70px;align-items:start;}
.contact-info .row{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--bd);}
.contact-info .row:first-of-type{border-top:1px solid var(--bd);}
.contact-info .ic{width:42px;height:42px;border-radius:12px;background:var(--panel-2);border:1px solid var(--bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--indigo-300);}
:root[data-theme="light"] .contact-info .ic{color:var(--indigo-600);}
.contact-info .ck{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-bottom:5px;}
.contact-info .cv{font-size:16px;color:var(--heading);font-weight:500;}
.contact-info .cv a:hover{color:var(--accent);}
form.qf{background:var(--panel);border:1px solid var(--bd);border-radius:20px;padding:36px;}
.qf .fld{margin-bottom:18px;}
.qf label{display:block;font-family:var(--fm);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-bottom:8px;}
.qf input,.qf textarea{width:100%;border:1.5px solid var(--bd);border-radius:11px;padding:14px 16px;font-family:var(--fs);font-size:15px;color:var(--heading);background:var(--bg);transition:border-color .16s,box-shadow .16s;}
.qf input::placeholder,.qf textarea::placeholder{color:var(--mute);}
.qf input:focus,.qf textarea:focus{outline:none;border-color:var(--indigo-400);box-shadow:0 0 0 3px var(--glow-indigo);}
.qf textarea{resize:vertical;min-height:108px;}
.qf .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.qf .btn{width:100%;justify-content:center;margin-top:6px;}

/* ---------- footer ---------- */
.foot{background:var(--bg-2);border-top:1px solid var(--bd);color:var(--soft);padding:70px 0 32px;}
:root[data-theme="light"] .foot{background:var(--indigo-950);border-top-color:transparent;color:rgba(255,255,255,.62);}
.foot .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:36px;padding-bottom:46px;border-bottom:1px solid var(--bd);}
:root[data-theme="light"] .foot .top{border-bottom-color:rgba(255,255,255,.1);}
.foot .brand img{height:28px;margin-bottom:18px;}
.foot .brand p{font-size:13.5px;line-height:1.6;max-width:34ch;}
.foot .brand .pos{font-family:var(--fm);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-top:18px;}
:root[data-theme="light"] .foot .brand .pos{color:rgba(255,255,255,.4);}
.foot .col h5{font-family:var(--fm);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin-bottom:16px;font-weight:500;}
:root[data-theme="light"] .foot .col h5{color:rgba(255,255,255,.45);}
.foot .col a{display:block;font-size:14px;color:var(--text);margin-bottom:11px;transition:color .15s;}
:root[data-theme="light"] .foot .col a{color:rgba(255,255,255,.72);}
.foot .col a:hover{color:var(--accent);}
:root[data-theme="light"] .foot .col a:hover{color:#fff;}
.foot .bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-family:var(--fm);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--mute);flex-wrap:wrap;gap:14px;}
:root[data-theme="light"] .foot .bottom{color:rgba(255,255,255,.42);}
.foot .bottom .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;margin-right:9px;vertical-align:middle;}

/* ---------- reveal ---------- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out);}
  .reveal.in{opacity:1;transform:none;}
}
@media (prefers-reduced-motion:reduce){
  .hero h1 .line span{animation:none;transform:none;}
  .ticker .track{animation:none;}
  .radar .sweep,.radar .pdot{animation:none;opacity:.7;}
  .orbit .link{animation:none;}
}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .hero h1{white-space:normal;}
  .hero .wrap{grid-template-columns:1fr;gap:56px;}
  .noc{max-width:430px;}
  .eco .wrap,.ai .wrap,.mcp .wrap,.region .wrap,.contact .grid{grid-template-columns:1fr;gap:48px;}
  .stats .wrap{grid-template-columns:1fr 1fr;}
  .stat{border-left:0;border-top:1px solid var(--bd);}
  .stat:nth-child(-n+2){border-top:0;}
  .steps,.val-grid{grid-template-columns:1fr 1fr;}
  .steps .prog{display:none;}
  .foot .top{grid-template-columns:1fr 1fr 1fr;gap:32px;}
}
@media(max-width:720px){
  .wrap{padding:0 22px;}
  .nav-in{padding:14px 22px;}
  .nav-links{display:none;}
  .nav-support .ns-label{display:none;}
  .nav-support{padding:10px;}
  .sec,.contact{padding:84px 0;}
  .statement,.quote{padding:100px 0;}
  .steps,.val-grid,.qf .row2,.stats .wrap{grid-template-columns:1fr;}
  .stat{border-top:1px solid var(--bd);}
  .stat:first-child{border-top:0;}
  .orbit{display:none;}
  .eco-tabs{display:flex;}
  .eco-detail{min-height:0;}
  .g-status{left:-8px;}
  .g-threat{left:-8px;}
  .g-spark{right:-8px;}
  .cta .wrap{flex-direction:column;align-items:flex-start;}
  .foot .top{grid-template-columns:1fr 1fr;}
}
