/* ============================================================
   NETEON UI KIT  ·  Sanity-language design system
   Tone: editorial + technical · dark-first · scarce brand
   Reused across all pages. Tokens → primitives → components.
   ============================================================ */

/* ---------- FONTS (self-hosted) ---------- */
@font-face{font-family:"Geist";src:url(fonts/geist-latin-wght-normal.woff2) format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url(fonts/ibm-plex-mono-latin-400-normal.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url(fonts/ibm-plex-mono-latin-500-normal.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url(fonts/ibm-plex-mono-latin-600-normal.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url(fonts/ibm-plex-mono-latin-700-normal.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---------- TOKENS ---------- */
:root{
  /* neutral ramp */
  --black:#0b0b0b; --white:#fff;
  --g100:#ededed; --g200:#d6d6d6; --g300:#b9b9b9; --g500:#797979; --g700:#4a4a4a; --g800:#353535; --g900:#212121; --g950:#161616;
  /* semantic surfaces */
  --canvas:#0b0b0b; --canvas-soft:#212121; --canvas-light:#fff; --canvas-paper:#ededed;
  --ink:#0b0b0b; --ink-soft:#212121;
  /* text */
  --fg:#fff; --fg-dim:#b9b9b9; --fg-mute:#797979; --fg-faint:#4a4a4a;
  --on-light:#0b0b0b; --on-light-dim:#4a4a4a; --on-light-mute:#797979;
  /* lines */
  --line:#353535; --line-2:#212121; --line-light:#e3e3e3; --line-light-2:#ededed;
  /* brand + accents (brand = live-accurate #ff560a) */
  --brand:#ff560a; --brand-press:#e64d07; --brand-soft:rgba(255,86,10,.1);
  --blue:#0084f8; --link:#0052ef; --link-dim:#55beff;
  --success:#37cd84; --green:#45ff00; --magenta:#ff23fc; --yellow:#fdfe00; --error:#dd0000; --code-str:#5ec9a8;
  --surface-blue:#afe3ff;
  /* fonts */
  --sans:"Geist","Inter Tight",system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  /* radius — intentional split: marketing(12) vs app(3-6) vs pill */
  --r-xs:3px; --r-sm:4px; --r-md:5px; --r-lg:6px; --r-marketing:12px; --r-pill:9999px;
  /* spacing */
  --s-xxs:4px; --s-xs:8px; --s-sm:12px; --s-md:16px; --s-lg:24px; --s-xl:32px; --s-2xl:48px; --s-sec:64px; --s-sec-lg:96px;
  /* layout */
  --container:1248px; --gutter:24px; --pad-x:24px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ---------- RESET / BASE ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{margin:0; background:var(--canvas); color:var(--fg); font-family:var(--sans); font-size:16px; line-height:1.5; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden}
body.lock{overflow:hidden}
a{color:inherit; text-decoration:none}
img,svg{display:block; max-width:100%}
h1,h2,h3,h4{margin:0; font-weight:400; letter-spacing:-.03em; line-height:1.05}
p{margin:0}
.container{max-width:var(--container); margin:0 auto; padding:0 var(--pad-x)}

/* ---------- TYPE SCALE (named, all weight 400) ---------- */
.t-display{font-size:clamp(2.85rem,7.3vw,7rem); letter-spacing:-.045em; line-height:.98}
.t-xl{font-size:clamp(2.2rem,5vw,4.5rem); letter-spacing:-.04em; line-height:1.04}
.t-md{font-size:clamp(1.9rem,3.7vw,3rem); letter-spacing:-.035em; line-height:1.07}
.t-sm{font-size:clamp(1.6rem,2.7vw,2.38rem); letter-spacing:-.028em; line-height:1.1}
.t-hmd{font-size:clamp(1.4rem,2vw,2rem); letter-spacing:-.02em; line-height:1.12}
.t-hsm{font-size:1.25rem; letter-spacing:-.015em; line-height:1.18}
.lead{font-size:clamp(1.05rem,1.45vw,1.28rem); line-height:1.55; color:var(--fg-dim)}
.t-body{font-size:1rem; line-height:1.5}
.t-bodysm{font-size:.94rem; line-height:1.5}
.dim{color:var(--fg-dim)} .mute{color:var(--fg-mute)} .brandc{color:var(--brand)}

/* mono labels */
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono); font-size:.8rem; font-weight:500; text-transform:uppercase; letter-spacing:.02em; color:var(--fg-dim)}
.mono-caps{font-family:var(--mono); font-size:.7rem; font-weight:400; text-transform:uppercase; letter-spacing:.05em; color:var(--fg-mute)}
.sec-index{font-family:var(--mono); font-size:.8rem; font-weight:500; text-transform:uppercase; letter-spacing:.04em; color:var(--fg-mute); display:flex; align-items:center; gap:.8em; margin-bottom:1.6rem}
.sec-index b{color:var(--fg); font-weight:500} .sec-index .ln{flex:1; height:1px; background:var(--line); max-width:80px}

/* ---------- SECTIONS / POLARITY ---------- */
.sec{padding:clamp(72px,11vh,128px) 0; position:relative}
.sec-dark{background:var(--canvas); color:var(--fg)}
.sec-light{background:var(--canvas-light); color:var(--on-light)}
.sec-paper{background:var(--canvas-paper); color:var(--on-light)}
.sec-light .sec-index, .sec-paper .sec-index{color:var(--on-light-mute)}
.sec-light .sec-index b, .sec-paper .sec-index b{color:var(--on-light)}
.sec-light .sec-index .ln, .sec-paper .sec-index .ln{background:var(--line-light)}
.sec-light .lead, .sec-paper .lead{color:var(--on-light-dim)}
.sec-head{max-width:680px} .sec-head h2{margin-top:.2rem} .sec-head p{margin-top:1.1rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center} .sec-head.center .sec-index{justify-content:center}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:.55em; font-family:var(--mono); font-weight:500; font-size:.82rem; text-transform:uppercase; letter-spacing:.02em;
  padding:.72em 1.25em; border-radius:var(--r-pill); border:1px solid transparent; cursor:pointer; white-space:nowrap;
  transition:background .15s var(--ease), color .15s var(--ease), border-color .15s var(--ease)}
.btn svg{transition:transform .15s var(--ease)} .btn:hover svg.arrow{transform:translateX(3px)}
.btn-brand{background:var(--brand); color:var(--ink); border-color:var(--brand)}
.btn-brand:hover{background:var(--brand-press); border-color:var(--brand-press)}
.btn-white{background:var(--white); color:var(--ink); border-color:var(--white)}
.btn-white:hover{background:var(--g200); border-color:var(--g200)}
.btn-ink{background:var(--ink); color:var(--white); border-color:var(--ink)}     /* primary on light */
.btn-ink:hover{background:#000}
.btn-outline{background:transparent; color:var(--fg); border-color:rgba(255,255,255,.45)}
.btn-outline:hover{border-color:var(--fg); background:rgba(255,255,255,.05)}
.btn-outline-ink{background:transparent; color:var(--on-light); border-color:var(--line-light)}
.btn-outline-ink:hover{border-color:var(--on-light); background:rgba(0,0,0,.03)}
.btn-ghost{background:transparent; color:var(--fg-dim); border-color:transparent; padding-left:.4em; padding-right:.4em}
.btn-ghost:hover{color:var(--fg)}
.btn-lg{padding:.92em 1.6em; font-size:.86rem}
.playbtn{display:inline-flex; align-items:center; gap:.6em; font-family:var(--mono); text-transform:uppercase; font-size:.82rem; letter-spacing:.02em; color:var(--fg-dim)}
.playbtn .pp{width:30px;height:30px;border-radius:50%;border:1px solid var(--g700);display:grid;place-items:center; transition:border-color .15s,background .15s}
.playbtn:hover{color:var(--fg)} .playbtn:hover .pp{border-color:var(--fg)}
.arrow-link{display:inline-flex; align-items:center; gap:.5em; font-family:var(--mono); text-transform:uppercase; font-size:.82rem; letter-spacing:.02em; color:var(--brand)}
.arrow-link svg{transition:transform .15s} .arrow-link:hover svg{transform:translateX(4px)}
.sec-light .arrow-link, .sec-paper .arrow-link{color:var(--ink)}

/* ---------- CHIPS / BADGES / STATUS ---------- */
.chip{display:inline-flex; align-items:center; gap:.5em; font-family:var(--mono); font-size:.72rem; font-weight:500; text-transform:uppercase; letter-spacing:.03em;
  color:var(--fg-dim); border:1px solid var(--line); border-radius:var(--r-pill); padding:.42em .8em}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--success); box-shadow:0 0 0 3px rgba(55,205,132,.16)}
.badge{display:inline-flex; align-items:center; font-family:var(--mono); font-size:.68rem; font-weight:500; text-transform:uppercase; letter-spacing:.04em;
  color:var(--ink); background:var(--white); border-radius:var(--r-pill); padding:.34em .7em}
.badge-ink{background:var(--ink); color:var(--white)}
.status{font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.03em; display:inline-flex; align-items:center; gap:.5em}
.status .k{color:var(--fg-mute)} .status .v{background:var(--white); color:var(--ink); padding:.12em .55em; border-radius:var(--r-xs); font-weight:500}
.status .v.ok{background:var(--success); color:var(--ink)} .status .v.brand{background:var(--brand); color:var(--ink)}

/* ---------- CODE PILL + CODE EDITOR ---------- */
.codepill{display:inline-flex; align-items:center; gap:.75em; font-family:var(--mono); font-size:.8rem; color:var(--fg-dim);
  background:var(--g950); border:1px solid var(--line); border-radius:var(--r-sm); padding:.62em .9em; cursor:pointer; transition:border-color .15s}
.codepill:hover{border-color:var(--g700)} .codepill .pr{color:var(--brand)} .codepill svg{opacity:.55}
/* code window (app-grade radius) */
.codewin{border:1px solid var(--line); border-radius:var(--r-lg); background:var(--g950); overflow:hidden}
.codewin-bar{display:flex; align-items:center; gap:.7em; padding:.65rem .9rem; border-bottom:1px solid var(--line-2)}
.codewin-bar .dots{display:flex; gap:6px} .codewin-bar .dots i{width:9px;height:9px;border-radius:50%;background:var(--g700)}
.codewin-bar .ttl{font-family:var(--mono); font-size:.68rem; text-transform:uppercase; letter-spacing:.04em; color:var(--fg-mute); margin-left:.3em}
.codewin-tabs{display:flex; gap:2px; padding:.5rem .7rem 0; border-bottom:1px solid var(--line-2)}
.codewin-tab{font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.03em; color:var(--fg-mute); padding:.5em .85em; border-radius:var(--r-sm) var(--r-sm) 0 0; cursor:pointer; appearance:none; -webkit-appearance:none; background:transparent; border:0; transition:color .15s,background .15s}
.codewin-tab[aria-selected="true"]{color:var(--fg); background:var(--g900); border:1px solid var(--line-2)}
.codewin-tab:hover{color:var(--fg-dim)}
.code{font-family:var(--mono); font-size:.78rem; line-height:1.95; color:var(--fg-dim); padding:1rem 1.1rem; margin:0; white-space:pre; overflow-x:auto; max-width:100%}
.code .c{color:var(--fg-mute)} .code .k{color:var(--fg)} .code .s{color:var(--code-str)} .code .n{color:var(--link-dim)}
.code .ln{color:var(--g700); user-select:none}
.cli-out{font-family:var(--mono); font-size:.76rem; color:var(--fg-dim); padding:.7rem 1.1rem; border-top:1px solid var(--line-2); display:flex; align-items:center; gap:.6em}
.cli-out .ok{color:var(--success)}

/* ---------- TEXTURES + CROP MARKS ---------- */
.dots{background-image:radial-gradient(var(--g700) 1px, transparent 1.4px); background-size:22px 22px}
.dots-soft{background-image:radial-gradient(rgba(255,255,255,.05) 1px, transparent 1.4px); background-size:22px 22px}
.dots-lite{background-image:radial-gradient(var(--g200) 1px, transparent 1.4px); background-size:22px 22px}
.crop{position:absolute; inset:0; pointer-events:none}
.crop i{position:absolute; width:12px; height:12px; border:1px solid var(--g700)}
.crop i:nth-child(1){top:-1px;left:-1px;border-right:0;border-bottom:0}
.crop i:nth-child(2){top:-1px;right:-1px;border-left:0;border-bottom:0}
.crop i:nth-child(3){bottom:-1px;left:-1px;border-right:0;border-top:0}
.crop i:nth-child(4){bottom:-1px;right:-1px;border-left:0;border-top:0}
.crop.lite i{border-color:var(--line-light)} .crop.ink i{border-color:var(--ink)}

/* ---------- CARDS (marketing radius 12px) ---------- */
.card-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-md)}
.card{background:var(--canvas-light); border:1px solid var(--line-light); border-radius:var(--r-marketing); overflow:hidden; display:flex; flex-direction:column; transition:border-color .15s var(--ease), background .15s}
.sec-light .card:hover{background:#fafafa; border-color:var(--g200)}
.card-img{position:relative; aspect-ratio:16/10; overflow:hidden; background:var(--g100); border-bottom:1px solid var(--line-light)}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-tag{position:absolute; top:11px; left:11px; z-index:2; font-family:var(--mono); font-size:.64rem; font-weight:500; text-transform:uppercase; letter-spacing:.04em; color:var(--ink); background:#fff; border:1px solid var(--line-light); border-radius:var(--r-pill); padding:.34em .7em}
.card-body{padding:var(--s-lg); display:flex; flex-direction:column; flex:1}
.card-body h3{font-size:1.28rem; letter-spacing:-.03em; line-height:1.15}
.card-body p{margin-top:.55rem; color:var(--on-light-dim); font-size:.94rem; line-height:1.5; flex:1}
.card-body .more{margin-top:1.2rem; display:inline-flex; align-items:center; gap:.45em; font-family:var(--mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.02em; color:var(--ink)}
.card-body .more svg{transition:transform .15s} .card:hover .more svg{transform:translateX(4px)}
/* dark feature card (canvas-soft) */
.card-dark{background:var(--canvas-soft); color:var(--fg); border:1px solid var(--line); border-radius:var(--r-marketing); padding:var(--s-xl); display:flex; flex-direction:column; gap:.7rem; transition:border-color .15s}
.card-dark:hover{border-color:var(--g700)}
.card-dark .ico{width:38px;height:38px;border:1px solid var(--line);border-radius:var(--r-lg);display:grid;place-items:center;color:var(--brand);margin-bottom:.4rem}
.card-dark h3{font-size:1.15rem; letter-spacing:-.02em} .card-dark p{color:var(--fg-dim); font-size:.92rem; line-height:1.5}
/* brand card */
.card-brand{background:var(--brand); color:var(--ink); border-radius:var(--r-marketing); padding:var(--s-xl)}

/* ---------- STUDIO / APP WINDOW MOCKUP ---------- */
.window{border:1px solid var(--line); border-radius:var(--r-lg); background:var(--g950); overflow:hidden}
.window-bar{display:flex; align-items:center; gap:.7em; padding:.7rem .9rem; border-bottom:1px solid var(--line-2)}
.window-bar .dots{display:flex; gap:6px} .window-bar .dots i{width:9px;height:9px;border-radius:50%;background:var(--g700)}
.window-bar .ttl{font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.04em; color:var(--fg-mute); display:flex; align-items:center; gap:.5em}
.window-bar .spacer{flex:1}
.window-tabs{display:flex; gap:.3em; padding:.6rem .9rem; border-bottom:1px solid var(--line-2)}
.window-tab{font-family:var(--mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.03em; color:var(--fg-mute); padding:.4em .7em; border-radius:var(--r-sm); cursor:pointer; appearance:none; -webkit-appearance:none; background:transparent; border:0}
.window-tab[aria-selected="true"]{color:var(--fg); background:var(--g900); border:1px solid var(--line-2)}
.window-body{padding:.4rem 0}
.wrow{display:flex; align-items:center; gap:.8em; padding:.7rem .9rem; border-bottom:1px solid var(--line-2); font-family:var(--mono); font-size:.76rem; color:var(--fg-dim)}
.wrow:last-child{border-bottom:0}
.wrow .d{width:7px;height:7px;border-radius:50%;background:var(--success);flex:none} .wrow .d.warn{background:var(--yellow)} .wrow .d.idle{background:var(--g700)}
.wrow .nm{color:var(--fg)} .wrow .meta{margin-left:auto; color:var(--fg-mute); font-size:.7rem}

/* ---------- FEATURE ROWS (title | desc + hairline) ---------- */
.frows{display:flex; flex-direction:column; max-width:min(100%,72rem)}
.frow{display:grid; grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr); gap:clamp(1rem,3vw,2rem); padding:1.7rem 0; border-top:1px solid var(--line)}
.frow:last-child{border-bottom:1px solid var(--line)}
.frow h3{font-size:clamp(1.3rem,2vw,1.75rem); letter-spacing:-.02em; line-height:1.12}
.frow p{color:var(--fg-dim); font-size:.94rem; line-height:1.55; align-self:start}
.sec-light .frow{border-color:var(--line-light)} .sec-light .frow p{color:var(--on-light-dim)}

/* ---------- STAT BAND ---------- */
.statband{display:grid; grid-template-columns:repeat(5,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden}
.statc{background:var(--canvas); padding:2rem 1.3rem}
.statc .n{font-size:clamp(2.6rem,4.5vw,4rem); font-weight:400; letter-spacing:-.04em; line-height:1}
.statc .n .u{color:var(--brand)}
.statc .l{margin-top:.7rem; font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.03em; color:var(--fg-dim)}

/* ---------- TIER / PRICING CARDS ---------- */
.tiers{display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-md)}
.tier{background:var(--canvas-light); color:var(--on-light); border:1px solid var(--line-light); border-radius:var(--r-marketing); padding:var(--s-xl); display:flex; flex-direction:column; gap:.5rem}
.tier-featured{background:var(--ink); color:var(--white)}     /* polarity inversion = the badge */
.tier .name{font-family:var(--mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; color:var(--on-light)}
.tier-featured .name{color:var(--g300)}
.tier .desc{font-size:.9rem; color:var(--on-light-dim); min-height:2.4em}
.tier-featured .desc{color:var(--g300)}
.tier .amount{font-size:clamp(1.9rem,3vw,2.6rem); font-weight:400; letter-spacing:-.03em; margin:.4rem 0 .2rem}
.tier .amount small{font-family:var(--mono); font-size:.8rem; color:var(--on-light-mute); letter-spacing:0}
.tier-featured .amount small{color:var(--g500)}
.tier .feats{list-style:none; margin:1.1rem 0 0; padding:0; display:flex; flex-direction:column; gap:.6rem; font-size:.9rem; color:var(--on-light-dim)}
.tier-featured .feats{color:var(--g200)}
.tier .feats li{display:flex; align-items:flex-start; gap:.55em} .tier .feats .ck{color:var(--success); flex:none; margin-top:.15em}
.tier .btn{margin-top:1.3rem; width:100%}

/* ---------- COMPARISON TABLE ---------- */
.ctable{width:100%; border-collapse:collapse; font-size:.92rem}
.ctable th,.ctable td{text-align:left; padding:1rem 1.1rem; border-bottom:1px solid var(--line)}
.ctable thead th{font-family:var(--mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; color:var(--fg-mute); font-weight:400}
.ctable tbody th{font-weight:400; color:var(--fg)} .ctable td{color:var(--fg-dim); text-align:center}
.ctable td.feat{text-align:left; color:var(--fg)}
.ctable .yes{color:var(--success)} .ctable .no{color:var(--g700)}
.sec-light .ctable .no{color:var(--on-light-mute)}
.ctable col.hl, .ctable th.hl, .ctable td.hl{background:rgba(255,86,10,.06)}
.sec-light .ctable th,.sec-light .ctable td{border-color:var(--line-light)} .sec-light .ctable tbody th{color:var(--on-light)} .sec-light .ctable td{color:var(--on-light-dim)}

/* ---------- TESTIMONIAL QUOTE ---------- */
.quote{display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); align-items:center}
.quote blockquote{margin:0; font-size:clamp(1.5rem,2.7vw,2.3rem); font-weight:400; letter-spacing:-.025em; line-height:1.22}
.quote .qlabel{font-family:var(--mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; color:var(--fg-mute); margin-bottom:1.2rem; display:block}
.quote .attr{margin-top:1.6rem; display:flex; align-items:center; gap:.8rem}
.quote .attr .av{width:42px;height:42px;border-radius:50%;background:var(--g200);border:1px solid var(--line-light);overflow:hidden;flex:none}
.quote .attr .nm{font-family:var(--mono); font-size:.78rem; text-transform:uppercase; letter-spacing:.02em; color:var(--fg)}
.quote .attr .role{font-family:var(--mono); font-size:.74rem; color:var(--fg-mute)}
.qnav{display:flex; gap:.6rem; margin-top:2rem}
.qnav button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--fg-dim);display:grid;place-items:center;cursor:pointer;transition:border-color .15s,color .15s}
.qnav button:hover{border-color:var(--fg);color:var(--fg)}

/* ---------- NODE GRAPH ---------- */
.mesh{width:100%; height:auto}
.ge{stroke:rgba(255,255,255,.28); stroke-width:1; fill:none}
.gn{fill:#fff} .gn.b{fill:var(--brand)}
.gl{font-family:var(--mono); font-size:9px; letter-spacing:.05em; fill:var(--fg-mute)} .gl.b{fill:var(--brand)}

/* ---------- LOGO ROW ---------- */
.logos{display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:2.4rem}
.logos span{font-family:var(--mono); font-size:1.05rem; font-weight:500; text-transform:uppercase; letter-spacing:.02em; color:var(--fg-mute); transition:color .15s}
.logos span:hover{color:var(--fg)}
.marquee{position:relative; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent); mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee-track{display:flex; gap:3.2rem; width:max-content; animation:scroll-x 34s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--mono); font-size:1.05rem; font-weight:500; letter-spacing:.02em; text-transform:uppercase; color:var(--fg-mute); transition:color .15s; white-space:nowrap}
.marquee-track span:hover{color:var(--fg)}
@keyframes scroll-x{to{transform:translateX(calc(-50% - 1.6rem))}}

/* ---------- BRAND / NAV ---------- */
.brand{display:inline-flex; align-items:center; color:var(--fg)}
.brand .mark{display:block; width:130px; height:19px; background:currentColor; -webkit-mask:url(neteon-logo.svg) no-repeat left center/contain; mask:url(neteon-logo.svg) no-repeat left center/contain}
.sec-light .brand, .nav.light .brand{color:var(--on-light)}

/* ---------- NAV MEGA-MENU (Sanity-style) ---------- */
.nav-item{position:static; display:inline-flex}
.nav-trigger{display:inline-flex; align-items:center; gap:.35em; font-family:var(--mono); font-size:.76rem; font-weight:500; text-transform:uppercase; letter-spacing:.02em; color:var(--fg-dim); padding:.45em .7em; border-radius:var(--r-pill); background:transparent; border:0; cursor:pointer; appearance:none; -webkit-appearance:none; transition:color .15s}
.nav-trigger .chev{transition:transform .2s var(--ease)}
.nav-item:hover .nav-trigger, .nav-item:focus-within .nav-trigger{color:var(--fg)}
.nav-item:hover .nav-trigger .chev, .nav-item:focus-within .nav-trigger .chev{transform:rotate(180deg)}
.nav.light .nav-trigger{color:var(--on-light-dim)} .nav.light .nav-item:hover .nav-trigger{color:var(--on-light)}
.mega{position:absolute; left:0; right:0; top:100%; background:var(--canvas); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity .2s var(--ease), transform .2s var(--ease), visibility .2s; z-index:60}
.nav-item:hover .mega, .nav-item:focus-within .mega{opacity:1; visibility:visible; transform:none}
.mega-inner{display:grid; grid-template-columns:1.45fr .85fr; gap:clamp(2rem,4vw,4rem); padding:2.2rem var(--pad-x) 2.4rem; max-width:var(--container); margin:0 auto}
.mm-cols{display:grid; grid-template-columns:1fr 1fr; gap:2.4rem}
.mm-h{font-family:var(--mono); font-size:.66rem; text-transform:uppercase; letter-spacing:.06em; color:var(--fg-mute); margin-bottom:.8rem; padding-bottom:.6rem; border-bottom:1px solid var(--line-2)}
.mm-link{display:block; padding:.5rem 0; color:var(--fg); font-size:1rem; letter-spacing:-.01em; transition:color .15s}
.mm-link span{display:block; font-family:var(--sans); font-size:.8rem; color:var(--fg-mute); margin-top:.05rem; text-transform:none; letter-spacing:0; line-height:1.35}
.mm-link:hover{color:var(--brand)} .mm-link:hover span{color:var(--fg-dim)}
.mm-feature{position:relative; border:1px solid var(--line); border-radius:var(--r-marketing); overflow:hidden; display:flex; flex-direction:column; background:var(--g950); transition:border-color .15s}
.mm-feature:hover{border-color:var(--g700)}
.mm-feature .mm-vis{position:relative; height:118px; background-color:var(--g950); overflow:hidden; display:grid; place-items:center; border-bottom:1px solid var(--line-2)}
.mm-feature .mm-vis.soft{background-image:radial-gradient(rgba(255,255,255,.06) 1px,transparent 1.4px); background-size:20px 20px}
.mm-feature .mm-vis.brand{background:var(--brand)}
.mm-feature .mm-body{padding:1.2rem 1.3rem 1.3rem}
.mm-feature .mm-body .badge{font-size:.62rem}
.mm-feature .mm-body h4{font-size:1.08rem; letter-spacing:-.02em; margin:.55rem 0 .3rem}
.mm-feature .mm-body p{font-size:.85rem; color:var(--fg-dim); line-height:1.45}
.mm-feature .mm-body .arrow-link{margin-top:.9rem; font-size:.76rem; color:var(--fg)}
.mm-feature:hover .mm-body .arrow-link{color:var(--brand)}
@media(max-width:980px){.mega{display:none}}

/* ---------- REVEAL ---------- */
.js [data-rev]{opacity:0; transform:translateY(12px); transition:opacity 1s var(--ease), transform 1s var(--ease)}
.js [data-rev].in{opacity:1; transform:none}
.js [data-rev][data-d="1"]{transition-delay:.09s} .js [data-rev][data-d="2"]{transition-delay:.18s}
.js [data-rev][data-d="3"]{transition-delay:.27s} .js [data-rev][data-d="4"]{transition-delay:.36s}

/* ---------- RESPONSIVE PRIMITIVES ---------- */
@media(max-width:1040px){
  .card-grid,.tiers{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(3,1fr)}
  .quote{grid-template-columns:1fr}
}
@media(max-width:680px){
  .card-grid,.tiers,.statband{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr; gap:.6rem}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js [data-rev]{opacity:1; transform:none; transition:none}
  .marquee-track{animation:none}
}
