/* ============================================================
   FASTPLANET — Shared site stylesheet
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-alt:#f4f5f8;
  --surface:#ffffff;
  --surface-2:#f8f9fb;
  --border:#e6e8ee;
  --border-strong:#d3d8e1;
  --text:#0d1526;
  --text-soft:#46506a;
  --text-mute:#838ea1;
  --accent:#2a52e0;
  --accent-hover:#1e3fbf;
  --accent-soft:#eef2fe;
  --shadow:0 22px 48px -30px rgba(13,21,38,.32);
  --shadow-sm:0 6px 20px -12px rgba(13,21,38,.26);
  --ring:rgba(42,82,224,.16);
  --grid-line:rgba(13,21,38,.045);
  --header-bg:rgba(255,255,255,.86);
  --ink:#0b1430;
  --ink-2:#080f24;
}
[data-theme="dark"]{
  --bg:#0a1020;
  --bg-alt:#0c1325;
  --surface:#111a31;
  --surface-2:#0f1729;
  --border:#1f2a45;
  --border-strong:#2c3a5c;
  --text:#eef1f7;
  --text-soft:#abb5c9;
  --text-mute:#6c7995;
  --accent:#5b81ff;
  --accent-hover:#7997ff;
  --accent-soft:#16203c;
  --shadow:0 28px 56px -30px rgba(0,0,0,.78);
  --shadow-sm:0 8px 26px -14px rgba(0,0,0,.7);
  --ring:rgba(91,129,255,.28);
  --grid-line:rgba(255,255,255,.04);
  --header-bg:rgba(10,16,32,.84);
  --ink:#0b1430;
  --ink-2:#070d20;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Figtree',sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.62;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;transition:background .35s ease,color .35s ease;
}
a{color:inherit;text-decoration:none}
svg{display:block}
.container{max-width:1200px;margin:0 auto;padding:0 32px}
h1,h2,h3,h4{font-family:'Schibsted Grotesk',sans-serif;letter-spacing:-.018em}

.eyebrow{
  font-family:'IBM Plex Mono',monospace;font-size:.73rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;color:var(--accent);
  display:inline-flex;align-items:center;gap:9px;
}
.eyebrow .bar{width:22px;height:1px;background:var(--accent);opacity:.55}

/* ===== PLANET LOGO ===== */
.logo{display:flex;align-items:center;gap:11px}
.logo-mark{width:37px;height:37px;flex-shrink:0;overflow:visible;transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.logo:hover .logo-mark{transform:scale(1.07)}
.logo-mark .planet-grp{transform-origin:20px 20px;animation:lpop .55s cubic-bezier(.34,1.3,.5,1) both}
@keyframes lpop{from{transform:scale(0)}to{transform:scale(1)}}
.logo-mark .orbit{transform-origin:20px 20px;animation:lspin 20s linear infinite}
@keyframes lspin{to{transform:rotate(360deg)}}
.logo-mark .orbit-arc{
  fill:none;stroke:var(--accent);stroke-dasharray:100;stroke-dashoffset:100;
  animation:ldraw 1.05s cubic-bezier(.4,.6,.2,1) .1s forwards;
}
@keyframes ldraw{to{stroke-dashoffset:0}}
.logo-mark .orbit-node{fill:var(--accent);opacity:0;animation:lfade .35s ease .95s forwards}
@keyframes lfade{to{opacity:1}}
.logo-mark .planet{fill:var(--accent)}
.logo-mark .gl{stroke:#fff;fill:none;opacity:.5}
.logo-type{
  font-family:'Schibsted Grotesk',sans-serif;font-weight:800;
  font-size:1.2rem;letter-spacing:.01em;color:var(--text);line-height:1;
}
.logo-type i{color:var(--accent);font-style:normal}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Figtree',sans-serif;font-weight:600;font-size:.94rem;
  padding:13px 24px;border-radius:8px;cursor:pointer;
  border:1px solid transparent;transition:.22s ease;white-space:nowrap;
}
.btn svg{width:16px;height:16px;transition:transform .22s ease}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 14px 28px -12px var(--ring)}
.btn-outline{background:transparent;border-color:var(--border-strong);color:var(--text)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--ink)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(0,0,0,.5)}
.btn-onnavy{background:transparent;border-color:rgba(255,255,255,.22);color:#fff}
.btn-onnavy:hover{border-color:rgba(255,255,255,.55);transform:translateY(-2px)}

/* ===== HEADER (topbar + nav) ===== */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:var(--header-bg);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s;
}
header.scrolled{border-bottom-color:var(--border);box-shadow:var(--shadow-sm)}

.topbar{
  background:var(--ink-2);height:38px;overflow:hidden;
  transition:height .3s ease,opacity .25s ease;
}
.topbar .container{display:flex;align-items:center;justify-content:space-between;height:38px}
.tb-left{
  display:flex;align-items:center;gap:9px;font-family:'IBM Plex Mono',monospace;
  font-size:.73rem;letter-spacing:.04em;color:rgba(255,255,255,.6);
}
.tb-left .d{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.tb-right{display:flex;align-items:center;gap:20px}
.tb-right a{font-size:.78rem;color:rgba(255,255,255,.68);transition:color .2s}
.tb-right a:hover{color:#fff}
header.scrolled .topbar{height:0;opacity:0}

.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.nav-mid{display:flex;align-items:center;gap:34px}
.nav-mid a:not(.btn){
  font-size:.93rem;font-weight:500;color:var(--text-soft);
  position:relative;padding:6px 0;transition:color .2s;
}
.nav-mid a:not(.btn)::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--accent);transition:width .25s;
}
.nav-mid a:not(.btn):hover,.nav-mid a.active{color:var(--text)}
.nav-mid a:not(.btn):hover::after,.nav-mid a.active::after{width:100%}
.nav-mid > .btn-primary{display:none}
.nav-end{display:flex;align-items:center;gap:14px}
.theme-btn,.burger{
  width:42px;height:42px;border-radius:8px;cursor:pointer;
  background:var(--surface-2);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;transition:.2s;
}
.theme-btn{color:var(--text-soft)}
.theme-btn:hover{color:var(--accent);border-color:var(--accent)}
.theme-btn svg{width:18px;height:18px}
.theme-btn .ic-sun{display:none}
[data-theme="dark"] .theme-btn .ic-sun{display:block}
[data-theme="dark"] .theme-btn .ic-moon{display:none}
.burger{display:none;flex-direction:column;gap:5px}
.burger span{width:17px;height:2px;background:var(--text);border-radius:2px}

/* ===== HOMEPAGE HERO ===== */
.hero{position:relative;padding:190px 0 96px;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:-60px;z-index:-1;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 70% 80% at 70% 25%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 70% 80% at 70% 25%,#000,transparent 75%);
  animation:drift 38s linear infinite;
}
@keyframes drift{to{background-position:60px 60px}}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center}
.hero h1{font-weight:800;font-size:clamp(2.7rem,5vw,4.05rem);line-height:1.06;margin:22px 0 20px}
.hero h1 .hl{color:var(--accent);white-space:nowrap}
.hero .lead{font-size:1.13rem;color:var(--text-soft);max-width:480px;margin-bottom:32px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.hero-meta{
  display:flex;gap:22px;flex-wrap:wrap;margin-top:34px;padding-top:26px;
  border-top:1px solid var(--border);font-family:'IBM Plex Mono',monospace;
  font-size:.74rem;letter-spacing:.06em;color:var(--text-mute);text-transform:uppercase;
}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta span::before{
  content:"";width:6px;height:6px;border-radius:2px;background:var(--accent);
  animation:blink 2.4s ease-in-out infinite;
}
.hero-meta span:nth-child(2)::before{animation-delay:.8s}
.hero-meta span:nth-child(3)::before{animation-delay:1.6s}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* network panel */
.panel-wrap{position:relative}
.panel-wrap::before{
  content:"";position:absolute;right:-18px;bottom:-18px;
  width:62%;height:62%;border:1px solid var(--accent);border-radius:16px;opacity:.18;
}
.net-panel{
  position:relative;background:var(--surface);
  border:1px solid var(--border);border-radius:16px;
  box-shadow:var(--shadow);overflow:hidden;
  animation:floaty 7s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.np-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:15px 20px;border-bottom:1px solid var(--border);background:var(--surface-2);
}
.np-head .ttl{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--text-mute)}
.np-head .status{display:flex;align-items:center;gap:7px;font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.08em;color:var(--text-soft)}
.np-head .dot{width:7px;height:7px;border-radius:50%;background:#1fab6d;animation:livedot 2s ease-in-out infinite}
@keyframes livedot{0%,100%{box-shadow:0 0 0 0 rgba(31,171,109,.45)}70%{box-shadow:0 0 0 7px rgba(31,171,109,0)}}
.np-body{padding:24px 24px 18px;display:flex;justify-content:center}
.globe{width:100%;max-width:282px;animation:globeIn 1s ease both}
@keyframes globeIn{from{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}
.globe .ring-l{stroke:var(--border-strong);fill:none}
.globe .grid-l{stroke:var(--border);fill:none}
.globe .arc{stroke:var(--accent);fill:none;opacity:.32}
.globe .node{fill:var(--accent)}
.globe .ping{fill:var(--accent);transform-box:fill-box;transform-origin:center;animation:ping 3.4s ease-out infinite}
.globe .ping.b{animation-delay:1.1s}
.globe .ping.c{animation-delay:2.2s}
@keyframes ping{0%{transform:scale(.5);opacity:.55}80%,100%{transform:scale(3);opacity:0}}
.globe .packet{fill:var(--accent);filter:drop-shadow(0 0 4px var(--accent))}
.globe .pkt-glow{fill:var(--accent);opacity:.22}
.np-foot{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border)}
.np-foot .cell{padding:15px 16px;border-right:1px solid var(--border)}
.np-foot .cell:last-child{border-right:none}
.np-foot .k{font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-mute)}
.np-foot .v{font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:1.02rem;margin-top:4px}

/* ===== SUB-PAGE HERO ===== */
.subhero{
  position:relative;overflow:hidden;padding:170px 0 76px;
  background:var(--surface-2);border-bottom:1px solid var(--border);
}
.subhero::before{
  content:"";position:absolute;inset:-60px;z-index:0;
  background-image:
    linear-gradient(var(--grid-line) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(ellipse 70% 80% at 75% 30%,#000,transparent 75%);
          mask-image:radial-gradient(ellipse 70% 80% at 75% 30%,#000,transparent 75%);
  animation:drift 40s linear infinite;
}
.subhero::after{
  content:"";position:absolute;right:-160px;top:-100px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(42,82,224,.13),transparent 60%);
  pointer-events:none;z-index:0;
}
.subhero .container{position:relative;z-index:1}
.subhero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:center}
.subhero-text .breadcrumb{
  display:flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;
  font-size:.72rem;letter-spacing:.08em;color:var(--text-mute);margin-bottom:18px;flex-wrap:wrap;
}
.subhero-text .breadcrumb a{color:var(--text-soft);transition:color .2s}
.subhero-text .breadcrumb a:hover{color:var(--accent)}
.subhero-text .breadcrumb .sep{color:var(--text-mute);opacity:.6}
.subhero-text .breadcrumb .cur{color:var(--text)}
.subhero h1{font-weight:800;font-size:clamp(2.2rem,4.2vw,3.4rem);line-height:1.07;margin:6px 0 18px}
.subhero h1 .hl{color:var(--accent)}
.subhero p.intro{font-size:1.1rem;color:var(--text-soft);max-width:560px;margin-bottom:26px}
.subhero .actions{display:flex;gap:13px;flex-wrap:wrap}
.subhero-art{display:flex;justify-content:center;align-items:center;opacity:.96}
.subhero-art svg{width:100%;max-width:380px;height:auto}

/* ===== CARRIER STRIP ===== */
.carriers{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface-2)}
.carriers .container{display:flex;align-items:center;gap:38px;flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.carriers .cap{font-family:'IBM Plex Mono',monospace;font-size:.71rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-mute);max-width:200px;line-height:1.5}
.carrier-names{display:flex;gap:34px;flex-wrap:wrap;align-items:center;flex:1}
.carrier-names b{font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:1.1rem;color:var(--text-mute);letter-spacing:.02em;transition:color .2s,transform .2s}
.carrier-names b:hover{color:var(--text);transform:translateY(-2px)}

/* ===== SECTIONS ===== */
.section{padding:clamp(74px,9vw,116px) 0}
.section.alt{background:var(--bg-alt)}
.section.small{padding:clamp(54px,7vw,84px) 0}
.sec-head h2{font-weight:700;font-size:clamp(1.95rem,3.2vw,2.6rem);line-height:1.14;margin-top:15px}
.sec-head p{color:var(--text-soft);margin-top:12px;font-size:1.05rem;max-width:520px}

/* ===== GLOBAL NETWORK (homepage) ===== */
.globalnet{
  position:relative;overflow:hidden;
  background:linear-gradient(165deg,var(--ink),var(--ink-2));
  padding:clamp(74px,9vw,110px) 0;
}
.globalnet::before{
  content:"";position:absolute;left:50%;top:36%;width:780px;height:520px;
  transform:translate(-50%,-50%);
  background:radial-gradient(ellipse,rgba(94,134,255,.16),transparent 68%);
  pointer-events:none;
}
.gn-head{max-width:620px;margin:0 auto;text-align:center;position:relative}
.gn-head .eyebrow{color:#7d97ff;justify-content:center}
.gn-head .eyebrow .bar{background:#7d97ff}
.gn-head h2{color:#fff;font-weight:700;font-size:clamp(1.95rem,3.2vw,2.6rem);line-height:1.14;margin-top:15px}
.gn-head p{color:rgba(255,255,255,.64);margin-top:13px;font-size:1.05rem}
.gn-map{position:relative;max-width:1010px;margin:24px auto 0}
.gn-map svg{width:100%;height:auto;display:block;overflow:visible}
.gn-map .land path{fill:url(#wmdots)}
.gn-map .arc{stroke:#5e86ff;stroke-width:1.4;fill:none;opacity:.4;stroke-dasharray:5 7;animation:gnflow 4s linear infinite}
@keyframes gnflow{to{stroke-dashoffset:-24}}
.gn-map .pop{fill:#5e86ff}
.gn-map .pulse{fill:#5e86ff;transform-box:fill-box;transform-origin:center;animation:gnpulse 3.2s ease-out infinite}
@keyframes gnpulse{0%{transform:scale(.45);opacity:.6}80%,100%{transform:scale(3.6);opacity:0}}
.gn-map .pkt{fill:#cdd9ff;filter:drop-shadow(0 0 4px #5e86ff)}
.gn-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:38px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1);position:relative}
.gn-fact{display:flex;gap:13px;align-items:flex-start}
.gn-fact .fic{width:40px;height:40px;border-radius:9px;flex-shrink:0;background:rgba(94,134,255,.12);border:1px solid rgba(94,134,255,.3);display:flex;align-items:center;justify-content:center}
.gn-fact .fic svg{width:19px;height:19px;stroke:#7da2ff;fill:none;stroke-width:1.7}
.gn-fact h4{color:#fff;font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:.97rem;margin-bottom:3px}
.gn-fact p{color:rgba(255,255,255,.5);font-size:.83rem;line-height:1.5}

/* ===== CAPABILITIES ===== */
.cap-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;align-items:start}
.cap-intro{position:sticky;top:108px}
.cap-intro .lnk{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-weight:600;color:var(--accent);font-size:.95rem}
.cap-intro .lnk svg{width:15px;height:15px;transition:transform .2s}
.cap-intro .lnk:hover svg{transform:translateX(4px)}
.cap-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.cap-card{background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:28px 26px;transition:.28s cubic-bezier(.2,.7,.2,1)}
.cap-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:var(--shadow-sm)}
.cap-card .row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.cap-card .ic{width:46px;height:46px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;transition:.28s}
.cap-card:hover .ic{transform:scale(1.08) rotate(-4deg)}
.cap-card .ic svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.7}
.cap-card .no{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--text-mute)}
.cap-card h3{font-weight:700;font-size:1.14rem;margin-bottom:9px}
.cap-card p{font-size:.92rem;color:var(--text-soft);line-height:1.62}

/* ===== SERVICES GRID ===== */
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:46px;flex-wrap:wrap}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{
  background:var(--surface);border:1px solid var(--border);border-radius:13px;
  padding:30px 28px;display:flex;flex-direction:column;
  transition:.28s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden;
}
.svc::before{
  content:"";position:absolute;left:0;top:0;right:0;height:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.svc:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:var(--shadow)}
.svc:hover::before{transform:scaleX(1)}
.svc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.svc-ic{width:46px;height:46px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;transition:.28s}
.svc:hover .svc-ic{transform:scale(1.08) rotate(-4deg)}
.svc-ic svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.7}
.svc-cat{font-family:'IBM Plex Mono',monospace;font-size:.64rem;letter-spacing:.11em;text-transform:uppercase;color:var(--text-mute)}
.svc h3{font-weight:700;font-size:1.22rem;line-height:1.25;margin-bottom:10px}
.svc p{font-size:.93rem;color:var(--text-soft);flex:1;margin-bottom:20px}
.svc-links{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding-top:18px;border-top:1px solid var(--border)}
.svc-links a{font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:.2s}
.svc-links a.more{color:var(--accent)}
.svc-links a.more svg{width:13px;height:13px;transition:transform .2s}
.svc-links a.more:hover svg{transform:translateX(4px)}
.svc-links a.sec{color:var(--text-mute)}
.svc-links a.sec:hover{color:var(--text)}

/* ===== TIER CARDS (pricing-style) ===== */
.tiers{display:grid;gap:22px}
.tiers.cols-2{grid-template-columns:repeat(2,1fr)}
.tiers.cols-3{grid-template-columns:repeat(3,1fr)}
.tier{
  background:var(--surface);border:1px solid var(--border);border-radius:13px;
  padding:32px 28px 28px;display:flex;flex-direction:column;
  transition:.28s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden;
}
.tier:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:var(--shadow)}
.tier.featured{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.tier.featured::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--accent)}
.tier .tag{font-family:'IBM Plex Mono',monospace;font-size:.65rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.tier .badge{position:absolute;top:18px;right:18px;background:var(--accent);color:#fff;font-family:'IBM Plex Mono',monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border-radius:5px}
.tier h3{font-weight:700;font-size:1.4rem;margin-bottom:8px;line-height:1.15}
.tier .blurb{color:var(--text-soft);font-size:.92rem;margin-bottom:22px}
.tier ul{list-style:none;padding:0;margin:0 0 26px;flex:1}
.tier ul li{display:flex;align-items:flex-start;gap:10px;padding:11px 0;border-bottom:1px solid var(--border);font-size:.92rem;color:var(--text-soft)}
.tier ul li:last-child{border-bottom:none}
.tier ul li svg{width:15px;height:15px;flex-shrink:0;stroke:var(--accent);fill:none;stroke-width:2.4;margin-top:3px}
.tier .btn{margin-top:auto;justify-content:center}

/* ===== FEATURE GRID ===== */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.feature-card{background:var(--surface-2);border:1px solid var(--border);border-radius:11px;padding:24px 24px;transition:.25s ease}
.feature-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}
.feature-card .fc-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.feature-card .fc-ic{width:36px;height:36px;border-radius:8px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feature-card .fc-ic svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:1.8}
.feature-card h4{font-weight:700;font-size:1rem;color:var(--text);line-height:1.25}
.feature-card ul{list-style:none;padding:0;margin:0}
.feature-card ul li{font-size:.9rem;color:var(--text-soft);padding:6px 0;display:flex;align-items:flex-start;gap:9px;line-height:1.55}
.feature-card ul li::before{content:"";flex-shrink:0;width:5px;height:5px;border-radius:50%;background:var(--accent);margin-top:9px}
.feature-card p{font-size:.92rem;color:var(--text-soft);line-height:1.62}

/* ===== SPEC TABLE ===== */
.spec-table{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.spec-table .sthead{padding:14px 22px;background:var(--surface-2);border-bottom:1px solid var(--border);font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--text-mute)}
.spec-table .row{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:14px 22px;border-bottom:1px solid var(--border);font-size:.93rem}
.spec-table .row:last-child{border-bottom:none}
.spec-table .row .k{color:var(--text-soft);font-weight:500}
.spec-table .row .v{color:var(--text);font-weight:700;font-family:'IBM Plex Mono',monospace;font-size:.86rem}
.spec-table .row .check{color:var(--accent);font-weight:700;display:inline-flex;align-items:center;gap:4px}
.two-col-tables{display:grid;grid-template-columns:1fr 1fr;gap:22px}

/* ===== PEERING GRID ===== */
.peering-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.peering-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:18px 20px;transition:.2s ease}
.peering-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.peering-card .cat{font-family:'IBM Plex Mono',monospace;font-size:.6rem;letter-spacing:.13em;text-transform:uppercase;color:var(--accent);display:block;margin-bottom:6px}
.peering-card h4{font-weight:700;font-size:1.04rem;margin-bottom:5px}
.peering-card p{font-size:.82rem;color:var(--text-soft);font-family:'IBM Plex Mono',monospace}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:start}
.contact-info{display:flex;flex-direction:column}
.contact-row{padding:24px 0;border-bottom:1px solid var(--border)}
.contact-row:first-child{padding-top:0}
.contact-row:last-child{border-bottom:none}
.contact-row h4{font-family:'IBM Plex Mono',monospace;font-size:.72rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.contact-row p,.contact-row a{font-size:1.02rem;color:var(--text);line-height:1.6}
.contact-row a{color:var(--text);transition:color .2s;display:inline-block}
.contact-row a:hover{color:var(--accent)}
.contact-row .muted{color:var(--text-soft);font-size:.93rem}
.contact-emails{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.contact-emails .em h5{font-family:'IBM Plex Mono',monospace;font-size:.66rem;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--text-mute);margin-bottom:6px}
.contact-emails .em a{font-size:.95rem;font-weight:600}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:34px 32px;box-shadow:var(--shadow-sm)}
.contact-card h3{font-weight:700;font-size:1.35rem;margin-bottom:12px}
.contact-card p{color:var(--text-soft);margin-bottom:22px}
.contact-card .btn{width:100%;justify-content:center}
.contact-card .quick{display:flex;flex-direction:column;gap:14px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.contact-card .qrow{display:flex;align-items:center;gap:14px;font-size:.95rem}
.contact-card .qrow .qic{width:38px;height:38px;border-radius:9px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-card .qrow .qic svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:1.8}
.contact-card .qrow .ql{font-family:'IBM Plex Mono',monospace;font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--text-mute);margin-bottom:2px}
.contact-card .qrow strong{font-weight:700;color:var(--text)}

/* ===== LEGAL / PROSE ===== */
.prose{max-width:780px;margin:0 auto}
.prose .toc{background:var(--surface-2);border:1px solid var(--border);border-radius:11px;padding:22px 26px;margin-bottom:48px}
.prose .toc h4{font-family:'IBM Plex Mono',monospace;font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.prose .toc ol{list-style:none;padding:0;counter-reset:toc;column-count:2;column-gap:28px}
.prose .toc ol li{counter-increment:toc;padding:4px 0;font-size:.92rem;break-inside:avoid}
.prose .toc ol li::before{content:counter(toc,decimal-leading-zero) ".";color:var(--text-mute);font-family:'IBM Plex Mono',monospace;margin-right:8px;font-size:.82rem}
.prose .toc ol li a{color:var(--text-soft);transition:color .2s}
.prose .toc ol li a:hover{color:var(--accent)}
.prose h2{font-weight:700;font-size:1.55rem;margin-top:54px;margin-bottom:14px;scroll-margin-top:110px;display:flex;align-items:baseline;gap:12px}
.prose h2 .pnum{font-family:'IBM Plex Mono',monospace;font-size:.78rem;color:var(--accent);font-weight:500;letter-spacing:.1em}
.prose h2:first-child{margin-top:0}
.prose h3{font-weight:700;font-size:1.18rem;margin-top:30px;margin-bottom:10px}
.prose p{margin-bottom:14px;color:var(--text-soft);line-height:1.78;font-size:1rem}
.prose ul{padding-left:0;list-style:none;margin-bottom:18px}
.prose ul li{position:relative;padding-left:22px;margin-bottom:8px;color:var(--text-soft);line-height:1.65}
.prose ul li::before{content:"";position:absolute;left:0;top:11px;width:10px;height:1px;background:var(--accent)}
.prose hr{border:0;border-top:1px solid var(--border);margin:38px 0}
.prose strong{color:var(--text);font-weight:700}
.prose .lead{font-size:1.1rem;color:var(--text);background:var(--accent-soft);border-left:3px solid var(--accent);padding:18px 22px;border-radius:7px;margin-bottom:34px;line-height:1.62}
[data-theme="dark"] .prose .lead{background:rgba(91,129,255,.08)}

/* ===== CTA BAND ===== */
.cta{background:linear-gradient(135deg,var(--ink),var(--ink-2));position:relative;overflow:hidden}
.cta::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(ellipse 60% 90% at 80% 50%,#000,transparent 80%);
          mask-image:radial-gradient(ellipse 60% 90% at 80% 50%,#000,transparent 80%);
  animation:drift 44s linear infinite;
}
.cta .container{position:relative;padding-top:78px;padding-bottom:78px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap}
.cta .eyebrow{color:#7d97ff}
.cta .eyebrow .bar{background:#7d97ff}
.cta h2{color:#fff;font-weight:700;font-size:clamp(1.8rem,3vw,2.5rem);line-height:1.14;margin:14px 0 12px;max-width:560px}
.cta p{color:rgba(255,255,255,.66);max-width:480px}
.cta-actions{display:flex;gap:13px;flex-wrap:wrap}

/* ===== FOOTER ===== */
footer{background:var(--ink-2);color:rgba(255,255,255,.62);border-top:1px solid rgba(255,255,255,.07)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;padding:72px 0 0}
.foot-brand .logo{margin-bottom:16px}
.foot-brand .logo-type{color:#fff}
.foot-brand p{font-size:.92rem;max-width:300px;margin-bottom:18px}
.reg{font-family:'IBM Plex Mono',monospace;font-size:.74rem;color:rgba(255,255,255,.4);line-height:1.7}
.foot-col h4{font-family:'IBM Plex Mono',monospace;font-size:.71rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:#7d97ff;margin-bottom:16px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:10px}
.foot-col a{font-size:.92rem;color:rgba(255,255,255,.62);transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{margin-top:56px;padding:24px 0;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:.82rem;color:rgba(255,255,255,.4)}

/* ===== REVEAL / LOAD ===== */
.reveal{opacity:0;transform:translateY(28px);filter:blur(7px);transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1),filter .75s ease}
.reveal.in{opacity:1;transform:none;filter:blur(0)}
.load{opacity:0;animation:up .8s cubic-bezier(.2,.7,.2,1) forwards}
.load.d1{animation-delay:.05s}.load.d2{animation-delay:.15s}
.load.d3{animation-delay:.26s}.load.d4{animation-delay:.38s}.load.d5{animation-delay:.5s}
@keyframes up{from{opacity:0;transform:translateY(26px);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}
.load-right{opacity:0;animation:inRight .9s cubic-bezier(.2,.7,.2,1) .3s forwards}
@keyframes inRight{from{opacity:0;transform:translateX(46px);filter:blur(8px)}to{opacity:1;transform:none;filter:blur(0)}}

/* ===== RESPONSIVE ===== */
#services{scroll-margin-top:100px}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .panel-wrap{max-width:440px;margin:0 auto}
  .subhero-grid{grid-template-columns:1fr;gap:38px}
  .subhero-art{max-width:300px;margin:0 auto}
  .cap-grid{grid-template-columns:1fr;gap:36px}
  .cap-intro{position:static}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
  .gn-facts{grid-template-columns:repeat(2,1fr)}
  .tiers.cols-3{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .peering-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .two-col-tables{grid-template-columns:1fr}
}
@media(max-width:760px){
  .container{padding:0 20px}
  .topbar{display:none}
  .nav-mid{display:none}
  .burger{display:flex}
  .nav-end .btn-primary{display:none}
  .nav-mid.open{display:flex;position:fixed;top:76px;left:0;right:0;flex-direction:column;gap:0;align-items:stretch;background:var(--bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm)}
  .nav-mid.open a:not(.btn){padding:16px 22px;border-bottom:1px solid var(--border)}
  .nav-mid.open > .btn-primary{display:flex;margin:16px 22px;justify-content:center}
  .hero{padding:128px 0 74px}
  .subhero{padding:130px 0 60px}
  .svc-grid,.tiers.cols-2,.tiers.cols-3,.feature-grid,.peering-grid{grid-template-columns:1fr}
  .cap-cards{grid-template-columns:1fr}
  .hero-cta .btn,.subhero .actions .btn{flex:1;justify-content:center}
  .contact-emails{grid-template-columns:1fr;gap:14px}
  .prose .toc ol{column-count:1}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
  .foot-brand{grid-column:1/-1}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none;filter:none}
  .load,.load-right,.globe,.net-panel{opacity:1}
}
