:root {
  
  --lime-300:#CDF38C; --lime-400:#BEF264; --lime:#A3E635; --lime-600:#84CC16; --lime-700:#5C8F0F;
  --lime-glow:rgba(163,230,53,0.28);
  
  --bg-app:#0A0B0D; --bg-sidebar:#0C0D0F; --bg-surface:#111316;
  --bg-surface-2:#16181C; --bg-surface-3:#1C1F24; --bg-inset:#08090A;
  
  --border:rgba(255,255,255,0.08);
  --border-strong:rgba(255,255,255,0.14);
  --border-faint:rgba(255,255,255,0.05);
  --border-lime:rgba(163,230,53,0.45);
  
  --fg1:#F4F6F4; --fg2:#B5BBB9; --fg3:#888F8C; --fg4:#7A8280; --fg-on-lime:#0E1A02;
  
  --success:#34D399; --success-bg:rgba(52,211,153,0.12);
  --info:#22D3EE;    --info-bg:rgba(34,211,238,0.12);
  --warning:#F5B43C; --warning-bg:rgba(245,180,60,0.12);
  --danger:#FB4D6A;  --danger-bg:rgba(251,77,106,0.12);
  --allowed:var(--info); --blocked:var(--danger);
  
  --viz-violet:#A78BFA; --viz-orange:#FB923C; --viz-magenta:#F472B6;
  
  --font-display:-apple-system,BlinkMacSystemFont,'SF Pro Display','Albert Sans','Segoe UI',sans-serif;
  --font-ui:-apple-system,BlinkMacSystemFont,'SF Pro Text','Albert Sans','Segoe UI',sans-serif;
  --font-mono:ui-monospace,'SF Mono','JetBrains Mono','SFMono-Regular',monospace;
  
  --r-sm:9px; --r-md:12px; --r-lg:16px; --r-xl:22px; --r-pill:999px;
  
  --shadow-md:0 6px 20px rgba(0,0,0,0.45);
  --shadow-lg:0 24px 60px -20px rgba(0,0,0,0.7);
  
  --ease:cubic-bezier(0.22,0.61,0.36,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  
  --maxw:1200px;
  
  --focus-ring:0 0 0 3px rgba(163,230,53,0.55);
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/albert-sans-latin-ext.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Albert Sans';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/albert-sans-latin.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-e.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-f.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-g.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/font-h.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-e.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-f.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-g.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/font-h.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-c.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-d.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-e.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-f.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-g.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/font-h.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100% }
body {
  font-family:var(--font-ui);
  background:var(--bg-app);
  color:var(--fg1);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection { background:var(--lime); color:var(--fg-on-lime) }
a   { color:inherit; text-decoration:none }
img { max-width:100%; display:block }
svg { display:block }
.container { max-width:var(--maxw); margin:0 auto; padding:0 28px; width:100% }
.mono      { font-family:var(--font-mono) }
.sr-only {
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.hp { position:absolute; left:-9999px; width:1px; height:1px; opacity:0 }
:focus-visible {
  outline:none;
  box-shadow:var(--focus-ring);
  border-radius:6px;
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
    scroll-behavior:auto !important;
  }
}
.page-grid {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(140% 100% at 50% -10%, #000 0%, transparent 65%);
  -webkit-mask-image:radial-gradient(140% 100% at 50% -10%, #000 0%, transparent 65%);
}
main, nav, footer { position:relative; z-index:1 }
.btn {
  font-family:var(--font-ui); font-weight:600;
  border-radius:var(--r-pill); border:1px solid transparent; cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  white-space:nowrap;
  transition:transform .2s var(--ease), background .2s, box-shadow .25s, border-color .2s, color .2s;
  font-size:14px; line-height:1;
}
.btn svg { width:16px; height:16px }
.btn-sm { padding:9px 16px;  font-size:13px }
.btn-md { padding:12px 20px }
.btn-lg { padding:15px 26px; font-size:15px }
.btn-primary {
  background:var(--lime); color:var(--fg-on-lime);
  box-shadow:0 0 0 1px var(--border-lime), 0 10px 30px -8px var(--lime-glow);
}
.btn-primary:hover {
  background:var(--lime-400); transform:translateY(-2px);
  box-shadow:0 0 0 1px var(--border-lime), 0 16px 40px -10px var(--lime-glow);
}
.btn-primary:active { transform:translateY(0) scale(.985) }
.btn-ghost   { background:rgba(255,255,255,.02); color:var(--fg1); border-color:var(--border-strong) }
.btn-ghost:hover { background:rgba(255,255,255,.06); border-color:var(--fg3); transform:translateY(-2px) }
.btn-outline { background:transparent; color:var(--fg1); border-color:var(--border-strong) }
.btn-outline:hover { border-color:var(--border-lime); color:var(--lime); background:rgba(163,230,53,.04) }
.btn-block { width:100% }
.btn:disabled { opacity:.6; cursor:not-allowed; transform:none !important }
.btn.loading  { opacity:.7; cursor:wait }
.pill {
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 15px; border-radius:var(--r-pill);
  background:rgba(163,230,53,.07); border:1px solid rgba(163,230,53,.22);
  font-size:12.5px; font-weight:600; color:var(--lime-300);
}
.pill .dot { width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 10px var(--lime); animation:pulse 1.8s infinite }
@keyframes pulse { 0%,100%{ opacity:1 } 50%{ opacity:.35 } }
.docs-nav {
  position:sticky; top:0; z-index:100; height:64px; display:flex; align-items:center;
  background:rgba(10,11,13,.72);
  backdrop-filter:blur(16px) saturate(140%); -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.docs-nav-inner {
  max-width:1340px; margin:0 auto; width:100%;
  padding:0 clamp(16px,4vw,28px); display:flex; align-items:center; gap:18px;
}
.docs-brand { display:flex; align-items:center; gap:11px; flex-shrink:0 }
.docs-brand img { height:32px }
.docs-brand-tag {
  font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--fg4); padding-left:13px; border-left:1px solid var(--border-strong);
}
.docs-nav-spacer { flex:1 }
.docs-search { position:relative; display:flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.03); border:1px solid var(--border);
  border-radius:var(--r-pill); padding:8px 14px; min-width:200px;
  transition:border-color .2s, background .2s; }
.docs-search:focus-within { border-color:var(--border-lime); background:rgba(255,255,255,.05) }
.docs-search svg { width:15px; height:15px; color:var(--fg4); flex-shrink:0 }
.docs-search input { background:transparent; border:none; outline:none; color:var(--fg1);
  font-family:var(--font-ui); font-size:13.5px; width:170px; }
.docs-search input::placeholder { color:var(--fg4) }
.docs-search kbd {
  font-family:var(--font-mono); font-size:10.5px; color:var(--fg4);
  border:1px solid var(--border-strong); border-radius:5px; padding:1px 6px;
  background:rgba(255,255,255,.03);
}
.search-results {
  display:none; position:absolute; top:calc(100% + 10px); right:0; width:380px;
  background:var(--bg-surface-2); border:1px solid var(--border-strong);
  border-radius:var(--r-lg); overflow:hidden; z-index:200; box-shadow:var(--shadow-lg);
}
.search-results.open { display:block }
.sr-header { padding:10px 16px; font-size:10.5px; font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; color:var(--fg4); border-bottom:1px solid var(--border-faint) }
.sr-empty  { padding:20px 16px; font-size:14px; color:var(--fg3); text-align:center }
.sr-item   { display:flex; flex-direction:column; gap:3px; padding:11px 16px; cursor:pointer;
  border-bottom:1px solid var(--border-faint); transition:background .15s; text-align:left;
  width:100%; background:none; border-left:none; border-right:none; border-top:none; font-family:inherit }
.sr-item:last-child { border-bottom:none }
.sr-item:hover, .sr-item.active { background:rgba(163,230,53,.06) }
.sr-section { font-size:11px; color:var(--lime); font-weight:600 }
.sr-title   { font-size:14px; font-weight:600; color:var(--fg1) }
.sr-excerpt { font-size:12.5px; color:var(--fg4); line-height:1.5;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100% }
.sr-excerpt mark, .sr-title mark { background:rgba(163,230,53,.22); color:var(--lime-300); border-radius:3px; padding:0 2px }
.docs-back { font-size:13.5px; font-weight:500; color:var(--fg2); display:inline-flex; align-items:center; gap:7px; transition:color .2s }
.docs-back:hover { color:var(--lime) }
.docs-back svg { width:14px; height:14px }
.docs-menu-btn { display:none; background:rgba(255,255,255,.03); border:1px solid var(--border);
  border-radius:var(--r-sm); width:38px; height:38px; align-items:center; justify-content:center;
  cursor:pointer; color:var(--fg2) }
.docs-menu-btn svg { width:18px; height:18px }
.docs-shell {
  max-width:1340px; margin:0 auto; padding:0 clamp(16px,4vw,28px);
  display:grid; grid-template-columns:264px minmax(0,1fr) 200px; gap:48px;
  position:relative; z-index:1;
}
.docs-sidebar { position:sticky; top:64px; align-self:start; height:calc(100vh - 64px);
  overflow-y:auto; padding:34px 0 60px; }
.docs-sidebar::-webkit-scrollbar { width:5px }
.docs-sidebar::-webkit-scrollbar-thumb { background:var(--border-strong); border-radius:3px }
.sb-group { margin-bottom:26px }
.sb-group-label { font-size:10.5px; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  color:var(--fg4); padding:0 14px 8px; }
.sb-link { display:flex; align-items:center; gap:10px; width:100%; text-align:left;
  padding:8px 14px; font-size:13.5px; color:var(--fg2); cursor:pointer; font-family:inherit;
  background:none; border:none; border-left:2px solid transparent; border-radius:0 var(--r-sm) var(--r-sm) 0;
  transition:color .18s, background .18s, border-color .18s; }
.sb-link:hover { color:var(--fg1); background:rgba(255,255,255,.03) }
.sb-link.active { color:var(--lime-300); background:rgba(163,230,53,.08); border-left-color:var(--lime) }
.sb-link svg { width:15px; height:15px; flex-shrink:0; opacity:.55; transition:opacity .18s, color .18s }
.sb-link.active svg { opacity:1; color:var(--lime) }
.docs-toc { position:sticky; top:64px; align-self:start; padding:40px 0 60px; }
.docs-toc-label { font-size:10.5px; font-weight:700; letter-spacing:.13em; text-transform:uppercase;
  color:var(--fg4); margin-bottom:12px; }
.docs-toc a { display:block; font-size:12.5px; color:var(--fg3); padding:5px 0 5px 12px;
  border-left:2px solid var(--border-faint); transition:color .18s, border-color .18s; }
.docs-toc a:hover { color:var(--fg1) }
.docs-toc a.active { color:var(--lime-300); border-left-color:var(--lime) }
.docs-main { padding:40px 0 90px; min-width:0 }
.doc-section { scroll-margin-top:90px; padding-bottom:18px }
.doc-section + .doc-section { margin-top:18px; padding-top:34px; border-top:1px solid var(--border-faint) }
.breadcrumb { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--fg4); margin-bottom:18px }
.breadcrumb a { color:var(--fg4); transition:color .2s }
.breadcrumb a:hover { color:var(--lime) }
.breadcrumb svg { width:13px; height:13px; opacity:.6 }
.doc-section h1 { font-family:var(--font-display); font-size:clamp(28px,3.4vw,40px); font-weight:800;
  letter-spacing:-.025em; line-height:1.08; margin-bottom:12px; color:var(--fg1) }
.doc-section .lead { font-size:17px; color:var(--fg2); line-height:1.65; margin-bottom:30px;
  padding-bottom:26px; border-bottom:1px solid var(--border-faint); }
.doc-section h2 { font-family:var(--font-display); font-size:21px; font-weight:700; letter-spacing:-.015em;
  margin:38px 0 12px; color:var(--fg1); scroll-margin-top:90px }
.doc-section h3 { font-size:15.5px; font-weight:700; margin:26px 0 9px; color:var(--lime-300) }
.doc-section p  { font-size:15px; color:var(--fg2); line-height:1.75; margin-bottom:14px }
.doc-section ul, .doc-section ol { margin:8px 0 18px 4px; display:flex; flex-direction:column; gap:8px;
  list-style:none; padding-left:0 }
.doc-section li { font-size:15px; color:var(--fg2); line-height:1.65; padding-left:24px; position:relative }
.doc-section li::before { content:""; position:absolute; left:4px; top:10px; width:6px; height:6px;
  border-radius:50%; background:var(--lime); opacity:.5 }
.doc-section ol { counter-reset:li }
.doc-section ol li::before { content:counter(li); counter-increment:li; background:none; opacity:1;
  left:0; top:0; width:18px; height:18px; font-size:11px; font-weight:700; color:var(--lime);
  font-family:var(--font-mono); display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border-lime); border-radius:5px; }
.doc-section ol li { padding-left:28px }
.doc-section li strong, .doc-section strong { color:var(--fg1); font-weight:600 }
.doc-section code { font-family:var(--font-mono); font-size:.84em; background:rgba(255,255,255,.05);
  border:1px solid var(--border-faint); padding:.12em .42em; border-radius:5px; color:var(--lime-300) }
.callout { display:flex; gap:12px; padding:14px 16px; border-radius:var(--r-md); margin:18px 0;
  font-size:14px; line-height:1.6; align-items:flex-start }
.callout-icon { width:18px; height:18px; flex-shrink:0; margin-top:1px }
.callout div { color:var(--fg2) }
.callout.info { background:var(--info-bg);    border:1px solid rgba(34,211,238,.25) }
.callout.info .callout-icon { color:var(--info) }
.callout.tip  { background:rgba(163,230,53,.07); border:1px solid rgba(163,230,53,.22) }
.callout.tip .callout-icon  { color:var(--lime) }
.callout.warn { background:var(--warning-bg); border:1px solid rgba(245,180,60,.25) }
.callout.warn .callout-icon { color:var(--warning) }
.steps { display:flex; flex-direction:column; gap:9px; margin:16px 0 22px }
.step  { display:flex; align-items:flex-start; gap:13px; padding:13px 15px;
  background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:var(--r-md) }
.step-num { min-width:25px; height:25px; border-radius:7px; background:rgba(163,230,53,.1);
  border:1px solid var(--border-lime); display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:12px; font-weight:700; color:var(--lime); flex-shrink:0; margin-top:1px }
.step p { margin-bottom:0; font-size:14px }
.doc-feature-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:22px 0 8px }
.doc-feature { background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:20px; transition:border-color .25s, transform .25s, background .25s }
.doc-feature:hover { border-color:rgba(163,230,53,.3); transform:translateY(-3px); background:rgba(255,255,255,.04) }
.doc-feature .df-ic { width:40px; height:40px; border-radius:11px; background:rgba(163,230,53,.1);
  border:1px solid rgba(163,230,53,.18); display:flex; align-items:center; justify-content:center; margin-bottom:14px }
.doc-feature .df-ic svg { width:20px; height:20px; color:var(--lime) }
.doc-feature h4 { font-family:var(--font-display); font-size:15.5px; font-weight:700; margin-bottom:6px; color:var(--fg1) }
.doc-feature p  { font-size:13.5px; color:var(--fg3); line-height:1.6; margin:0 }
.doc-table { width:100%; border-collapse:collapse; margin:16px 0 24px; font-size:14px;
  border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden }
.doc-table th { text-align:left; padding:11px 14px; font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; color:var(--fg4); background:rgba(255,255,255,.03); border-bottom:1px solid var(--border) }
.doc-table td { padding:12px 14px; border-bottom:1px solid var(--border-faint); color:var(--fg2); vertical-align:top }
.doc-table tr:last-child td { border-bottom:none }
.doc-table td:first-child { color:var(--fg1); font-weight:600 }
.role-badge { display:inline-flex; align-items:center; gap:6px; padding:3px 10px; border-radius:var(--r-pill);
  font-size:11.5px; font-weight:700 }
.role-badge::before { content:""; width:6px; height:6px; border-radius:50% }
.role-badge.owner  { background:rgba(163,230,53,.12); color:var(--lime) }
.role-badge.owner::before  { background:var(--lime) }
.role-badge.admin  { background:rgba(34,211,238,.12); color:var(--info) }
.role-badge.admin::before  { background:var(--info) }
.role-badge.viewer { background:rgba(255,255,255,.06); color:var(--fg3) }
.role-badge.viewer::before { background:var(--fg3) }
.sev { display:inline-block; padding:2px 9px; border-radius:var(--r-pill); font-size:11px; font-weight:700 }
.sev.high { background:var(--danger-bg); color:var(--danger) }
.sev.med  { background:var(--warning-bg); color:var(--warning) }
.sev.low  { background:rgba(163,230,53,.12); color:var(--lime) }
.code-block { background:var(--bg-inset); border:1px solid var(--border); border-radius:var(--r-md);
  margin:14px 0; overflow:hidden }
.code-block-hd { display:flex; align-items:center; justify-content:space-between; padding:8px 14px;
  border-bottom:1px solid var(--border-faint); background:rgba(255,255,255,.02) }
.code-block-hd .lang { font-family:var(--font-mono); font-size:10.5px; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--fg4) }
.code-copy { background:none; border:1px solid var(--border); border-radius:6px; color:var(--fg3);
  font-size:11px; font-family:var(--font-ui); padding:3px 9px; cursor:pointer; display:inline-flex; align-items:center; gap:5px;
  transition:color .2s, border-color .2s }
.code-copy:hover { color:var(--lime); border-color:var(--border-lime) }
.code-copy svg { width:12px; height:12px }
.code-block pre { margin:0; padding:14px 16px; overflow-x:auto }
.code-block code { font-family:var(--font-mono); font-size:13px; color:var(--lime-300);
  background:none; border:none; padding:0; display:block; line-height:1.7; white-space:pre }
.device-tabs { display:flex; gap:7px; margin:18px 0 16px; flex-wrap:wrap }
.dtab { display:inline-flex; align-items:center; gap:7px; padding:8px 14px; border-radius:var(--r-pill);
  font-size:13px; font-weight:600; background:rgba(255,255,255,.03); border:1px solid var(--border);
  color:var(--fg3); cursor:pointer; font-family:inherit; transition:all .2s }
.dtab:hover { color:var(--fg1); border-color:var(--fg4) }
.dtab.active { background:rgba(163,230,53,.1); border-color:var(--border-lime); color:var(--lime-300) }
.dtab svg { width:14px; height:14px }
.device-content { display:none }
.device-content.active { display:block; animation:docFade .3s var(--ease-out) }
@keyframes docFade { from { opacity:0; transform:translateY(6px) } to { opacity:1; transform:none } }
.bl-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin:14px 0 8px }
.bl-card { border:1px solid var(--border); border-radius:var(--r-md); padding:15px 16px;
  background:rgba(255,255,255,.02); transition:border-color .25s }
.bl-card:hover { border-color:rgba(163,230,53,.25) }
.bl-card h4 { font-size:14px; font-weight:700; margin-bottom:5px; color:var(--fg1) }
.bl-card p  { font-size:12.5px; margin:0 0 10px; color:var(--fg3); line-height:1.55 }
.bl-tag { display:inline-block; padding:2px 9px; border-radius:var(--r-pill); font-size:10.5px;
  font-weight:600; margin-right:6px }
.bl-tag.general  { background:rgba(163,230,53,.1); color:var(--lime) }
.bl-tag.security { background:var(--danger-bg); color:var(--danger) }
.bl-tag.regional { background:var(--info-bg); color:var(--info) }
.bl-tag.other    { background:rgba(255,255,255,.06); color:var(--fg3) }
.sec-div { border:none; border-top:1px solid var(--border-faint); margin:30px 0 }
.next-link { display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:600;
  color:var(--lime); margin-top:8px }
.next-link svg { width:15px; height:15px }
.docs-footer { border-top:1px solid var(--border); background:var(--bg-sidebar); padding:30px 0;
  position:relative; z-index:1 }
.docs-footer-inner { max-width:1340px; margin:0 auto; padding:0 clamp(16px,4vw,28px);
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px;
  font-size:13px; color:var(--fg4) }
.docs-footer a { color:var(--fg3); transition:color .2s }
.docs-footer a:hover { color:var(--lime) }
@media (max-width:1140px) {
  .docs-shell { grid-template-columns:240px minmax(0,1fr); gap:36px }
  .docs-toc { display:none }
}
@media (max-width:880px) {
  .docs-shell { grid-template-columns:1fr }
  .docs-menu-btn { display:flex }
  .docs-search { display:none }
  .docs-sidebar { position:fixed; top:64px; left:0; bottom:0; width:280px; z-index:90;
    background:var(--bg-sidebar); border-right:1px solid var(--border); padding:24px 0 60px;
    transform:translateX(-100%); transition:transform .28s var(--ease); height:calc(100vh - 64px) }
  .docs-sidebar.open { transform:none }
  .doc-feature-grid, .bl-grid { grid-template-columns:1fr }
  .docs-main { padding-top:28px }
  .docs-scrim { display:none; position:fixed; inset:64px 0 0; background:rgba(0,0,0,.55); z-index:80 }
  .docs-scrim.open { display:block }
}
.consent-banner {
  position:fixed; right:24px; bottom:24px; z-index:990; 
  width:min(420px, calc(100vw - 32px));
  
  transform:translateY(140%); opacity:0;
  transition:transform .5s var(--ease-out), opacity .4s ease;
  pointer-events:none;
}
.consent-banner.show { transform:none; opacity:1; pointer-events:auto }
.consent-card {
  position:relative; overflow:hidden;
  background:linear-gradient(180deg, rgba(20,22,26,.72), rgba(12,13,15,.78));
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid var(--border-strong);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg), 0 0 0 1px rgba(0,0,0,.3);
  padding:20px 20px 18px;
}
.consent-card::before {
  content:""; position:absolute; left:0; right:0; top:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--lime), transparent);
  opacity:.6;
}
.consent-card::after {
  content:""; position:absolute; top:-60px; right:-40px; width:160px; height:160px;
  background:radial-gradient(circle, rgba(163,230,53,.14), transparent 70%);
  filter:blur(8px); pointer-events:none;
}
.consent-card > * { position:relative; z-index:1 }
.consent-head { display:flex; align-items:center; gap:10px; margin-bottom:9px }
.consent-ic {
  width:30px; height:30px; flex-shrink:0; border-radius:9px;
  background:rgba(163,230,53,.1); border:1px solid rgba(163,230,53,.22);
  display:flex; align-items:center; justify-content:center;
}
.consent-ic svg { width:16px; height:16px; color:var(--lime) }
.consent-title {
  font-family:var(--font-display); font-size:14.5px; font-weight:700;
  letter-spacing:-.01em; color:var(--fg1);
}
.consent-text { font-size:12.8px; line-height:1.6; color:var(--fg3); margin-bottom:16px }
.consent-text a { color:var(--lime); text-decoration:none; border-bottom:1px solid rgba(163,230,53,.3) }
.consent-text a:hover { color:var(--lime-400); border-bottom-color:var(--lime-400) }
.consent-actions { display:flex; gap:9px }
.consent-actions .btn { flex:1 }
@media (max-width:520px) {
  .consent-banner { left:16px; right:16px; bottom:16px; width:auto }
}
