/* ============================================================
   VPSBILL — Landing hi-tech graphic system (light)
   Builds on premium.css tokens. Brand green + subtle cyan tech accent.
   ============================================================ */
.pm{
  /* secondary accent kept in the emerald family (no cyan/teal) */
  --cyan: oklch(0.63 0.135 165);
  --cyan-700: oklch(0.47 0.115 164);
  --grid-line: oklch(0.23 0.02 255 / 0.06);
  --glow-green: oklch(0.70 0.16 159 / 0.55);
  --ink-grad: linear-gradient(120deg, oklch(0.49 0.13 162), oklch(0.66 0.16 158));
  /* emerald-only hero gradient on the landing (overrides the lime-tinted global one) */
  --hero-grad: linear-gradient(135deg, oklch(0.45 0.12 162) 0%, oklch(0.61 0.155 159) 55%, oklch(0.73 0.15 156) 130%);
}

body.pm{overflow-y:auto;}
.pm .mono{font-family:'IBM Plex Mono',monospace;}

/* ---------------- shared layout ---------------- */
.wrap{max-width:1180px;margin:0 auto;padding:0 32px;}
.sec{padding:74px 0;position:relative;}
.sec-h{margin-bottom:40px;}
.sec-h.center{text-align:center;}
.sec-h .k{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--green-700);font-family:'IBM Plex Mono',monospace;padding:5px 12px;border-radius:999px;background:color-mix(in srgb,var(--green) 11%,transparent);border:1px solid color-mix(in srgb,var(--green) 22%,transparent);}
.sec-h .k::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 25%,transparent);animation:pip 1.8s ease-in-out infinite;}
.sec-h h2{font-size:clamp(28px,3.4vw,40px);font-weight:800;letter-spacing:-0.035em;margin-top:14px;line-height:1.06;}
.sec-h h2 .g{background:var(--ink-grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.sec-h p{color:var(--ink-2);margin-top:12px;max-width:58ch;font-size:15.5px;line-height:1.6;}
.sec-h.center p{margin-left:auto;margin-right:auto;}
@keyframes pip{0%,100%{opacity:1}50%{opacity:.3}}

/* faint global blueprint grid behind everything */
.bp-grid{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 8%,#000 92%,transparent);}
.sec > .wrap{position:relative;z-index:1;}

/* ---------------- NAV ---------------- */
.nav{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:18px;padding:13px 32px;background:color-mix(in oklch,var(--app) 78%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav .lk{display:flex;gap:2px;margin:0 auto;}
.nav .lk a{padding:8px 15px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--ink-2);cursor:pointer;text-decoration:none;transition:.15s;}
.nav .lk a:hover{color:var(--ink);background:var(--canvas);}
.nav-cta{display:flex;gap:9px;align-items:center;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:64px 0 40px;overflow:hidden;}
.hero-inner{display:grid;grid-template-columns:1.04fr 0.96fr;gap:40px;align-items:center;position:relative;z-index:2;}
.hero-copy{max-width:560px;}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--green-700);background:color-mix(in srgb,var(--green) 12%,transparent);border:1px solid color-mix(in srgb,var(--green) 22%,transparent);padding:6px 13px;border-radius:999px;margin-bottom:22px;font-family:'IBM Plex Mono',monospace;}
.eyebrow svg{width:14px;height:14px;}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--glow-green);animation:pip 1.6s infinite;}
.hero h1{font-size:clamp(40px,5.2vw,64px);font-weight:800;letter-spacing:-0.045em;line-height:1.02;}
.hero h1 .g{background:var(--ink-grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-sub{font-size:17.5px;color:var(--ink-2);line-height:1.6;margin-top:20px;max-width:50ch;}
.hcta{display:flex;gap:11px;margin-top:28px;flex-wrap:wrap;}
.hcta .pm-btn{flex:none;padding:13px 22px;text-decoration:none;}
.hero-meta{display:flex;gap:8px 22px;flex-wrap:wrap;margin-top:24px;font-size:12.5px;color:var(--ink-3);font-family:'IBM Plex Mono',monospace;}
.hero-meta span{display:inline-flex;align-items:center;gap:7px;}
.hero-meta span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--green);}

/* hero background fx */
.hero-fx{position:absolute;inset:-60px 0 auto;height:560px;z-index:0;pointer-events:none;}
.hero-fx .blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.4;animation:floaty 10s ease-in-out infinite;}
.hero-fx .b1{width:340px;height:340px;background:var(--glow-green);top:-40px;right:6%;}
.hero-fx .b2{width:260px;height:260px;background:color-mix(in srgb,var(--cyan) 50%,transparent);top:120px;right:28%;animation-delay:-4s;}
.hero-fx .grid{position:absolute;inset:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 70% 20%,#000,transparent 72%);mask-image:radial-gradient(ellipse 80% 70% at 70% 20%,#000,transparent 72%);}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-26px)}}

/* hero stage holds the 3 graphic variants */
.hero-stage{position:relative;height:440px;}
.hvar{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transform:scale(.96) translateY(14px);pointer-events:none;transition:opacity .5s ease,transform .5s ease;}
.hvar.on{opacity:1;transform:none;pointer-events:auto;}

/* ---- hero variant switcher ---- */
.hero-switch{margin-top:30px;z-index:5;display:inline-flex;gap:3px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:4px;box-shadow:var(--shadow-card);}
.hero-switch button{font:inherit;font-size:12px;font-weight:700;color:var(--ink-2);background:transparent;border:0;border-radius:999px;padding:7px 14px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:.15s;}
.hero-switch button svg{width:14px;height:14px;}
.hero-switch button.on{background:var(--ink);color:var(--app);}
.hero-switch .lab{font-size:10.5px;color:var(--ink-3);font-family:'IBM Plex Mono',monospace;padding:0 8px 0 4px;align-self:center;letter-spacing:.04em;}

/* ===== Variant A: Terminal / CLI ===== */
.term{width:100%;max-width:480px;background:oklch(0.20 0.012 255);border:1px solid oklch(1 0 0/0.08);border-radius:11px;box-shadow:0 30px 70px -30px oklch(0.3 0.06 255/0.5),0 0 0 1px oklch(0.3 0.04 255/0.04);overflow:hidden;font-family:'IBM Plex Mono',monospace;}
.term-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:oklch(0.25 0.012 255);border-bottom:1px solid oklch(1 0 0/0.06);}
.term-bar .tl{display:flex;gap:6px;}
.term-bar .tl i{width:11px;height:11px;border-radius:50%;}
.term-bar .tl i:nth-child(1){background:#ff5f57;} .term-bar .tl i:nth-child(2){background:#febc2e;} .term-bar .tl i:nth-child(3){background:#28c840;}
.term-bar .tt{display:block;width:auto;height:auto;border-radius:0;padding:0;cursor:text;background:transparent;font-size:11px;color:oklch(0.7 0.01 255);margin-left:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.term-bar .tt b{color:oklch(0.85 0.02 255);}
.term-body{padding:16px 16px 18px;font-size:12.5px;line-height:1.85;color:oklch(0.82 0.01 255);min-height:268px;}
.term-body .ln{white-space:pre-wrap;}
.term-body .pr{color:var(--green);} 
.term-body .cm{color:oklch(0.78 0.10 207);}
.term-body .ok{color:var(--green);} .term-body .dim{color:oklch(0.55 0.01 255);} .term-body .wht{color:oklch(0.96 0.01 255);}
.term-body .bar{display:inline-block;height:7px;border-radius:4px;background:var(--green);box-shadow:0 0 10px var(--glow-green);vertical-align:middle;}
.term-cursor{display:inline-block;width:8px;height:15px;background:var(--green);vertical-align:-2px;animation:blink 1s steps(1) infinite;box-shadow:0 0 8px var(--glow-green);}
@keyframes blink{0%,50%{opacity:1}50.01%,100%{opacity:0}}

/* ===== Variant B: Isometric server rack ===== */
.iso-wrap{width:100%;display:grid;place-items:center;}
.iso{animation:isofloat 6s ease-in-out infinite;position:relative;}
@keyframes isofloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.rack{width:248px;background:linear-gradient(160deg,oklch(0.99 0.002 255),oklch(0.945 0.004 255));border:1px solid var(--line);border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 40px 64px -28px oklch(0.3 0.08 160/0.45),0 2px 0 oklch(1 0 0/0.7) inset;position:relative;}
.rack-top{display:flex;align-items:center;justify-content:space-between;padding:3px 4px 7px;border-bottom:1px dashed var(--line);margin-bottom:2px;}
.rack-top .nm{font-family:'IBM Plex Mono',monospace;font-size:10.5px;font-weight:700;color:var(--ink-2);letter-spacing:.04em;}
.rack-top .sd{display:flex;gap:4px;}
.rack-top .sd i{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--glow-green);}
.ru{height:30px;border-radius:8px;background:var(--card);border:1px solid var(--line);display:flex;align-items:center;gap:8px;padding:0 11px;position:relative;box-shadow:0 1px 2px oklch(0.3 0.02 255/0.05);}
.ru .vent{flex:1;height:11px;border-radius:3px;background:repeating-linear-gradient(90deg,var(--canvas) 0 3px,transparent 3px 6px);}
.ru .led{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--glow-green);}
.ru .led.a{animation:led 1.4s infinite;} .ru .led.b{background:var(--cyan);box-shadow:0 0 8px color-mix(in srgb,var(--cyan) 70%,transparent);animation:led 2s .3s infinite;} .ru .led.c{background:var(--warn);box-shadow:0 0 8px color-mix(in srgb,var(--warn) 60%,transparent);animation:led 1.1s .6s infinite;}
@keyframes led{0%,100%{opacity:1}50%{opacity:.25}}
.iso-glow{position:absolute;width:300px;height:110px;background:var(--glow-green);filter:blur(54px);opacity:.5;left:50%;top:64%;transform:translate(-50%,0);z-index:-1;pointer-events:none;}
.iso-badge{position:absolute;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:700;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:6px 10px;box-shadow:var(--shadow-card);display:flex;align-items:center;gap:6px;}
.iso-badge .d{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--glow-green);}

/* ===== Variant C: Neon network globe ===== */
.netviz{position:relative;width:100%;max-width:440px;aspect-ratio:1;display:grid;place-items:center;}
.netviz .core{position:absolute;width:78px;height:78px;border-radius:50%;background:radial-gradient(circle at 40% 35%,oklch(0.78 0.16 159),var(--green-700));box-shadow:0 0 40px var(--glow-green),inset 0 0 18px oklch(1 0 0/0.3);display:grid;place-items:center;color:#fff;z-index:3;}
.netviz .core svg{width:30px;height:30px;}
.netviz .ringo{position:absolute;border:1.4px dashed color-mix(in srgb,var(--green) 38%,transparent);border-radius:50%;}
.netviz .ringo.r1{width:62%;height:62%;animation:spin 26s linear infinite;}
.netviz .ringo.r2{width:84%;height:84%;border-color:color-mix(in srgb,var(--cyan) 34%,transparent);animation:spin 40s linear reverse infinite;}
.netviz .ringo.r3{width:100%;height:100%;border-style:solid;border-color:var(--grid-line);}
@keyframes spin{to{transform:rotate(360deg)}}
.netviz .node{position:absolute;z-index:4;display:flex;flex-direction:column;align-items:center;gap:5px;}
.netviz .node .pin{width:15px;height:15px;border-radius:50%;background:var(--card);border:2px solid var(--green);box-shadow:0 0 0 5px color-mix(in srgb,var(--green) 16%,transparent);position:relative;}
.netviz .node .pin::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid var(--green);animation:ping 2.4s ease-out infinite;}
.netviz .node .tag{font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:700;background:var(--card);border:1px solid var(--line);border-radius:7px;padding:3px 7px;box-shadow:var(--shadow-soft);white-space:nowrap;}
.netviz .node .tag b{color:var(--green-700);}
@keyframes ping{0%{transform:scale(1);opacity:.8}100%{transform:scale(2.6);opacity:0}}
.netviz svg.arcs{position:absolute;inset:0;width:100%;height:100%;overflow:visible;z-index:2;}
.netviz svg.arcs path{fill:none;stroke:color-mix(in srgb,var(--green) 55%,transparent);stroke-width:1.4;stroke-dasharray:5 7;animation:dash 1.4s linear infinite;}
.netviz svg.arcs path.c{stroke:color-mix(in srgb,var(--cyan) 55%,transparent);}
@keyframes dash{to{stroke-dashoffset:-24}}

/* ============================================================
   LOGO STRIP
   ============================================================ */
.strip{padding:22px 0;}
.strip .lab{text-align:center;font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;}
.logos{display:flex;flex-wrap:wrap;gap:14px 46px;justify-content:center;align-items:center;}
.logos span{font-weight:800;font-size:18px;color:var(--ink-3);letter-spacing:-0.02em;opacity:.6;transition:.2s;}
.logos span:hover{opacity:1;color:var(--green-700);}

/* ============================================================
   STAT BAND
   ============================================================ */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.stat{position:relative;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px 22px;box-shadow:var(--shadow-card);overflow:hidden;}
.stat::after{content:"";position:absolute;right:-30px;bottom:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--glow-green),transparent 68%);opacity:.16;}
.stat .n{font-family:'IBM Plex Mono',monospace;font-size:38px;font-weight:700;letter-spacing:-0.03em;line-height:1;}
.stat .n .u{font-size:19px;color:var(--ink-3);}
.stat .n .g{background:var(--ink-grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.stat .l{font-size:12.5px;color:var(--ink-2);margin-top:9px;font-weight:600;}
.stat .spark{position:absolute;right:16px;top:18px;width:54px;height:22px;}

/* ============================================================
   FEATURES — bento
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;}
.feat{position:relative;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:var(--shadow-card);overflow:hidden;transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s;grid-column:span 2;}
.feat.w3{grid-column:span 3;} .feat.w6{grid-column:span 6;}
.feat:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg,0 24px 50px -24px oklch(0.3 0.06 255/0.3));}
.feat::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--ink-grad);transform:scaleX(0);transform-origin:left;transition:transform .35s ease;}
.feat:hover::before{transform:scaleX(1);}
.feat .fi{width:44px;height:44px;border-radius:13px;background:color-mix(in srgb,var(--green) 12%,transparent);color:var(--green-700);display:grid;place-items:center;margin-bottom:15px;transition:.25s;}
.feat:hover .fi{transform:scale(1.08) rotate(-5deg);}
.feat .fi svg{width:22px;height:22px;}
.feat h3{font-size:16.5px;font-weight:700;letter-spacing:-0.015em;}
.feat p{font-size:13.5px;color:var(--ink-2);margin-top:8px;line-height:1.55;max-width:40ch;}
.feat .gfx{margin-top:16px;}

/* feature mini-graphics */
.gfx-timer{display:flex;align-items:center;gap:14px;}
.gfx-timer .ring{--p:0;width:58px;height:58px;border-radius:50%;background:conic-gradient(var(--green) calc(var(--p)*1%),var(--canvas) 0);display:grid;place-items:center;transition:--p 1.2s ease;}
.gfx-timer .ring::after{content:"";width:44px;height:44px;border-radius:50%;background:var(--card);}
.gfx-timer .ring b{position:absolute;font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:700;color:var(--green-700);}
.gfx-timer .seq{display:flex;flex-direction:column;gap:5px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--ink-3);}
.gfx-timer .seq i{display:flex;align-items:center;gap:6px;}
.gfx-timer .seq i .d{width:5px;height:5px;border-radius:50%;background:var(--green);}

.gfx-io{display:flex;align-items:flex-end;gap:5px;height:46px;}
.gfx-io span{flex:1;background:var(--ink-grad);border-radius:4px 4px 2px 2px;opacity:.85;animation:iobar 1.6s ease-in-out infinite;transform-origin:bottom;}
@keyframes iobar{0%,100%{transform:scaleY(.35)}50%{transform:scaleY(1)}}

.gfx-shield{position:relative;height:64px;display:grid;place-items:center;}
.gfx-shield .sh{width:48px;height:54px;border-radius:0 0 24px 24px / 0 0 30px 30px;background:color-mix(in srgb,var(--green) 14%,transparent);border:1.6px solid var(--green);position:relative;z-index:2;clip-path:polygon(50% 0,100% 18%,100% 60%,50% 100%,0 60%,0 18%);box-shadow:0 0 22px var(--glow-green);}
.gfx-shield i{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--danger);top:50%;left:50%;animation:deflect 2.2s linear infinite;}
@keyframes deflect{0%{transform:translate(-60px,-30px);opacity:0}30%{opacity:1}60%{transform:translate(-14px,-6px)}61%{opacity:1}100%{transform:translate(-70px,28px);opacity:0}}

.gfx-route{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--ink-2);display:flex;flex-direction:column;gap:6px;}
.gfx-route .hop{display:flex;align-items:center;gap:8px;}
.gfx-route .hop .b{flex:1;height:5px;border-radius:3px;background:var(--canvas);overflow:hidden;}
.gfx-route .hop .b i{display:block;height:100%;background:var(--green);width:0;border-radius:3px;}
.gfx-route .hop .ms{color:var(--green-700);width:42px;text-align:right;}

.gfx-layers{display:flex;flex-direction:column;gap:5px;}
.gfx-layers span{height:13px;border-radius:5px;background:var(--canvas);border:1px solid var(--line);position:relative;overflow:hidden;}
.gfx-layers span::after{content:"";position:absolute;inset:0;width:30%;background:linear-gradient(90deg,transparent,var(--glow-green),transparent);animation:scan 2.6s linear infinite;}
.gfx-layers span:nth-child(2)::after{animation-delay:.5s} .gfx-layers span:nth-child(3)::after{animation-delay:1s}
@keyframes scan{0%{transform:translateX(-100%)}100%{transform:translateX(380%)}}

.gfx-pulse{height:44px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.gfx-pulse svg{width:200%;height:100%;animation:ecgscroll 3.2s linear infinite;}
.gfx-pulse .base{fill:none;stroke:color-mix(in srgb,var(--green) 22%,transparent);stroke-width:1.5;}
.gfx-pulse .wave{fill:none;stroke:var(--green);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 4px var(--glow-green));}
@keyframes ecgscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   BENCHMARK (data-viz)
   ============================================================ */
.bench{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.bench-card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow-card);}
.bench-card .bt{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px;}
.bench-card .bt h3{font-size:16px;font-weight:700;letter-spacing:-0.02em;}
.bench-card .bt .un{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--ink-3);}
.bench-card > .sub{font-size:12.5px;color:var(--ink-2);margin-bottom:20px;}
.brow{margin-bottom:16px;}
.brow:last-child{margin-bottom:0;}
.brow .bl{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:7px;}
.brow .bl .nm{font-weight:600;display:flex;align-items:center;gap:7px;}
.brow .bl .nm .tagme{font-size:9.5px;font-weight:700;background:var(--green);color:oklch(0.2 0.04 160);padding:1px 7px;border-radius:999px;font-family:'IBM Plex Mono',monospace;}
.brow .bl .vv{font-family:'IBM Plex Mono',monospace;font-weight:700;color:var(--ink);}
.brow .track{height:13px;border-radius:7px;background:var(--canvas);border:1px solid var(--line);overflow:hidden;}
.brow .track i{display:block;height:100%;width:0;border-radius:7px;background:linear-gradient(90deg,oklch(0.74 0.012 255),oklch(0.66 0.014 255));transition:width 1.3s cubic-bezier(.2,.8,.2,1);}
.brow.me .track i{background:var(--ink-grad);box-shadow:0 0 16px var(--glow-green);}
.bench-foot{margin-top:18px;font-size:11.5px;font-family:'IBM Plex Mono',monospace;color:var(--ink-3);display:flex;align-items:center;gap:8px;}
.bench-foot::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--glow-green);}

/* ============================================================
   NETWORK / LATENCY MAP (new)
   ============================================================ */
.netmap{position:relative;background:linear-gradient(165deg,oklch(0.21 0.014 255),oklch(0.17 0.012 255));border:1px solid oklch(1 0 0/0.06);border-radius:26px;padding:34px;overflow:hidden;box-shadow:0 40px 80px -40px oklch(0.3 0.06 160/0.5);color:oklch(0.92 0.01 255);}
.netmap .nm-grid{position:absolute;inset:0;background-image:linear-gradient(oklch(1 0 0/0.05) 1px,transparent 1px),linear-gradient(90deg,oklch(1 0 0/0.05) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse 90% 90% at 50% 40%,#000,transparent 80%);mask-image:radial-gradient(ellipse 90% 90% at 50% 40%,#000,transparent 80%);}
.netmap-head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:8px;flex-wrap:wrap;}
.netmap-head .k{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--green);letter-spacing:.1em;text-transform:uppercase;}
.netmap-head .k::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--glow-green);animation:pip 1.6s infinite;}
.netmap-head h2{font-size:clamp(24px,3vw,34px);font-weight:800;letter-spacing:-0.03em;margin-top:12px;color:#fff;}
.netmap-head p{color:oklch(0.7 0.012 255);font-size:14px;margin-top:8px;max-width:46ch;}
.netmap .live{font-family:'IBM Plex Mono',monospace;font-size:11px;color:oklch(0.7 0.012 255);display:flex;align-items:center;gap:8px;background:oklch(1 0 0/0.05);border:1px solid oklch(1 0 0/0.08);border-radius:999px;padding:7px 13px;}
.netmap .live .d{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--glow-green);animation:pip 1.4s infinite;}

.mapstage{position:relative;z-index:2;height:340px;margin-top:18px;}
.mapstage svg.arc{position:absolute;inset:0;width:100%;height:100%;overflow:visible;}
.mapstage svg.arc path{fill:none;stroke:oklch(0.7 0.14 159/0.5);stroke-width:1.4;stroke-dasharray:4 8;animation:dash 1.6s linear infinite;}
.mapstage svg.arc path.c{stroke:oklch(0.58 0.12 166/0.55);}
.dc{position:absolute;transform:translate(-50%,-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;}
.dc .pin{position:relative;width:18px;height:18px;border-radius:50%;background:oklch(0.7 0.16 159);box-shadow:0 0 0 5px oklch(0.7 0.16 159/0.18),0 0 18px var(--glow-green);}
.dc .pin::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--green);animation:ping 2.6s ease-out infinite;}
.dc.cyan .pin{background:oklch(0.58 0.13 166);box-shadow:0 0 0 5px oklch(0.58 0.13 166/0.2),0 0 18px oklch(0.58 0.13 166/0.5);}
.dc.cyan .pin::after{border-color:var(--cyan);}
.dc .card{background:oklch(0.26 0.014 255);border:1px solid oklch(1 0 0/0.09);border-radius:11px;padding:9px 12px;text-align:center;min-width:118px;box-shadow:0 12px 30px -14px oklch(0 0 0/0.6);}
.dc .card .cn{font-size:12.5px;font-weight:700;color:#fff;display:flex;align-items:center;gap:6px;justify-content:center;}
.dc .card .cn .fl{font-size:15px;}
.dc .card .pingv{font-family:'IBM Plex Mono',monospace;font-size:17px;font-weight:700;color:var(--green);margin-top:3px;}
.dc.cyan .card .pingv{color:var(--cyan);}
.dc .card .pingv .u{font-size:11px;color:oklch(0.6 0.012 255);}
.dc .card .meta{font-size:9.5px;font-family:'IBM Plex Mono',monospace;color:oklch(0.6 0.012 255);margin-top:2px;}
.netmap-foot{position:relative;z-index:2;display:flex;gap:26px;flex-wrap:wrap;margin-top:22px;padding-top:18px;border-top:1px solid oklch(1 0 0/0.08);}
.netmap-foot .nf{font-family:'IBM Plex Mono',monospace;}
.netmap-foot .nf .v{font-size:20px;font-weight:700;color:#fff;}
.netmap-foot .nf .v .g{color:var(--green);}
.netmap-foot .nf .l{font-size:11px;color:oklch(0.62 0.012 255);margin-top:2px;}

/* ============================================================
   STEPS — pipeline
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;position:relative;}
.steps::before{content:"";position:absolute;top:42px;left:14%;right:14%;height:2px;background:repeating-linear-gradient(90deg,color-mix(in srgb,var(--green) 45%,transparent) 0 8px,transparent 8px 16px);z-index:0;}
.step{position:relative;z-index:1;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow-card);transition:transform .25s,box-shadow .25s;}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg,0 24px 50px -24px oklch(0.3 0.06 255/0.3));}
.step .sn{width:48px;height:48px;border-radius:14px;background:var(--ink-grad);color:#fff;display:grid;place-items:center;font-weight:800;font-family:'IBM Plex Mono',monospace;font-size:18px;margin-bottom:16px;box-shadow:0 12px 24px -10px var(--glow-green);}
.step h3{font-size:17px;font-weight:700;letter-spacing:-0.015em;}
.step p{font-size:13.5px;color:var(--ink-2);margin-top:8px;line-height:1.55;}
.step .chip{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--green-700);background:color-mix(in srgb,var(--green) 10%,transparent);border:1px solid color-mix(in srgb,var(--green) 20%,transparent);padding:4px 10px;border-radius:999px;}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:24px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;}
.tcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg,0 24px 50px -24px oklch(0.3 0.06 255/0.3));}
.tcard .stars{color:#f5a623;font-size:13px;letter-spacing:2px;}
.tcard p{font-size:14.5px;color:var(--ink);line-height:1.6;margin-top:12px;}
.tcard .tm{display:flex;align-items:center;gap:11px;margin-top:18px;}
.tcard .tm .av{width:38px;height:38px;border-radius:50%;background:var(--ink-grad);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;}
.tcard .tm .nm{font-size:13.5px;font-weight:700;} .tcard .tm .rl{font-size:11.5px;color:var(--ink-3);font-family:'IBM Plex Mono',monospace;}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:780px;margin:0 auto;}
.faq details{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:2px 20px;margin-bottom:10px;box-shadow:var(--shadow-soft);transition:.2s;}
.faq details[open]{border-color:color-mix(in srgb,var(--green) 35%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--green) 10%,transparent);}
.faq summary{font-size:14.5px;font-weight:700;padding:16px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--green-700);font-weight:700;font-size:20px;line-height:1;}
.faq details[open] summary::after{content:"\2212";}
.faq .fa{font-size:13.5px;color:var(--ink-2);padding:0 0 16px;line-height:1.6;margin:0;}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{position:relative;background:linear-gradient(150deg,oklch(0.42 0.11 162),oklch(0.6 0.16 155) 60%,oklch(0.72 0.155 154));border-radius:28px;padding:56px 44px;text-align:center;color:#fff;overflow:hidden;box-shadow:0 40px 90px -36px var(--glow-green);}
.cta-band .cgrid{position:absolute;inset:0;background-image:linear-gradient(oklch(1 0 0/0.08) 1px,transparent 1px),linear-gradient(90deg,oklch(1 0 0/0.08) 1px,transparent 1px);background-size:38px 38px;-webkit-mask-image:radial-gradient(ellipse 80% 100% at 50% 0%,#000,transparent 70%);mask-image:radial-gradient(ellipse 80% 100% at 50% 0%,#000,transparent 70%);}
.cta-band .glow{position:absolute;width:420px;height:200px;border-radius:50%;background:oklch(1 0 0/0.3);filter:blur(70px);top:-90px;left:50%;transform:translateX(-50%);}
.cta-band h2{font-size:clamp(28px,3.4vw,40px);font-weight:800;letter-spacing:-0.035em;position:relative;}
.cta-band p{opacity:.92;margin:12px auto 26px;position:relative;max-width:50ch;font-size:15.5px;}
.cta-band .pm-btn{position:relative;}
.cta-mini{position:relative;margin-top:18px;font-family:'IBM Plex Mono',monospace;font-size:12px;opacity:.85;display:flex;gap:18px;justify-content:center;flex-wrap:wrap;}
.cta-mini span{display:inline-flex;align-items:center;gap:6px;}
.cta-mini span::before{content:"\2713";font-weight:700;}

/* ============================================================
   FOOTER
   ============================================================ */
footer{border-top:1px solid var(--line);padding:48px 0 56px;color:var(--ink-3);font-size:13px;position:relative;}
.ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:28px;margin-bottom:30px;}
.ft-grid h4{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:13px;text-transform:uppercase;letter-spacing:.06em;font-family:'IBM Plex Mono',monospace;}
.ft-grid a{display:block;color:var(--ink-2);text-decoration:none;font-size:13.5px;padding:4px 0;transition:.15s;}
.ft-grid a:hover{color:var(--green-700);}
.ft-bot{border-top:1px solid var(--line);padding-top:20px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:'IBM Plex Mono',monospace;font-size:12px;}

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

/* ============================================================
   responsive
   ============================================================ */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:24px;}
  .hero-stage{height:360px;order:-1;}
  .hero-switch{position:static;margin-top:20px;}
  .statband{grid-template-columns:1fr 1fr;}
  .bento{grid-template-columns:1fr;}
  .feat,.feat.w3,.feat.w6{grid-column:auto;}
  .bench{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .steps::before{display:none;}
  .tgrid{grid-template-columns:1fr;}
  .ft-grid{grid-template-columns:1fr 1fr;}
  .nav .lk{display:none;}
}
@media(max-width:560px){
  .statband{grid-template-columns:1fr;}
  .wrap{padding:0 20px;}
}
