/* MeshDash.co.uk — Complete Design System v2
   Fonts: Exo 2 (headings/UI) + Share Tech Mono (data/code)
   Exact variable parity with the dashboard panel */
:root {
  --bg:#020912; --bg2:#070f1c; --bg3:#0b1929; --bg4:#12243f;
  --bd:#0d2137; --bd2:#1a3455; --bd3:#233f62;
  --acc:#00c8f5; --ok:#00f090; --warn:#ffa800; --err:#ff3050; --pur:#b060ff;
  --txt:#bdd4f0; --txt2:#97c4ff; --txt3:#5a7a9e;
  --mono:'Share Tech Mono','Courier New',monospace;
  --sans:'Exo 2',system-ui,sans-serif;
  --r:6px; --r2:10px; --max:1300px;
  --acc-g:rgba(0,200,245,.2); --ok-g:rgba(0,240,144,.2);
  --warn-g:rgba(255,168,0,.2); --err-g:rgba(255,48,80,.2); --pur-g:rgba(176,96,255,.2);
  --nav-h:60px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--txt);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:'';position:fixed;inset:0;z-index:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.04) 2px,rgba(0,0,0,.04) 4px);pointer-events:none}
a{color:var(--acc);text-decoration:none}
a:hover{text-decoration:underline;color:var(--acc)}
img{max-width:100%}
h1,h2,h3,h4,h5{font-family:var(--sans);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--txt)}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.5vw,3rem)}
h3{font-size:clamp(1rem,2vw,1.35rem);font-weight:700}
h4{font-size:1rem;font-weight:700;letter-spacing:.02em}
em{color:var(--acc);font-style:normal}
strong{color:var(--txt)}
code{font-family:var(--mono);background:rgba(0,200,245,.07);border:1px solid rgba(0,200,245,.15);padding:1px 5px;border-radius:3px;font-size:.88em;color:var(--acc)}
pre{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);padding:16px;overflow-x:auto}
pre code{background:none;border:none;padding:0;font-size:11px;color:var(--ok);line-height:1.7}
p{color:var(--txt2);line-height:1.7}

/* ── NAV ── */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(2,9,18,.94);border-bottom:1px solid var(--bd2);backdrop-filter:blur(20px)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 24px;height:var(--nav-h);display:flex;align-items:center;gap:0}
.nav-brand{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:900;font-size:18px;color:var(--txt);letter-spacing:-.02em;text-decoration:none;margin-right:24px;white-space:nowrap;flex-shrink:0}
.nav-brand:hover{text-decoration:none;color:var(--txt)}
.brand-hex{color:var(--acc);font-size:22px;line-height:1}
.brand-tag{font-family:var(--mono);font-size:8px;color:var(--txt3);border:1px solid var(--bd2);padding:1px 5px;border-radius:3px;letter-spacing:1.5px;margin-left:2px}
.nav-links{display:flex;gap:0;list-style:none;flex:1}
.nav-links li a{display:block;padding:0 14px;height:var(--nav-h);line-height:var(--nav-h);font-size:12px;font-weight:600;color:var(--txt3);border-bottom:2px solid transparent;transition:.2s;text-decoration:none;white-space:nowrap}
.nav-links li a:hover{color:var(--txt);border-bottom-color:rgba(0,200,245,.4);text-decoration:none}
.nav-links li a.active{color:var(--acc);border-bottom-color:var(--acc)}
.nav-links li a.nav-hl{color:var(--acc)}
.nav-actions{display:flex;gap:10px;align-items:center;margin-left:16px}
.btn-ghost{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--bd2);border-radius:var(--r);font-size:12px;font-weight:600;color:var(--txt3);transition:.2s;text-decoration:none;white-space:nowrap}
.btn-ghost:hover{border-color:var(--acc);color:var(--acc);text-decoration:none}
.btn-nav-cta{display:flex;align-items:center;gap:6px;padding:7px 18px;background:var(--acc);border:none;border-radius:var(--r);font-size:12px;font-weight:800;color:#020912;text-decoration:none;white-space:nowrap;transition:.2s;font-family:var(--sans)}
.btn-nav-cta:hover{background:#33d4f8;text-decoration:none;color:#020912}
.nav-hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;margin-left:auto}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--txt);border-radius:1px;transition:.2s}

/* ── SHARED LAYOUT ── */
.page-wrap{padding-top:var(--nav-h);position:relative;z-index:1}
.section{padding:80px 24px;position:relative;z-index:1}
.section-inner{max-width:var(--max);margin:0 auto}
.section--alt{background:var(--bg2);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd)}
.section--dark{background:#010710;border-top:1px solid var(--bd)}
.section-hdr{text-align:center;margin-bottom:56px}
.section-hdr h2{margin-bottom:14px}
.eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--acc);display:block;margin-bottom:12px}
.section-lead{font-size:1.05rem;color:var(--txt2);max-width:640px;margin:0 auto;line-height:1.7;font-weight:300}

/* ── BUTTONS ── */
.btn-hero-p{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--acc);border:none;border-radius:var(--r);font-size:14px;font-weight:800;color:#020912;text-decoration:none;transition:.2s;font-family:var(--sans)}
.btn-hero-p:hover{background:#33d4f8;transform:translateY(-2px);box-shadow:0 8px 30px var(--acc-g);text-decoration:none;color:#020912}
.btn-hero-g{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:transparent;border:1px solid var(--bd2);border-radius:var(--r);font-size:14px;font-weight:600;color:var(--txt);text-decoration:none;transition:.2s}
.btn-hero-g:hover{border-color:var(--acc);color:var(--acc);text-decoration:none}
.btn-acc-sm{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:var(--acc);border:none;border-radius:var(--r);font-size:12px;font-weight:800;color:#020912;text-decoration:none;transition:.2s;font-family:var(--sans);cursor:pointer}
.btn-acc-sm:hover{background:#33d4f8;text-decoration:none;color:#020912}

/* ── CARDS ── */
.card{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r2);padding:24px;position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s,transform .2s}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--bd2);transition:.2s}
.card:hover{border-color:var(--acc);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.card:hover::before{background:var(--acc)}
.card--acc{border-color:rgba(0,200,245,.25)}
.card--acc::before{background:linear-gradient(90deg,var(--acc),var(--ok))}
.card--ok::before{background:var(--ok)}
.card--warn::before{background:var(--warn)}
.card--pur::before{background:var(--pur)}

/* ── DEMO CHROME WRAPPER ── */
.demo-chrome{background:var(--bg);border:1px solid var(--bd2);border-radius:var(--r2);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.demo-chrome-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--bd);user-select:none}
.dcb-dots{display:flex;gap:6px}
.dcb-dots span{width:10px;height:10px;border-radius:50%}
.dcb-dots span:nth-child(1){background:#ff5f57}
.dcb-dots span:nth-child(2){background:#febc2e}
.dcb-dots span:nth-child(3){background:#28c840}
.dcb-url{font-family:var(--mono);font-size:10px;color:var(--txt3);flex:1;text-align:center}
.dcb-live{font-family:var(--mono);font-size:8px;color:var(--ok);border:1px solid rgba(0,240,144,.3);padding:2px 8px;border-radius:3px;letter-spacing:1px;animation:liveblink 2s ease-in-out infinite}
@keyframes liveblink{0%,100%{opacity:1}50%{opacity:.5}}
.demo-chrome-body{padding:16px}
.demo-chrome-body.p0{padding:0}

/* ── PANEL PRIMITIVES (matching dashboard exactly) ── */
.p-card{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r)}
.p-ch{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--bd);font-family:var(--mono);font-size:10px;font-weight:bold;color:var(--acc);letter-spacing:.5px;flex-shrink:0}
.p-cb{padding:12px 14px}
.p-inp{background:var(--bg);border:1px solid var(--bd2);border-radius:3px;color:var(--txt);font-family:var(--mono);font-size:11px;padding:6px 10px;width:100%;outline:none;transition:.15s}
.p-inp:focus{border-color:var(--acc)}
.p-btn{background:var(--bg2);border:1px solid var(--bd2);border-radius:4px;color:var(--txt);font-family:var(--mono);font-size:10px;padding:5px 12px;cursor:pointer;transition:.15s}
.p-btn:hover{border-color:var(--acc);color:var(--acc)}
.p-btn-acc{background:var(--acc);border:none;border-radius:4px;color:#020912;font-family:var(--sans);font-size:11px;font-weight:800;padding:7px 16px;cursor:pointer;transition:.15s}
.p-btn-acc:hover{background:#33d4f8}
.p-tog{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9px;color:var(--txt3);cursor:pointer}
.tog-track{width:32px;height:16px;background:var(--bd2);border-radius:8px;position:relative;transition:.2s}
.tog-thumb{position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:var(--txt3);transition:.2s}
input:checked + .tog-track{background:rgba(0,200,245,.3);border:1px solid var(--acc)}
input:checked + .tog-track .tog-thumb{left:16px;background:var(--acc)}

/* ── TOPBAR DEMO REPLICA ── */
.topbar-demo{display:flex;align-items:center;padding:8px 16px;background:var(--bg);border-bottom:1px solid var(--bd2);gap:12px}
.topbar-brand{font-family:var(--sans);font-weight:900;font-size:13px;color:var(--txt);letter-spacing:-.01em;flex-shrink:0}
.topbar-brand em{color:var(--acc);font-style:normal}
.rmd-widget{display:flex;align-items:stretch;border:1px solid var(--bd2);background:var(--bg2);border-radius:4px;font-family:var(--mono);font-size:9px;gap:0;cursor:pointer;transition:.15s;overflow:hidden}
.rmd-widget:hover{border-color:var(--acc)}
.rmd-sec{display:flex;flex-direction:column;justify-content:center;padding:5px 10px;border-right:1px solid var(--bd);min-width:0}
.rmd-sec:last-child{border-right:none}
.rmd-nid{color:var(--acc);font-weight:bold;font-size:11px;white-space:nowrap}
.rmd-nmeta{color:var(--txt3);font-size:8px;margin-top:1px}
.rmd-stats{display:flex;gap:10px}
.rmd-stat{display:flex;align-items:center;gap:4px;color:var(--txt3)}
.rmd-stat .n{color:var(--txt);font-weight:bold}
.rmd-dots{display:flex;flex-direction:column;gap:3px}
.rmd-row{display:flex;align-items:center;gap:5px}
.rmd-dot{width:6px;height:6px;border-radius:50%;background:var(--bd2);transition:.3s;flex-shrink:0}
.rmd-dot.on{background:var(--ok);box-shadow:0 0 5px var(--ok);animation:blink 2s ease-in-out infinite}
.rmd-dot.lg{width:8px;height:8px}
.rmd-lbl{font-size:7px;color:var(--txt3);width:24px}
.rmd-val{font-size:9px}
.rmd-val.ok{color:var(--ok)}
.io-group{display:flex;gap:8px}
.io-row{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:7px;color:var(--txt3);letter-spacing:.5px}
.io-led{width:7px;height:7px;border-radius:50%;background:var(--bd2);transition:.1s}
.io-led.tx-flash{background:var(--warn);box-shadow:0 0 5px var(--warn)}
.io-led.rx-flash{background:var(--ok);box-shadow:0 0 5px var(--ok)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* sidebar demo replica */
.sidebar-demo{width:160px;background:var(--bg);border-right:1px solid var(--bd);flex-shrink:0;display:flex;flex-direction:column;padding:8px 0}
.nsec-demo{font-family:var(--mono);font-size:7px;color:var(--txt3);letter-spacing:2px;text-transform:uppercase;padding:10px 12px 4px}
.ni-demo{display:flex;align-items:center;gap:8px;padding:7px 12px;font-family:var(--mono);font-size:10px;color:var(--txt3);cursor:pointer;transition:.15s;border-left:2px solid transparent}
.ni-demo:hover{color:var(--txt);background:rgba(0,200,245,.04);border-left-color:rgba(0,200,245,.3)}
.ni-demo.active{color:var(--acc);background:rgba(0,200,245,.08);border-left-color:var(--acc)}
.ni-ico{font-size:11px}

/* ── KPI STRIP ── */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.kpi-cell{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);padding:10px 14px;position:relative;overflow:hidden}
.kpi-cell::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--kc,var(--acc));box-shadow:0 0 8px var(--kc,var(--acc))}
.kpi-val{font-family:var(--mono);font-size:22px;font-weight:900;color:var(--kc,var(--acc));line-height:1;margin-bottom:3px}
.kpi-lbl{font-family:var(--mono);font-size:7px;color:var(--txt3);letter-spacing:1.5px;text-transform:uppercase}

/* ── NODE CARD REPLICA ── */
.nc{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);padding:10px;cursor:pointer;transition:.18s;position:relative;overflow:visible;display:flex;flex-direction:column;gap:7px}
.nc::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--nc-col,var(--bd2));border-radius:var(--r) 0 0 var(--r);transition:.18s}
.nc:hover{border-color:var(--nc-col,var(--acc));transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,0,0,.5)}
.nc.local{border-color:rgba(0,240,144,.25)}
.nc.local::before{background:var(--ok)}
.nc-head{display:flex;align-items:flex-start;gap:8px;padding-left:6px}
.nc-av{width:32px;height:32px;border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;font-family:var(--mono);color:#060b12;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.nc-role{position:absolute;bottom:-3px;right:-3px;width:13px;height:13px;border-radius:50%;background:var(--bg2);border:1px solid var(--bd2);font-size:6px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);color:var(--txt3)}
.nc-meta{flex:1;min-width:0}
.nc-name{font-size:11px;font-weight:700;font-family:var(--mono);color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nc-sub{font-size:8px;color:var(--txt3);font-family:var(--mono);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nc-st{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}
.online-dot{width:6px;height:6px;border-radius:50%}
.online-dot.on{background:var(--ok);box-shadow:0 0 5px var(--ok);animation:blink 2.5s ease-in-out infinite}
.online-dot.off{background:var(--bd2)}
.nc-heard{font-size:8px;font-family:var(--mono);color:var(--txt3)}
.bat-row{display:flex;justify-content:space-between;margin-bottom:2px;padding:0 6px}
.bat-lbl{font-size:7px;color:var(--txt3);font-family:var(--mono)}
.bat-val{font-size:8px;font-family:var(--mono);font-weight:bold}
.bat-track{height:4px;background:var(--bg);border-radius:2px;overflow:hidden;border:1px solid var(--bd);margin:0 6px}
.bat-fill{height:100%;border-radius:2px;transition:width .5s}
.nc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:0 6px}
.nc-cell{background:var(--bg);border:1px solid var(--bd);border-radius:3px;padding:5px 6px}
.nc-cell-lbl{font-size:7px;color:var(--txt3);font-family:var(--mono);letter-spacing:.3px;margin-bottom:1px}
.nc-cell-val{font-size:10px;font-weight:bold;font-family:var(--mono)}
.nc-foot{display:flex;align-items:center;gap:6px;padding:4px 6px;border-top:1px solid var(--bd)}
.src-badge{font-family:var(--mono);font-size:7px;font-weight:bold;padding:2px 5px;border-radius:2px}
.src-rf{background:rgba(0,240,144,.1);color:var(--ok);border:1px solid rgba(0,240,144,.2)}
.src-mqtt{background:rgba(255,168,0,.1);color:var(--warn);border:1px solid rgba(255,168,0,.2)}
.src-local{background:rgba(0,200,245,.1);color:var(--acc);border:1px solid rgba(0,200,245,.2)}
.sig-bars{display:flex;gap:2px;align-items:flex-end;height:12px}
.sig-bar{width:3px;border-radius:1px;background:var(--bd2);transition:.2s}
.sig-bar.lit{background:var(--nc-col,var(--acc))}
.dm-btn{margin-left:auto;background:none;border:1px solid var(--bd2);border-radius:3px;color:var(--txt3);font-size:8px;padding:2px 7px;cursor:pointer;transition:.15s;font-family:var(--mono)}
.dm-btn:hover{border-color:var(--acc);color:var(--acc)}

/* ── MSG BUBBLES ── */
.msg-bubble{max-width:70%;padding:10px 14px;border-radius:8px;font-size:12px;line-height:1.5;position:relative}
.msg-out{align-self:flex-end;background:rgba(0,200,245,.12);border:1px solid rgba(0,200,245,.2);color:var(--txt)}
.msg-in{align-self:flex-start;background:var(--bg2);border:1px solid var(--bd2);color:var(--txt)}
.msg-meta{font-family:var(--mono);font-size:8px;color:var(--txt3);margin-top:4px;display:flex;align-items:center;gap:6px}
.msg-status{font-family:var(--mono);font-size:8px;padding:1px 5px;border-radius:2px}
.msg-delivered{color:var(--ok);border:1px solid rgba(0,240,144,.2)}
.msg-sent{color:var(--warn);border:1px solid rgba(255,168,0,.2)}
.msg-failed{color:var(--err);border:1px solid rgba(255,48,80,.2)}

/* ── SHARK TABLE ── */
.shark-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:9px;table-layout:fixed}
.shark-table th{position:sticky;top:0;background:var(--bg2);color:var(--txt3);padding:6px 8px;text-align:left;border-bottom:1px solid var(--bd);white-space:nowrap;cursor:pointer;z-index:1}
.shark-table th:hover{color:var(--acc)}
.shark-table td{padding:3px 8px;border-bottom:1px solid rgba(255,255,255,.025);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.shark-table tr{cursor:pointer;transition:.08s}
.shark-table tr:hover{background:rgba(255,255,255,.03)}
.shark-table tr.sel{background:rgba(0,200,245,.1)}
.pt-msg{color:var(--ok);font-weight:bold}
.pt-pos{color:var(--warn);font-weight:bold}
.pt-tlm{color:var(--pur);font-weight:bold}
.pt-nfo{color:var(--acc);font-weight:bold}
.pt-ack{color:var(--txt3)}
.pill-bar{display:flex;gap:5px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:14px;border:1px solid var(--bd);background:var(--bg);font-family:var(--mono);font-size:8px;font-weight:bold;color:var(--txt3);cursor:pointer;transition:.15s}
.pill:hover{border-color:var(--acc);color:var(--txt)}
.pill.active{background:rgba(0,200,245,.1);border-color:var(--acc);color:var(--acc)}
.pill-cnt{background:rgba(0,0,0,.5);padding:1px 5px;border-radius:6px;color:var(--txt)}

/* ── TRACEROUTE HOP CHAIN ── */
.hop-chain{display:flex;flex-wrap:wrap;align-items:center;gap:0;padding:20px}
.hop-node{display:flex;flex-direction:column;align-items:center;gap:6px}
.hop-av{width:46px;height:46px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:10px;font-weight:bold;color:#060b12;box-shadow:0 2px 12px rgba(0,0,0,.4)}
.hop-id{font-family:var(--mono);font-size:9px;color:var(--acc)}
.hop-name{font-family:var(--mono);font-size:8px;color:var(--txt3)}
.hop-link{display:flex;flex-direction:column;align-items:center;padding:0 8px;margin-top:0}
.hop-line{width:40px;height:1px;background:linear-gradient(90deg,var(--bd2),var(--acc),var(--bd2));position:relative}
.hop-line::after{content:'▶';position:absolute;right:-6px;top:-6px;font-size:9px;color:var(--acc)}
.hop-snr{font-family:var(--mono);font-size:7px;color:var(--txt3);margin-top:2px;white-space:nowrap}

/* ── ANALYTICS CARD ── */
.an-card{background:var(--bg);border:1px solid var(--bd2);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;min-height:200px}
.an-card-hdr{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:9px;color:var(--txt3);margin-bottom:10px;border-bottom:1px dashed var(--bd);padding-bottom:8px}
.an-chart-wrap{flex:1;position:relative;min-height:150px}

/* ── PLUGIN CARD ── */
.pl-card{background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);padding:16px;position:relative;overflow:hidden;transition:.2s}
.pl-card:hover{border-color:var(--acc);box-shadow:0 4px 15px rgba(0,200,245,.1)}
.pl-stripe{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--bd)}
.pl-stripe.run{background:var(--ok);box-shadow:0 0 8px var(--ok)}
.pl-stripe.stop{background:var(--warn)}
.pl-head{display:flex;gap:10px;margin-bottom:10px;margin-left:8px}
.pl-icon{width:38px;height:38px;background:var(--bg);border:1px solid var(--bd);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:15px}
.pl-title{font-weight:bold;font-size:11px;color:var(--txt);font-family:var(--mono)}
.pl-id{font-size:8px;color:var(--txt3);font-family:var(--mono)}
.pl-desc{font-size:11px;color:var(--txt2);line-height:1.5;margin-bottom:12px;margin-left:8px}
.pl-foot{display:flex;gap:6px;border-top:1px solid var(--bd);padding-top:10px;margin-left:8px}

/* ── CODE BLOCK ── */
.code-block{position:relative;background:#020810;border:1px solid var(--bd2);border-radius:var(--r);padding:16px;overflow-x:auto}
.code-copy{position:absolute;top:8px;right:8px;background:var(--bg2);border:1px solid var(--bd2);border-radius:4px;padding:4px 8px;color:var(--txt3);font-size:10px;cursor:pointer;transition:.15s;font-family:var(--mono)}
.code-copy:hover{border-color:var(--acc);color:var(--acc)}

/* ── COMPARISON TABLE ── */
.why-table{width:100%;border-collapse:collapse;overflow:hidden;border-radius:var(--r2);border:1px solid var(--bd2)}
.why-table th{padding:14px 20px;font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;text-align:left}
.why-table th:first-child{background:rgba(0,0,0,.2)}
.why-table th.col-md{background:rgba(0,200,245,.06);color:var(--acc);border-bottom:2px solid var(--acc)}
.why-table th.col-alt{background:rgba(255,255,255,.02);color:var(--txt3)}
.why-table td{padding:10px 20px;border-top:1px solid var(--bd);font-size:13px}
.why-table td:first-child{color:var(--txt);font-weight:600}
.why-table td.yes{color:var(--ok)}
.why-table td.no{color:var(--err)}
.why-table td.part{color:var(--warn)}
.why-table tr:hover td{background:rgba(255,255,255,.015)}

/* ── STEPS ── */
.step-list{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:24px;padding:28px 0;border-bottom:1px solid var(--bd)}
.step:last-child{border-bottom:none}
.step-num{width:40px;height:40px;border-radius:50%;background:var(--acc);color:#020912;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:16px;flex-shrink:0;margin-top:2px}
.step-body h3{margin-bottom:8px;font-size:1.1rem}
.step-body p{font-size:13px;color:var(--txt2);line-height:1.65}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--acc)}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ── FOOTER ── */
.site-footer{background:#010710;border-top:1px solid var(--bd2);padding:60px 24px 28px;position:relative;z-index:1}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{font-family:var(--sans);font-weight:900;font-size:20px;color:var(--txt);margin-bottom:10px}
.footer-logo em{color:var(--acc);font-style:normal}
.footer-tagline{font-size:12px;color:var(--txt3);line-height:1.6;margin-bottom:14px}
.footer-badges{display:flex;flex-wrap:wrap;gap:5px}
.f-badge{font-family:var(--mono);font-size:8px;padding:2px 8px;border:1px solid var(--bd2);border-radius:3px;color:var(--txt3)}
.footer-col h4{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--txt3);font-family:var(--mono);margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{font-size:12px;color:var(--txt3);transition:.15s;display:flex;align-items:center;gap:5px}
.footer-col ul li a:hover{color:var(--acc);text-decoration:none}
.footer-bottom{max-width:var(--max);margin:0 auto;padding-top:24px;border-top:1px solid var(--bd);text-align:center;font-size:11px;color:var(--txt3)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .footer-inner{grid-template-columns:1fr 1fr}
  .kpi-strip{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .nav-hamburger{display:flex}
  .nav-inner.open .nav-links,.nav-inner.open .nav-actions{display:flex;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--bd2);padding:8px 0;z-index:201}
  .nav-inner.open .nav-links{gap:0}
  .nav-inner.open .nav-links li a{padding:10px 24px;height:auto;line-height:normal;border-bottom:none}
  .nav-inner.open .nav-actions{padding:8px 16px}
  .section{padding:60px 16px}
  h1{font-size:2rem} h2{font-size:1.6rem}
  .footer-inner{grid-template-columns:1fr;gap:28px}
}
