:root{
  --bg:#05070f;
  --bg-2:#0a0f1f;
  --panel:rgba(255,255,255,.04);
  --panel-brd:rgba(255,255,255,.09);
  --txt:#e8edf7;
  --muted:#8c97b0;
  --muted-2:#697590;
  --cyan:#22d3ee;
  --blue:#3b82f6;
  --violet:#8b5cf6;
  --grad:linear-gradient(120deg,#22d3ee,#3b82f6 55%,#8b5cf6);
  --glow:0 0 40px rgba(59,130,246,.35);
  --maxw:1180px;
  /* themeable surfaces */
  --header-bg:rgba(5,7,15,.78);
  --menu-bg:rgba(5,7,15,.97);
  --hairline:rgba(255,255,255,.06);
  --hairline-soft:rgba(255,255,255,.05);
  --hairline-2:rgba(255,255,255,.07);
  --surface-faint:rgba(255,255,255,.03);
  --overlay:rgba(3,5,12,.7);
  --tip-bg:rgba(8,12,24,.94);
  --glass:rgba(8,12,24,.7);
  --input-bg:rgba(5,7,15,.55);
  --contact-bg:rgba(5,7,15,.45);
  --label-stroke:rgba(5,7,15,.85);
  --map-dot:rgba(150,185,235,.62);
  --hub:#ffffff;
  --hero-fade:var(--bg);
  --sel:rgba(34,211,238,.28);
  color-scheme:dark;
}
:root[data-theme="light"]{
  --bg:#f7f9fd;
  --bg-2:#eef2f9;
  --panel:rgba(18,38,74,.035);
  --panel-brd:rgba(18,38,74,.12);
  --txt:#101a2e;
  --muted:#5a667e;
  --muted-2:#6b7791;
  --cyan:#0e93b0;
  --blue:#2563eb;
  --violet:#7c3aed;
  --grad:linear-gradient(120deg,#0ea5b8,#2563eb 55%,#7c3aed);
  --glow:0 8px 30px rgba(37,99,235,.18);
  --header-bg:rgba(247,249,253,.82);
  --menu-bg:rgba(247,249,253,.98);
  --hairline:rgba(18,38,74,.10);
  --hairline-soft:rgba(18,38,74,.08);
  --hairline-2:rgba(18,38,74,.12);
  --surface-faint:rgba(18,38,74,.04);
  --overlay:rgba(20,30,55,.35);
  --tip-bg:rgba(255,255,255,.96);
  --glass:rgba(255,255,255,.78);
  --input-bg:rgba(255,255,255,.8);
  --contact-bg:rgba(255,255,255,.7);
  --label-stroke:rgba(255,255,255,.92);
  --map-dot:rgba(40,82,150,.5);
  --hub:#1d4ed8;
  --hero-fade:var(--bg);
  --sel:rgba(37,99,235,.2);
  color-scheme:light;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"PingFang SC","Hiragino Sans GB","Microsoft YaHei","Segoe UI",system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--txt);
  line-height:1.75;
  letter-spacing:.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--sel)}
a{color:inherit;text-decoration:none}
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
/* latin/number runs inside CJK get a touch of breathing room & tabular figures */
.nw{white-space:nowrap}
.eyebrow{
  display:inline-block;font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--cyan);font-weight:600;margin-bottom:16px;
}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--cyan);vertical-align:middle;margin-right:10px;opacity:.7}
h2.title{font-size:clamp(28px,3.8vw,46px);font-weight:800;letter-spacing:-.01em;line-height:1.25;text-wrap:balance}
.lead{color:var(--muted);max-width:64ch;margin-top:18px;font-size:17px;line-height:1.8;text-wrap:pretty}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ===== NAV ===== */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:.35s ease}
header.scrolled{background:var(--header-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--panel-brd)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;font-size:19px;letter-spacing:.5px}
.brand .mark{width:38px;height:38px;border-radius:11px;background:var(--grad);display:grid;place-items:center;box-shadow:var(--glow);position:relative;overflow:hidden;flex:none}
.brand .mark svg{width:22px;height:22px}
.brand small{display:block;font-size:11px;font-weight:500;color:var(--muted);letter-spacing:.18em}
.nav-links{display:flex;gap:23px;align-items:center}
.nav-links a{font-size:14.5px;color:var(--muted);font-weight:500;transition:.25s;position:relative;white-space:nowrap}
.nav-links a:hover{color:var(--txt)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--grad);transition:.3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.user-btn{display:inline-flex;align-items:center;gap:9px;padding:10px 20px;border-radius:999px;font-weight:600;font-size:14.5px;background:var(--grad);color:#fff;box-shadow:var(--glow);transition:.3s;position:relative}
.user-btn:hover{transform:translateY(-2px);box-shadow:0 8px 34px rgba(59,130,246,.55)}
.user-btn svg{width:17px;height:17px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--txt);border-radius:2px;transition:.3s}
.theme-toggle{width:40px;height:40px;border-radius:11px;border:1px solid var(--panel-brd);background:var(--panel);
  color:var(--txt);display:grid;place-items:center;cursor:pointer;transition:.25s;flex:none;backdrop-filter:blur(8px)}
.theme-toggle:hover{border-color:var(--cyan);color:var(--cyan)}
.theme-toggle svg{width:19px;height:19px}
.theme-toggle .ico-sun{display:none}
:root[data-theme="light"] .theme-toggle .ico-sun{display:block}
:root[data-theme="light"] .theme-toggle .ico-moon{display:none}

/* ===== HERO ===== */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:74px}
#net-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 70% 60% at 70% 30%,rgba(59,130,246,.18),transparent 60%),
             radial-gradient(ellipse 50% 50% at 15% 80%,rgba(139,92,246,.14),transparent 60%),
             linear-gradient(180deg,transparent 60%,var(--bg));
  pointer-events:none}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:9px;padding:7px 16px;border-radius:999px;background:var(--panel);border:1px solid var(--panel-brd);font-size:13.5px;color:var(--muted);backdrop-filter:blur(8px);margin-bottom:26px}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#22d3ee;box-shadow:0 0 12px #22d3ee;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{font-size:clamp(38px,6.2vw,74px);font-weight:850;line-height:1.14;letter-spacing:-.02em;max-width:18ch}
.hero h1 .grad-text{margin-right:.04em}
.hero p.sub{color:var(--muted);font-size:clamp(16px,1.45vw,19px);margin-top:22px;max-width:46ch;line-height:1.85;text-wrap:pretty}
.hero p.sub-spec{margin-top:12px;color:var(--muted)}
.hero p.sub .hl{color:var(--txt);font-weight:500;white-space:nowrap}
.hero p.sub .hl em{font-style:normal;font-weight:700;color:var(--cyan);font-variant-numeric:tabular-nums;letter-spacing:.01em}
.dot-sep{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--cyan);opacity:.7;margin:0 12px;vertical-align:middle}
.hero-actions{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:12px;font-weight:600;font-size:15.5px;transition:.3s;cursor:pointer}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(59,130,246,.5)}
.btn-ghost{background:var(--panel);border:1px solid var(--panel-brd);color:var(--txt)}
.btn-ghost:hover{border-color:var(--cyan);background:rgba(34,211,238,.08)}
.btn-wechat{background:linear-gradient(120deg,#22c55e,#16a34a);color:#fff;border:none;font-family:inherit;box-shadow:0 0 30px rgba(34,197,94,.35)}
.btn-wechat:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(34,197,94,.5)}
.btn-wechat svg{width:18px;height:18px}

/* ===== WECHAT QR MODAL ===== */
.qr-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;
  background:var(--overlay);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:.3s}
.qr-overlay.open{opacity:1;visibility:visible}
.qr-card{position:relative;width:min(360px,92vw);background:linear-gradient(180deg,var(--bg-2),var(--bg));
  border:1px solid var(--panel-brd);border-radius:24px;padding:34px 30px 28px;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.45);transform:scale(.9) translateY(20px);transition:.35s cubic-bezier(.2,.8,.2,1)}
.qr-overlay.open .qr-card{transform:none}
.qr-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--muted);font-size:28px;line-height:1;cursor:pointer;transition:.25s}
.qr-close:hover{color:var(--txt);transform:rotate(90deg)}
.qr-card h3{font-size:20px;font-weight:800}
.qr-sub{color:var(--muted);font-size:14px;margin-top:6px}
.qr-img{margin:22px auto 16px;width:230px;max-width:72vw;border-radius:16px;overflow:hidden;background:#fff;padding:8px;box-shadow:var(--glow)}
.qr-img img{width:100%;height:auto;display:block;border-radius:10px}
.qr-tip{color:var(--muted);font-size:13px}
.hero-stats{display:flex;gap:clamp(28px,4vw,52px);margin-top:64px;flex-wrap:wrap}
.hero-stats .stat .num{font-size:clamp(32px,3.4vw,46px);font-weight:850;line-height:1;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.hero-stats .stat .lbl{color:var(--muted);font-size:14px;margin-top:10px;letter-spacing:.02em}

/* ===== SECTION SHELL ===== */
.sec{padding:110px 0}
.sec-head{margin-bottom:54px;max-width:780px}
.reveal{opacity:0;transform:translateY(34px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===== TRIPLE NETWORK ===== */
.triple{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.triple-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.carrier-row{display:flex;gap:18px;margin:30px 0}
.carrier{flex:1;text-align:center;padding:22px 12px;border-radius:16px;background:var(--panel);border:1px solid var(--panel-brd);transition:.35s}
.carrier:hover{transform:translateY(-6px);border-color:var(--cyan);box-shadow:var(--glow)}
.carrier b{font-size:22px;display:block;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.carrier span{font-size:12.5px;color:var(--muted)}
.triple-points li{list-style:none;padding:13px 0 13px 34px;position:relative;color:var(--muted);border-bottom:1px solid var(--hairline-soft)}
.triple-points li::before{content:"";position:absolute;left:0;top:18px;width:18px;height:18px;border-radius:6px;background:var(--grad);box-shadow:var(--glow)}
.triple-points li b{color:var(--txt)}
.net-diagram{position:relative;aspect-ratio:1;display:grid;place-items:center}
.net-diagram svg{width:100%;height:100%;overflow:visible}
.ring{fill:none;stroke:var(--hairline-2);stroke-width:1}
.orbit-dot{fill:var(--cyan);filter:drop-shadow(0 0 6px var(--cyan))}
.core-label{font:700 15px/1 "PingFang SC",sans-serif;fill:#fff;text-anchor:middle}

/* ===== CORE BUSINESS TABS ===== */
.tabs{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:38px}
.tab{padding:14px 26px;border-radius:14px;border:1px solid var(--panel-brd);background:var(--panel);cursor:pointer;font-weight:600;font-size:16px;color:var(--muted);transition:.3s;display:flex;align-items:center;gap:11px}
.tab .ti{width:24px;height:24px;color:var(--cyan)}
.tab.active{color:#fff;border-color:transparent;background:var(--grad);box-shadow:var(--glow)}
.tab.active .ti{color:#fff}
.panel{display:none;animation:fade .5s ease}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{padding:28px 24px;border-radius:18px;background:var(--panel);border:1px solid var(--panel-brd);transition:.35s;position:relative;overflow:hidden}
.feat::before{content:"";position:absolute;inset:0;background:var(--grad);opacity:0;transition:.35s;z-index:0}
.feat:hover{transform:translateY(-6px);border-color:transparent}
.feat:hover::before{opacity:.12}
.feat .ic{width:46px;height:46px;border-radius:12px;background:rgba(34,211,238,.12);display:grid;place-items:center;margin-bottom:16px;position:relative;z-index:1;font-size:22px}
.feat h4{font-size:18px;position:relative;z-index:1}
.feat p{color:var(--muted);font-size:14.5px;margin-top:8px;position:relative;z-index:1}

/* ===== GLOBAL MAP ===== */
.map-wrap{background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.map-stage{position:relative;border-radius:24px;border:1px solid var(--panel-brd);background:radial-gradient(ellipse at 50% 38%,rgba(59,130,246,.12),transparent 70%),var(--panel);padding:24px;overflow:hidden}
.map-canvas-box{position:relative;width:100%;aspect-ratio:1000 / 372}
#mapdots{position:absolute;inset:0;width:100%;height:100%;display:block}
.map-svg{position:absolute;inset:0;width:100%;height:100%;display:block;overflow:visible}
/* network arcs */
.arc{fill:none;stroke:url(#arcg);stroke-width:1.2;stroke-linecap:round;
  stroke-dasharray:6 7;opacity:.85;animation:arcflow 3.2s linear infinite}
@keyframes arcflow{to{stroke-dashoffset:-26}}
/* PoP markers */
.pop{cursor:pointer}
.pop circle.core{fill:var(--cyan);filter:drop-shadow(0 0 5px var(--cyan))}
.pop circle.halo{fill:var(--cyan);opacity:.25;transform-origin:center;transform-box:fill-box;animation:ripple 3s infinite ease-out}
.pop.hub circle.core{fill:var(--hub);filter:drop-shadow(0 0 7px var(--cyan))}
.pop.hub circle.halo{fill:var(--hub);opacity:.35}
@keyframes ripple{0%{transform:scale(.6);opacity:.5}100%{transform:scale(3.2);opacity:0}}
.pop:hover circle.core{fill:var(--hub)}
.pop text{font:600 12px/1 "PingFang SC",sans-serif;fill:var(--txt);opacity:0;transition:.2s;
  paint-order:stroke;stroke:var(--label-stroke);stroke-width:3px;stroke-linejoin:round}
.pop.hub text{opacity:.95;font-weight:700}
.pop:hover text{opacity:1}
.map-legend{display:flex;gap:30px;flex-wrap:wrap;margin-top:26px;color:var(--muted);font-size:14px}
.map-legend b{color:var(--txt)}
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.region{padding:24px;border-radius:16px;background:var(--panel);border:1px solid var(--panel-brd);transition:.3s}
.region:hover{border-color:var(--cyan);transform:translateY(-4px)}
.region h4{font-size:17px;margin-bottom:6px}
.region h4 .tag{font-size:11px;color:var(--cyan);border:1px solid rgba(34,211,238,.4);padding:2px 9px;border-radius:999px;margin-left:8px;vertical-align:middle}
.region p{color:var(--muted);font-size:14px}

/* ===== SOLUTIONS ===== */
.sol-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.sol{padding:34px;border-radius:20px;background:var(--panel);border:1px solid var(--panel-brd);transition:.35s;position:relative;overflow:hidden}
.sol:hover{transform:translateY(-6px);box-shadow:var(--glow);border-color:rgba(34,211,238,.4)}
.sol .pill{display:inline-block;font-size:12px;color:var(--cyan);background:rgba(34,211,238,.1);padding:5px 13px;border-radius:999px;margin-bottom:14px;font-weight:600}
.sol h3{font-size:21px}
.sol ul{margin-top:16px}
.sol li{list-style:none;color:var(--muted);font-size:14.5px;padding:7px 0 7px 26px;position:relative}
.sol li::before{content:"✓";position:absolute;left:0;color:var(--cyan);font-weight:700}

/* ===== TECH & PROCESS ===== */
.tech-wrap{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tech-card{padding:30px 26px;border-radius:18px;background:var(--panel);border:1px solid var(--panel-brd);transition:.35s;position:relative;overflow:hidden}
.tech-card:hover{transform:translateY(-6px);border-color:rgba(34,211,238,.4);box-shadow:var(--glow)}
.tech-card .tn{font-size:30px;font-weight:850;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;opacity:.85}
.tech-card h4{font-size:18px;margin:6px 0 8px}
.tech-card p{color:var(--muted);font-size:14.5px}
.process-title{font-size:24px;font-weight:800;margin:64px 0 30px;text-align:center}
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative}
.process::before{content:"";position:absolute;top:22px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.5),transparent)}
.step{text-align:center;position:relative;padding:0 6px}
.step .dot{width:46px;height:46px;margin:0 auto 16px;border-radius:50%;background:var(--bg-2);border:2px solid var(--cyan);color:var(--cyan);display:grid;place-items:center;font-weight:800;font-size:18px;position:relative;z-index:1;transition:.35s}
.step:hover .dot{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--glow);transform:scale(1.12)}
.step h5{font-size:15.5px;margin-bottom:8px}
.step p{color:var(--muted);font-size:13.5px;line-height:1.55}

/* ===== CLIENTS ===== */
.clients{background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.client-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cc{padding:30px;border-radius:18px;background:var(--panel);border:1px solid var(--panel-brd);transition:.4s;position:relative;overflow:hidden}
.cc::after{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:.4s}
.cc:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,.4)}
.cc:hover::after{transform:scaleX(1)}
.cc .cnum{font-size:30px;font-weight:850;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.cc h4{font-size:18px;margin:6px 0 10px}
.cc p{color:var(--muted);font-size:14px}

/* ===== GUARANTEE ===== */
.guard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.guard{text-align:center;padding:30px 18px;border-radius:18px;background:var(--panel);border:1px solid var(--panel-brd);transition:.3s}
.guard:hover{transform:translateY(-6px);border-color:var(--cyan)}
.guard .big{font-size:38px;font-weight:850;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.guard p{color:var(--muted);font-size:14px;margin-top:8px}

/* ===== CONTACT / CTA ===== */
.cta-band{margin:0 24px 100px}
.cta-inner{max-width:var(--maxw);margin:0 auto;border-radius:28px;padding:64px 50px;text-align:center;position:relative;overflow:hidden;background:linear-gradient(120deg,rgba(34,211,238,.14),rgba(139,92,246,.14));border:1px solid var(--panel-brd)}
.cta-inner h2{font-size:clamp(28px,4vw,42px);font-weight:850}
.cta-inner p{color:var(--muted);margin:16px auto 36px;max-width:520px}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:880px;margin:0 auto;text-align:left}
.contact-card{padding:26px;border-radius:18px;background:var(--contact-bg);border:1px solid var(--panel-brd);transition:.35s;display:block}
.contact-card:hover{transform:translateY(-5px);border-color:var(--cyan);box-shadow:var(--glow)}
.contact-card .ci{font-size:24px}
.contact-card .ck{display:block;color:var(--muted);font-size:13px;margin:12px 0 6px;letter-spacing:.05em}
.contact-card b{display:block;font-size:19px;font-weight:800}
.contact-card .cs{display:block;color:var(--muted);font-size:13px;margin-top:6px}
.contact-card .phone-line{display:block;font-size:19px;font-weight:800;color:var(--txt);line-height:1.5;transition:.2s;white-space:nowrap}
.contact-card .phone-line:hover{color:var(--cyan)}

/* ===== FOOTER ===== */
footer{padding:70px 0 40px;border-top:1px solid var(--panel-brd);background:var(--bg-2)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot-grid h5{font-size:14px;letter-spacing:.06em;margin-bottom:16px;color:var(--txt)}
.foot-grid a,.foot-grid p{display:block;color:var(--muted);font-size:14px;padding:5px 0;transition:.25s}
.foot-grid a:hover{color:var(--cyan)}
.foot-bottom{border-top:1px solid var(--hairline);margin-top:46px;padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:var(--muted);font-size:13px}
.foot-bottom .beian{color:var(--muted);transition:.25s}
.foot-bottom .beian:hover{color:var(--cyan)}
/* legal / disclaimer */
.foot-legal{margin-top:42px;padding-top:30px;border-top:1px solid var(--hairline)}
.foot-legal h6{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--muted);margin-bottom:14px;text-transform:none}
.foot-legal ol{margin:0;padding-left:20px;columns:2;column-gap:48px}
.foot-legal li{color:var(--muted-2);font-size:12px;line-height:1.7;margin-bottom:9px;break-inside:avoid;text-wrap:pretty}
.foot-legal li:last-child{column-span:all;border-top:1px dashed var(--hairline-2);padding-top:12px;margin-top:6px;color:var(--muted-2)}
@media(max-width:760px){.foot-legal ol{columns:1}}
@media(max-width:620px){
  .map-zoom{right:9px;bottom:9px;gap:5px}
  .map-zoom button{width:28px;height:28px;font-size:15px}
}

/* ===== MAP: zoom / pan / latency tooltip ===== */
.map-canvas-box{cursor:grab;touch-action:none;overflow:hidden;border-radius:14px}
.map-canvas-box.grabbing{cursor:grabbing}
.arc-hit{fill:none;stroke:transparent;stroke-width:16;pointer-events:stroke;cursor:pointer}
.arc.active{stroke:url(#arcg);stroke-width:2.4;stroke-dasharray:none;opacity:1;filter:drop-shadow(0 0 4px rgba(34,211,238,.8))}
.map-tip{position:absolute;z-index:5;pointer-events:none;transform:translate(-50%,-118%);
  background:var(--tip-bg);border:1px solid rgba(34,211,238,.45);border-radius:11px;
  padding:9px 14px;backdrop-filter:blur(8px);box-shadow:0 10px 30px rgba(0,0,0,.5);
  opacity:0;transition:opacity .18s;white-space:nowrap;text-align:center}
.map-tip.show{opacity:1}
.map-tip b{display:block;font-size:13.5px;font-weight:700;color:var(--txt);letter-spacing:.02em}
.map-tip i{font-style:normal;font-size:18px;font-weight:850;font-variant-numeric:tabular-nums;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.map-tip i small{font-size:12px;font-weight:600;color:var(--muted);-webkit-text-fill-color:var(--muted);margin-left:2px}
.map-tip::after{content:"";position:absolute;left:50%;bottom:-6px;width:11px;height:11px;
  transform:translateX(-50%) rotate(45deg);background:var(--tip-bg);
  border-right:1px solid rgba(34,211,238,.45);border-bottom:1px solid rgba(34,211,238,.45)}
.map-zoom{position:absolute;right:14px;bottom:14px;z-index:5;display:flex;flex-direction:column;gap:6px}
.map-zoom button{width:34px;height:34px;border-radius:9px;border:1px solid var(--panel-brd);
  background:var(--glass);backdrop-filter:blur(8px);color:var(--txt);font-size:18px;line-height:1;
  cursor:pointer;transition:.2s;display:grid;place-items:center}
.map-zoom button:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(34,211,238,.1)}
.map-zoom button:active{transform:scale(.92)}
/* view tabs */
.map-tabs{display:inline-flex;gap:4px;margin-bottom:18px;padding:4px;border-radius:13px;background:var(--panel);border:1px solid var(--panel-brd)}
.map-tabs button{padding:9px 22px;border:none;border-radius:9px;background:transparent;color:var(--muted);font-family:inherit;font-size:14.5px;font-weight:600;cursor:pointer;transition:.25s}
.map-tabs button:hover{color:var(--txt)}
.map-tabs button.active{background:var(--grad);color:#fff;box-shadow:var(--glow)}
.map-legend:empty{display:none}
.map-legend span.cn-note{color:var(--muted)}
/* latency calculator */
.lat-calc{margin-top:22px;padding:24px 26px;border-radius:18px;background:var(--panel);border:1px solid var(--panel-brd)}
.lat-calc-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.lat-calc-head h4{font-size:17px;font-weight:700}
.lat-calc-head span{font-size:13px;color:var(--muted)}
.lat-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.lat-row select{appearance:none;-webkit-appearance:none;background:var(--input-bg) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238c97b0' stroke-width='3'><path d='M6 9l6 6 6-6' stroke-linecap='round' stroke-linejoin='round'/></svg>") no-repeat right 14px center;
  border:1px solid var(--panel-brd);border-radius:12px;color:var(--txt);font-family:inherit;font-size:15px;font-weight:600;
  padding:12px 38px 12px 16px;min-width:130px;cursor:pointer;transition:.25s}
.lat-row select:hover,.lat-row select:focus{border-color:var(--cyan);outline:none}
.lat-swap{display:grid;place-items:center;width:38px;height:38px;border-radius:10px;border:1px solid var(--panel-brd);
  background:var(--panel);color:var(--cyan);font-size:17px;cursor:pointer;transition:.25s;flex:none}
.lat-swap:hover{border-color:var(--cyan);background:rgba(34,211,238,.1);transform:rotate(180deg)}
.lat-result{display:flex;align-items:baseline;gap:5px;margin-left:auto;padding:8px 20px;border-radius:12px;
  background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.25)}
.lat-result span{font-size:32px;font-weight:850;font-variant-numeric:tabular-nums;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lat-result small{font-size:14px;color:var(--muted);font-weight:600}
.lat-path{margin-top:14px;color:var(--muted);font-size:13.5px;line-height:1.7;min-height:1.2em}
.lat-path b{color:var(--cyan);font-weight:600}
.lat-path .hop{color:var(--txt)}
@media(max-width:620px){
  .lat-result{margin-left:0;width:100%;justify-content:center}
  .lat-row select{flex:1;min-width:0}
}

/* ===== NAAS PRODUCT MATRIX ===== */
.naas-wrap{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
/* 控制中台 · 瑶枢 */
.naas-core{
  position:relative;overflow:hidden;border-radius:24px;margin-bottom:26px;
  padding:38px 40px;display:flex;gap:40px;align-items:center;justify-content:space-between;flex-wrap:wrap;
  background:linear-gradient(120deg,rgba(167,139,250,.14),rgba(124,58,237,.06) 60%,transparent);
  border:1px solid rgba(167,139,250,.28);
}
.ncore-glow{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(440px 200px at 14% 30%,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%)}
.naas-core>*{position:relative;z-index:1}
.ncore-left{display:flex;gap:22px;align-items:center;min-width:300px;flex:1 1 360px}
.ncore-right{flex:1 1 360px;max-width:520px}
.ncore-right p{color:var(--muted);line-height:1.8;text-wrap:pretty}
.ncore-badge{display:inline-block;font-size:11.5px;letter-spacing:.18em;font-weight:700;color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);border-radius:999px;padding:5px 13px;margin-bottom:12px}
.naas-core h3{font-size:clamp(28px,3vw,38px);font-weight:850;letter-spacing:.02em;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.ncore-type{font-size:15px;font-weight:500;color:var(--muted);letter-spacing:0}
/* product grid */
.naas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.naas-card{
  position:relative;overflow:hidden;border-radius:20px;padding:30px 28px 26px;
  background:var(--panel);border:1px solid var(--panel-brd);transition:.4s cubic-bezier(.2,.7,.2,1);
}
.naas-card .nc-bar{position:absolute;top:0;left:0;right:0;height:3px;border-radius:20px 20px 0 0;
  background:linear-gradient(90deg,var(--accent),var(--accent2));transform:scaleX(0);transform-origin:left;transition:.45s}
.naas-card::after{content:"";position:absolute;inset:0;z-index:0;opacity:0;transition:.4s;
  background:radial-gradient(420px 220px at 88% -10%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 70%)}
.naas-card:hover{transform:translateY(-8px);border-color:color-mix(in srgb,var(--accent) 42%,transparent);
  box-shadow:0 24px 60px -22px color-mix(in srgb,var(--accent) 60%,transparent)}
.naas-card:hover .nc-bar{transform:scaleX(1)}
.naas-card:hover::after{opacity:1}
.naas-card>*{position:relative;z-index:1}
.nc-top{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.nc-icon{flex:none;width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  color:var(--accent);background:color-mix(in srgb,var(--accent) 13%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);transition:.4s}
.nc-icon svg{width:26px;height:26px}
.nc-icon.big{width:74px;height:74px;border-radius:20px}
.nc-icon.big svg{width:38px;height:38px}
.naas-card:hover .nc-icon{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;
  border-color:transparent;box-shadow:0 0 26px -4px color-mix(in srgb,var(--accent) 70%,transparent)}
.nc-title h3,.naas-card h3{font-size:23px;font-weight:850;letter-spacing:.04em;line-height:1.1;
  background:linear-gradient(120deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.nc-type{display:block;font-size:13px;color:var(--muted);margin-top:5px;letter-spacing:.01em}
.nc-slogan{font-family:"Songti SC","STSong","SimSun",serif;font-size:18.5px;font-weight:600;letter-spacing:.06em;
  color:var(--txt);margin:4px 0 14px;position:relative;padding-left:14px}
.nc-slogan::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent2))}
.nc-desc{color:var(--muted);font-size:14.5px;line-height:1.7;text-wrap:pretty}
.nc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.nc-tags span{font-size:12.5px;font-weight:500;padding:5px 12px;border-radius:999px;
  color:color-mix(in srgb,var(--accent) 70%,#fff);
  background:color-mix(in srgb,var(--accent) 11%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 22%,transparent)}

/* ===== QUALIFICATIONS & COMPLIANCE ===== */
.quals-wrap{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.quals-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:stretch}
.quals-info{display:flex;flex-direction:column}
.qual-lic{padding:26px 28px;border-radius:18px 18px 0 0;background:var(--panel);border:1px solid var(--panel-brd);border-bottom:none}
.qual-no{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--cyan);
  border:1px solid color-mix(in srgb,var(--cyan) 40%,transparent);border-radius:999px;padding:5px 13px;margin-bottom:14px}
.qual-lic h3{font-size:clamp(20px,2.4vw,27px);font-weight:850;line-height:1.25}
.qual-meta{margin-top:18px;list-style:none}
.qual-meta li{display:flex;gap:14px;padding:9px 0;border-top:1px solid var(--hairline);font-size:14.5px}
.qual-meta li span{flex:none;width:84px;color:var(--muted)}
.qual-meta li b{color:var(--txt);font-weight:600}
.qual-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--panel-brd);
  border:1px solid var(--panel-brd);border-top:none}
.qbadge{display:flex;align-items:center;gap:12px;padding:16px 16px;background:var(--bg-2)}
.qbadge b{flex:none;width:46px;height:46px;border-radius:11px;display:grid;place-items:center;font-size:14px;font-weight:850;
  color:#fff;background:var(--grad);box-shadow:var(--glow)}
.qbadge span{display:flex;flex-direction:column;font-size:13.5px;font-weight:600;color:var(--txt);line-height:1.3}
.qbadge span small{font-size:11.5px;font-weight:500;color:var(--muted);margin-top:2px}
.qbadge span small.ok{color:#34d399;font-weight:600}
.qbadge.soon b{background:var(--surface-faint);color:var(--muted);box-shadow:none;border:1px dashed var(--panel-brd)}
.qbadge.soon span{color:var(--muted)}
.qual-foot{margin-top:16px;color:var(--muted);font-size:13px;line-height:1.7;text-wrap:pretty}
/* gallery */
.quals-gallery{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-content:start}
.cert{margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--panel-brd);background:var(--panel);
  cursor:zoom-in;transition:.35s;position:relative}
.cert:hover{transform:translateY(-5px);border-color:var(--cyan);box-shadow:0 18px 44px -18px color-mix(in srgb,var(--cyan) 55%,transparent)}
.cert img{width:100%;height:auto;display:block;aspect-ratio:3/4;object-fit:cover;object-position:top}
.cert figcaption{padding:12px 14px;font-size:13.5px;font-weight:600;color:var(--txt);display:flex;justify-content:space-between;align-items:center}
.cert figcaption span{font-size:12px;font-weight:500;color:var(--cyan)}
/* lightbox */
.lightbox{position:fixed;inset:0;z-index:210;display:flex;align-items:center;justify-content:center;padding:30px;
  background:rgba(3,5,12,.9);backdrop-filter:blur(10px);opacity:0;visibility:hidden;transition:.3s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:min(680px,92vw);max-height:90vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6);
  transform:scale(.96);transition:.3s}
.lightbox.open img{transform:none}
.lightbox-close{position:absolute;top:22px;right:26px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;width:44px;height:44px;border-radius:50%;font-size:26px;line-height:1;cursor:pointer;transition:.25s}
.lightbox-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}

/* ===== TYPOGRAPHY & DETAIL REFINEMENTS ===== */
.feat p,.region p,.cc p,.tech-card p,.step p,.guard p,.sol li,.triple-points li,.contact-card .cs{text-wrap:pretty}
.feat h4,.cc h4,.tech-card h4,.region h4,.sol h3,.step h5{letter-spacing:-.01em}
.feat p,.tech-card p{line-height:1.7}
.region p,.cc p{line-height:1.7}
/* tabular figures for all stat numerals */
.cc .cnum,.guard .big,.tech-card .tn,.carrier b,.contact-card b,.contact-card .phone-line{font-variant-numeric:tabular-nums}
.carrier b{letter-spacing:.02em}
/* gentler dividers + tighter list rhythm */
.triple-points li{line-height:1.6;padding-top:14px;padding-bottom:14px}
.triple-points li:last-child{border-bottom:none}
/* section heads breathe a bit more */
.sec-head .title{margin-top:2px}
/* map legend as neat chips */
.map-legend span{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;background:var(--surface-faint);border:1px solid var(--panel-brd)}
.map-legend b{color:var(--cyan);font-variant-numeric:tabular-nums}
/* solution list spacing */
.sol li{line-height:1.6}
/* footer legibility */
.foot-grid p{line-height:1.7}
.foot-bottom a,.foot-bottom span{line-height:1.7}

/* ===== RESPONSIVE ===== */
/* collapse nav to a menu earlier (8 links) + 2-col NaaS on tablet */
@media(max-width:1024px){
  .nav-links{position:fixed;top:74px;left:0;right:0;flex-direction:column;gap:0;padding:10px 24px 24px;background:var(--menu-bg);backdrop-filter:blur(18px);border-bottom:1px solid var(--panel-brd);transform:translateY(-160%);transition:.4s}
  .nav-links.open{transform:none}
  .nav-links a{padding:14px 0;width:100%;border-bottom:1px solid var(--hairline-soft)}
  .nav-links a::after{display:none}
  .burger{display:flex}
  .naas-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:880px){
  .triple-grid{grid-template-columns:1fr;gap:36px}
  .feat-grid,.region-grid,.client-cards,.tech-grid,.naas-grid,.quals-grid{grid-template-columns:1fr}
  .qual-badges{grid-template-columns:repeat(2,1fr)}
  .naas-core{padding:30px 26px;gap:26px}
  .ncore-left{min-width:0;flex-basis:100%}
  .sol-grid{grid-template-columns:1fr}
  .guard-grid{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:1fr;gap:24px}
  .process::before{top:0;bottom:0;left:22px;right:auto;width:2px;height:auto;background:linear-gradient(180deg,transparent,rgba(34,211,238,.5),transparent)}
  .step{display:grid;grid-template-columns:46px 1fr;column-gap:16px;row-gap:6px;text-align:left;align-items:start}
  .step .dot{margin:0;grid-column:1;grid-row:1 / span 2}
  .step h5{grid-column:2;grid-row:1;align-self:center;margin-bottom:0}
  .step p{grid-column:2;grid-row:2}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .hero-stats{gap:30px}
  .user-btn .lbl{display:none}
  .user-btn{padding:10px 14px}
}
@media(max-width:520px){
  .guard-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
}
