:root{
  --paper:#f6f4ee;--panel:#fff;--panel-2:#efece3;--line:#d8d3c6;--line-soft:#e6e2d8;
  --text:#1c2530;--text-dim:#56616e;--text-faint:#8a93a0;
  --soc-low:#e08a1e;--soc-mid:#b8b22c;--soc-high:#1f9d57;--accent:#1f9d57;--accent-ink:#fff;
  --sun:#e0a92e;--danger:#d6483b;--grid-op:.55;--radius:4px;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
:root[data-theme=dark]{
  --paper:#0d1117;--panel:#141b24;--panel-2:#1b2530;--line:#2a3947;--line-soft:#1c2a36;
  --text:#e6edf3;--text-dim:#8da2b5;--text-faint:#5e7184;
  --soc-low:#f4a23b;--soc-mid:#d4d04a;--soc-high:#3fd07a;--accent:#3fd07a;--accent-ink:#0d1117;
  --sun:#ffcf4d;--danger:#ff6b5e;--grid-op:.9;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--text);font-family:var(--sans);line-height:1.55;-webkit-font-smoothing:antialiased;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:32px 32px;transition:background-color .3s,color .3s}
body::before{content:"";position:fixed;inset:0;background:var(--paper);opacity:var(--grid-op);z-index:-1;transition:.3s}
a{color:inherit;text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
header{border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--paper) 80%,transparent);backdrop-filter:blur(8px);position:sticky;top:0;z-index:50}
.bar{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-weight:600;letter-spacing:-.3px;font-size:15px}
.brand .cell{width:22px;height:14px;border:1.5px solid var(--soc-high);border-radius:2px;position:relative;flex:none}
.brand .cell::after{content:"";position:absolute;right:-4px;top:3px;width:3px;height:6px;background:var(--soc-high);border-radius:0 1px 1px 0}
.brand .cell::before{content:"";position:absolute;inset:2px;background:linear-gradient(90deg,var(--soc-high) 70%,transparent 70%);border-radius:1px}
.right{display:flex;align-items:center;gap:6px}
nav.top a{font-family:var(--mono);font-size:14px;color:var(--text-dim);margin-left:22px}
nav.top a:hover{color:var(--text)}
@media(max-width:760px){nav.top{display:none}}
.toggle{display:inline-flex;align-items:center;gap:7px;margin-left:18px;font-family:var(--mono);font-size:12px;color:var(--text-dim);border:1px solid var(--line);background:var(--panel);padding:7px 11px;border-radius:var(--radius);cursor:pointer;transition:.15s}
.toggle:hover{border-color:var(--text-faint);color:var(--text)}
.toggle .ic{width:14px;height:14px}
.toggle .lbl-light{display:none}
:root[data-theme=dark] .toggle .lbl-dark{display:none}
:root[data-theme=dark] .toggle .lbl-light{display:inline}
.hero{padding:28px 0 20px}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--soc-high);display:inline-flex;align-items:center;gap:8px;margin-bottom:12px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--soc-high)}
h1{font-size:clamp(26px,3.6vw,40px);line-height:1.06;font-weight:800;letter-spacing:-1.2px;max-width:20ch}
h1 .charge{background:linear-gradient(90deg,var(--soc-low),var(--soc-mid) 45%,var(--soc-high));-webkit-background-clip:text;background-clip:text;color:transparent}
.sub{color:var(--text-dim);font-size:16.5px;max-width:60ch;margin-top:10px}
.btn{font-family:var(--mono);font-size:15px;font-weight:600;padding:13px 22px;border-radius:var(--radius);border:1px solid var(--line);cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:9px;background:transparent;color:var(--text)}
.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-ghost:hover{background:var(--panel-2);border-color:var(--text-faint)}

/* calculator */
.calc{padding:22px 0 44px;border-bottom:1px solid var(--line)}
.calc h2{font-size:13px;font-family:var(--mono);letter-spacing:2px;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px}
.calc .h2sub{color:var(--text-dim);font-size:14px;margin-bottom:18px;max-width:60ch}
.grid2{display:grid;grid-template-columns:1.05fr .95fr;gap:24px}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}
.panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:0 1px 2px rgba(0,0,0,.03)}
.panel-h{padding:13px 18px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px;letter-spacing:1px;color:var(--text-dim);display:flex;justify-content:space-between;align-items:center}
.panel-b{padding:18px}
label{display:block;font-size:14px;color:var(--text-dim);margin:14px 0 6px}
label:first-child{margin-top:0}
input,select{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);color:var(--text);font-family:var(--mono);font-size:15px}
input:focus,select:focus{outline:2px solid var(--accent);outline-offset:-1px;border-color:var(--accent)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.row3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px}
/* device rows */
.dev{display:grid;grid-template-columns:1.5fr .7fr .6fr .45fr .65fr .6fr auto;gap:6px;align-items:center;margin-bottom:8px}
.dev input,.dev select{padding:8px 9px;font-size:13px}
.dev .x{cursor:pointer;color:var(--text-faint);border:1px solid var(--line);border-radius:var(--radius);padding:8px 11px;background:var(--paper);font-family:var(--mono)}
.dev .x:hover{color:var(--danger);border-color:var(--danger)}
.dev-head{display:grid;grid-template-columns:1.5fr .7fr .6fr .45fr .65fr .6fr auto;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.3px;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px}
.adddev{margin-top:6px;font-family:var(--mono);font-size:13px;color:var(--accent);background:none;border:1px dashed var(--line);width:100%;padding:9px;border-radius:var(--radius);cursor:pointer}
.adddev:hover{border-color:var(--accent)}
.preset{font-family:var(--mono);font-size:11px;color:var(--text-dim);border:1px solid var(--line);background:var(--paper);padding:5px 9px;border-radius:var(--radius);cursor:pointer;margin:0 4px 4px 0}
.preset:hover{border-color:var(--accent);color:var(--accent)}
/* results */
.res{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.res .cellr{background:var(--panel);padding:16px}
.res .k{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}
.res .v{font-size:26px;font-weight:800;letter-spacing:-.5px;margin-top:4px}
.res .v small{font-size:13px;font-weight:600;color:var(--text-dim)}
.reslist{margin-top:1px}
.resrow{background:var(--panel);display:flex;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--line-soft);font-size:15px}
.resrow .lab{color:var(--text-dim)}
.resrow .val{font-family:var(--mono);font-weight:600}
.warn{background:color-mix(in srgb,var(--danger) 12%,var(--panel));border:1px solid var(--danger);color:var(--text);padding:11px 14px;border-radius:var(--radius);font-size:14px;margin-top:12px}
.tip{background:color-mix(in srgb,var(--soc-high) 9%,var(--panel));border:1px solid color-mix(in srgb,var(--soc-high) 45%,var(--line));color:var(--text);padding:12px 14px;border-radius:var(--radius);font-size:14px;line-height:1.55;margin-top:12px}
.bp{margin-top:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);overflow:hidden}
.bp-h{padding:11px 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);display:flex;justify-content:space-between;align-items:center}
.bp-cfg{color:var(--accent);font-weight:700}
.bp-b{padding:14px 16px}
.bp ol{margin:0;padding-left:20px}
.bp li{font-size:14.5px;line-height:1.5;margin-bottom:9px;color:var(--text)}
.bp-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:6px;padding-top:12px;border-top:1px solid var(--line-soft);font-family:var(--mono);font-size:12px;color:var(--text-faint)}
.bp-meta b{color:var(--text-dim);font-weight:600}
.bp-scope{font-size:12px;color:var(--text-faint);margin-top:12px;padding-top:10px;border-top:1px solid var(--line-soft);line-height:1.5}
.note{color:var(--text-faint);font-size:13px;margin-top:10px}
.soc-bars{display:flex;gap:3px;padding:14px 0 4px}
.soc-bars i{flex:1;height:34px;border-radius:2px;background:var(--panel-2);position:relative;overflow:hidden}
.soc-bars i::after{content:"";position:absolute;inset:0;transform:scaleY(var(--f,0));transform-origin:bottom;background:var(--c,var(--soc-high));transition:transform .6s cubic-bezier(.2,.8,.2,1)}
.soc-leg{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;color:var(--text-faint)}
.actions{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.overlay{margin-top:16px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:12px 14px}
.overlay-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.ovl-toggle{font-size:13px;color:var(--text-dim);display:flex;align-items:center;gap:8px;cursor:pointer;margin:0}
.ovl-toggle input{width:auto}
.overlay select{width:auto;padding:6px 9px;font-size:12px;font-family:var(--mono)}
.ovl-lead{font-size:13px;color:var(--text-dim);margin:12px 0 8px}
.ovl-row{padding:9px 0;border-top:1px solid var(--line-soft);font-size:14px}
.ovl-row:first-of-type{border-top:none}
.ovl-meta{font-family:var(--mono);font-size:11px;color:var(--text-faint);margin-top:3px}
.ovl-tag{font-family:var(--mono);font-size:10px;color:var(--soc-low);border:1px solid var(--soc-low);border-radius:2px;padding:1px 5px;margin-left:6px;white-space:nowrap}
.ovl-disc{font-size:11px;color:var(--text-faint);margin-top:10px;border-top:1px solid var(--line-soft);padding-top:8px}
.diagram{margin-top:18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:8px 12px 6px}
.diagram-h{font-family:var(--mono);font-size:10px;letter-spacing:1px;color:var(--text-faint);padding:4px 2px 2px}
.diagram svg{display:block}

/* content sections */
.stages{padding:52px 0;border-bottom:1px solid var(--line)}
.stages h2{font-size:13px;font-family:var(--mono);letter-spacing:2px;text-transform:uppercase;color:var(--text-faint);margin-bottom:26px}
.flow{display:grid;grid-template-columns:repeat(5,1fr)}
@media(max-width:760px){.flow{grid-template-columns:1fr 1fr}}
.fnode{border:1px solid var(--line);padding:18px 16px;background:var(--panel);position:relative}
.fnode .n{font-family:var(--mono);font-size:11px;color:var(--soc-high);letter-spacing:1px}
.fnode .t{font-weight:700;margin-top:9px;font-size:15px}
.fnode .d{color:var(--text-dim);font-size:13px;margin-top:5px}
.chem{padding:52px 0;border-bottom:1px solid var(--line)}
.chem h2{font-size:23px;letter-spacing:-.5px;margin-bottom:8px}
.chem .lead{color:var(--text-dim);font-size:15px;margin-bottom:24px;max-width:60ch}
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel)}
table{width:100%;border-collapse:collapse;font-size:15px;min-width:560px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line-soft)}
tbody tr:last-child td{border-bottom:none}
th{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);background:var(--panel-2)}
td:first-child{font-weight:600}
.tag{font-family:var(--mono);font-size:11px;padding:2px 8px;border-radius:2px;background:var(--panel-2)}
.tag.hi{color:var(--soc-high)}.tag.lo{color:var(--soc-low)}
.disc{font-size:13px;color:var(--text-faint);margin-top:18px;max-width:72ch}
footer{border-top:1px solid var(--line);padding:48px 0 32px;color:var(--text-faint);font-size:14px}
.foot{display:block}
.foot-cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:32px}
@media(max-width:760px){.foot-cols{grid-template-columns:1fr 1fr;gap:26px}}
@media(max-width:440px){.foot-cols{grid-template-columns:1fr}}
.foot-h{font-family:var(--mono);font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--text);margin-bottom:12px;font-weight:600}
.foot-brand p{color:var(--text-dim);font-size:13.5px;line-height:1.55;max-width:34ch;margin:0}
.foot-col a{display:block;color:var(--text-dim);margin-bottom:8px;font-size:13.5px;text-decoration:none}
.foot-col a:hover{color:var(--accent)}
.foot-base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:36px;padding-top:20px;border-top:1px solid var(--line-soft);font-size:12px}
.foot-base span:first-child{font-family:var(--mono);color:var(--text-dim)}
.foot-disc{color:var(--text-faint);max-width:60ch}

/* content / doc pages */
.doc{padding:56px 0;min-height:50vh}
.doc-h1{font-size:clamp(28px,4.4vw,44px);font-weight:800;letter-spacing:-1.2px;line-height:1.06;margin:14px 0}
.doc-lead{color:var(--text-dim);font-size:19.5px;max-width:62ch;margin-bottom:32px}
.doc h2{font-size:23px;letter-spacing:-.4px;margin:34px 0 10px}
.doc h3{font-size:16px;margin:22px 0 8px;font-family:var(--mono);color:var(--text-dim)}
.doc p{max-width:70ch;margin-bottom:14px;color:var(--text)}
.doc p,.doc li{font-size:17px}
.doc a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.doc a.btn{text-decoration:none}
.doc a.btn-primary{color:var(--accent-ink)}
.doc a.btn-ghost{color:var(--text)}
.doc .note{color:var(--text-faint);font-size:13px;max-width:70ch}
.doc .res{max-width:none}
pre.code{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;font-family:var(--mono);font-size:13px;overflow-x:auto;margin:10px 0 16px;color:var(--text)}
.refs{list-style:none;padding:0;margin:10px 0;max-width:72ch}
.refs li{font-size:13px;color:var(--text-dim);padding:6px 0;border-bottom:1px solid var(--line-soft);font-family:var(--mono)}
.refs li:last-child{border-bottom:none}
.crumb{font-family:var(--mono);font-size:12px;color:var(--text-faint);margin-bottom:8px}
.crumb a{color:var(--text-dim);text-decoration:none}
.crumb a:hover{color:var(--accent)}
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
@media(max-width:760px){.uc-grid{grid-template-columns:1fr}}
.uc-card{border:1px solid var(--line);border-radius:var(--radius);padding:20px;background:var(--panel);transition:.15s;display:block;text-decoration:none}
.uc-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.uc-t{font-weight:700;font-size:16px;margin-bottom:6px}
.doc a.uc-card,.doc a.uc-card:hover{text-decoration:none}
.net-url{color:#1a64d6;font-size:15px;font-weight:600;text-decoration:none;word-break:break-word}
[data-theme="dark"] .net-url{color:#5b9bff}
.uc-card:hover .net-url{text-decoration:underline;text-underline-offset:2px}
.uc-card .uc-d{text-decoration:none;color:var(--text-dim);font-size:14px;line-height:1.55}
.uc-d{color:var(--text-dim);font-size:14px}
.tool-card{margin-top:8px}
.tool-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fhint{display:block;font-size:11px;color:var(--text-faint);margin-top:4px;line-height:1.4}
@media(max-width:560px){.tool-fields{grid-template-columns:1fr}}
.tool-out{margin-top:20px;padding-top:18px;border-top:1px solid var(--line)}
.tool-main{font-size:40px;font-weight:800;letter-spacing:-1px;line-height:1}
.tool-main small{font-size:16px;font-weight:600;color:var(--text-dim)}
.tool-sub{color:var(--text-dim);font-size:15px;margin-top:8px;font-family:var(--mono)}
.tool-svg svg{display:block;margin-top:6px}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
