: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 }
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:11.5px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--lime);
}
.eyebrow::before { content:""; width:18px; height:1.5px; background:var(--lime); opacity:.7 }
.eyebrow.center  { justify-content:center }
.h-display { font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.02; color:var(--fg1) }
.it        { font-style:italic; font-weight:600; color:var(--lime) }
.hl        { color:var(--lime) }
.section-title { font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.06; font-size:clamp(30px,3.6vw,46px); color:var(--fg1) }
.section-sub   { color:var(--fg2); font-size:clamp(15px,1.5vw,17.5px); line-height:1.55; max-width:620px }
.section-pad   { padding:clamp(72px,9vw,128px) 0 }
.center        { text-align:center }
.mxauto        { margin-left:auto; margin-right:auto }
.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 } }
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:68px; display:flex; align-items:center;
  transition:background .3s, border-color .3s, backdrop-filter .3s;
  border-bottom:1px solid transparent;
}
nav.scrolled {
  background:rgba(10,11,13,.72);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom-color:var(--border);
}
.nav-inner   { max-width:var(--maxw); margin:0 auto; padding:0 28px; width:100%; display:flex; align-items:center; justify-content:space-between; gap:24px }
.nav-logo img { height:34px }
.nav-links { display:flex; gap:30px; align-items:center; list-style:none }
.nav-links a { font-size:14px; font-weight:500; color:var(--fg2); transition:color .2s; position:relative; padding:4px 0 }
.nav-links a::after { content:""; position:absolute; left:0; bottom:-2px; width:0; height:1.5px; background:var(--lime); transition:width .25s var(--ease) }
.nav-links a:hover { color:var(--fg1) }
.nav-links a:hover::after { width:100% }
.nav-right   { display:flex; gap:14px; align-items:center }
.nav-signin  { font-size:14px; font-weight:500; color:var(--fg2); transition:color .2s }
.nav-signin:hover { color:var(--fg1) }
.nav-dd { position:relative }
.nav-dd-btn {
  display:inline-flex; align-items:center; gap:5px;
  background:none; border:none; cursor:pointer; font-family:inherit;
  font-size:14px; font-weight:500; color:var(--fg2); transition:color .2s; padding:4px 0;
}
.nav-dd-btn:hover, .nav-dd.open .nav-dd-btn { color:var(--fg1) }
.nav-dd-caret { width:13px; height:13px; transition:transform .2s }
.nav-dd.open .nav-dd-caret { transform:rotate(180deg) }
.nav-dd-menu {
  position:absolute; top:calc(100% + 12px); right:0; min-width:248px;
  background:var(--bg-surface-2); border:1px solid var(--border-strong);
  border-radius:var(--r-md); padding:6px; box-shadow:var(--shadow-lg);
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .2s, transform .2s, visibility .2s; z-index:200;
}
.nav-dd:hover .nav-dd-menu, .nav-dd.open .nav-dd-menu { opacity:1; visibility:visible; transform:none }
.nav-dd-menu a { display:flex; gap:11px; align-items:flex-start; padding:10px 12px;
  border-radius:var(--r-sm); color:var(--fg2); transition:background .15s, color .15s }
.nav-dd-menu a:hover { background:rgba(255,255,255,.04); color:var(--fg1) }
.nav-dd-menu svg { width:18px; height:18px; color:var(--lime); flex-shrink:0; margin-top:2px }
.nav-dd-menu strong { display:block; font-size:13.5px; font-weight:600; color:var(--fg1) }
.nav-dd-menu small  { display:block; font-size:11.5px; color:var(--fg4); margin-top:1px }
.hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px }
.hamburger span { width:22px; height:2px; background:var(--fg1); border-radius:2px; transition:.25s }
.cta-wrap {
  position:relative; border:1px solid var(--border-lime); border-radius:var(--r-xl);
  overflow:hidden;
  background:linear-gradient(150deg, rgba(163,230,53,.08), rgba(10,11,13,.4) 60%);
  padding:clamp(40px,6vw,72px);
}
.cta-wrap .glowc {
  position:absolute; width:480px; height:480px; border-radius:50%;
  background:rgba(163,230,53,.14); filter:blur(100px);
  top:-220px; right:-120px; pointer-events:none;
}
.cta-inner    { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap }
.cta-inner h2 { font-family:var(--font-display); font-weight:800; letter-spacing:-.025em; line-height:1.05; font-size:clamp(28px,4vw,46px) }
.cta-inner p  { color:var(--fg2); font-size:16px; margin-top:12px }
.cta-btns     { display:flex; gap:13px; flex-wrap:wrap }
footer { border-top:1px solid var(--border); background:var(--bg-sidebar); padding:64px 0 36px; margin-top:0 }
.footer-grid       { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px }
.footer-brand img  { height:34px; margin-bottom:18px }
.footer-brand p    { font-size:13.5px; color:var(--fg3); line-height:1.6; max-width:320px; margin-bottom:18px }
.footer-contact    { font-style:normal; font-size:13px; color:var(--fg3); line-height:1.8 }
.footer-contact strong { color:var(--fg2) }
.footer-contact a  { color:var(--lime); transition:color .2s }
.footer-contact a:hover { color:var(--lime-400) }
.footer-col h4 { font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--fg4); margin-bottom:16px }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:11px }
.footer-col a  { font-size:13.5px; color:var(--fg2); transition:color .2s }
.footer-col a:hover { color:var(--lime) }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:48px; padding-top:24px; border-top:1px solid var(--border-faint); font-size:13px; color:var(--fg4) }
.footer-links  { display:flex; gap:22px; flex-wrap:wrap }
.footer-links a { color:var(--fg4); transition:color .2s }
.footer-links a:hover { color:var(--fg2) }
.about-hero { padding:128px 0 18px }
.about-hero .eyebrow { margin-bottom:16px }
.about-hero h1 { font-family:var(--font-display); font-weight:800; letter-spacing:-.03em;
  font-size:clamp(36px,5vw,58px); line-height:1.03; margin-bottom:20px; color:var(--fg1) }
.about-lead { color:var(--fg2); font-size:clamp(16px,1.7vw,19px); line-height:1.6; max-width:680px }
.about-lead strong { color:var(--fg1); font-weight:600 }
.snapshot { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start;
  padding:clamp(40px,6vw,72px) 0 }
.snap-facts { display:flex; flex-direction:column; gap:30px }
.snap-block .lbl { font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--lime); margin-bottom:8px }
.snap-block .big { font-family:var(--font-display); font-weight:800; letter-spacing:-.03em;
  font-size:clamp(38px,5vw,54px); line-height:1; color:var(--fg1) }
.snap-block p { color:var(--fg2); font-size:14.5px; line-height:1.6; max-width:380px; margin-top:6px }
.snap-block p strong { color:var(--fg1); font-weight:600 }
.wedo-chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:4px }
.wedo-chip { display:inline-flex; align-items:center; gap:8px; padding:8px 15px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.03); border:1px solid var(--border); font-size:13.5px; font-weight:600; color:var(--fg2) }
.wedo-chip::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--lime); box-shadow:0 0 8px var(--lime) }
.snap-card { position:relative; border:1px solid var(--border-lime); border-radius:var(--r-xl);
  background:linear-gradient(180deg, rgba(163,230,53,.04), var(--bg-inset));
  box-shadow:var(--shadow-lg), 0 0 60px -24px var(--lime-glow); padding:28px; overflow:hidden }
.snap-card .ttl { font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:var(--fg3); margin-bottom:18px }
.snap-prod { display:flex; gap:16px; align-items:flex-start; padding:14px 0 }
.snap-prod + .snap-prod { border-top:1px solid var(--border-faint) }
.snap-prod-ic { width:48px; height:48px; border-radius:13px; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.snap-prod-ic svg { width:24px; height:24px; color:#fff }
.snap-prod-ic.dns  { background:linear-gradient(150deg,#FB923C,#EA580C) }
.snap-prod-ic.ipam { background:linear-gradient(150deg,#60A5FA,#2563EB) }
.snap-prod h3 { font-family:var(--font-display); font-size:18px; font-weight:700; color:var(--fg1); margin-bottom:4px }
.snap-prod p { font-size:13.5px; color:var(--fg3); line-height:1.55 }
.snap-div { height:1px; background:var(--border-faint); margin:18px 0 }
.snap-platforms { display:flex; flex-wrap:wrap; gap:9px }
.plat-chip { font-family:var(--font-mono); font-size:12.5px; color:var(--fg2);
  background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--r-sm); padding:7px 13px }
.snap-card-foot { display:flex; align-items:center; justify-content:space-between; margin-top:20px;
  padding-top:18px; border-top:1px solid var(--border-faint) }
.snap-card-foot .se { font-size:12px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--lime) }
.snap-card-foot .url { display:inline-flex; align-items:center; gap:7px; font-family:var(--font-mono);
  font-size:13px; color:var(--fg3) }
.snap-card-foot .url::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 8px var(--lime) }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:44px }
.value-card { background:rgba(255,255,255,.02); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:24px; transition:transform .25s var(--ease), border-color .25s, background .25s }
.value-card:hover { transform:translateY(-4px); border-color:rgba(163,230,53,.3); background:rgba(255,255,255,.04) }
.value-card .v-ic { width:44px; height:44px; border-radius:12px; background:rgba(163,230,53,.1);
  border:1px solid rgba(163,230,53,.18); display:flex; align-items:center; justify-content:center; margin-bottom:16px }
.value-card .v-ic svg { width:21px; height:21px; color:var(--lime) }
.value-card h3 { font-family:var(--font-display); font-size:17px; font-weight:700; margin-bottom:8px; color:var(--fg1) }
.value-card p { font-size:13.5px; color:var(--fg2); line-height:1.6 }
@media (max-width:900px) {
  .snapshot { grid-template-columns:1fr; gap:36px }
  .values-grid { grid-template-columns:1fr }
  .about-hero { padding-top:104px }
}
.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 }
}
@media (max-width: 1000px) {
  .hero-inner   { grid-template-columns:1fr; gap:44px }
  .hero-visual  { max-width:520px }
  .cap-grid     { grid-template-columns:1fr 1fr }
  .price-grid   { grid-template-columns:1fr; max-width:460px; margin-left:auto; margin-right:auto }
  .how-steps    { grid-template-columns:1fr 1fr }
  .feat-row     { grid-template-columns:1fr; gap:36px }
  .feat-row.reverse .feat-copy { order:0 }
  .stats-strip  { grid-template-columns:1fr 1fr }
  .footer-grid  { grid-template-columns:1fr 1fr }
}
@media (max-width: 680px) {
  .nav-links, .nav-right .nav-signin, .nav-dd { display:none }
  .hamburger        { display:flex }
  .nav-right .btn   { padding:9px 16px; font-size:13px }
  .cap-grid         { grid-template-columns:1fr }
  .how-steps        { grid-template-columns:1fr }
  .addon-grid       { grid-template-columns:1fr }
  .field-row        { grid-template-columns:1fr }
  .footer-grid      { grid-template-columns:1fr 1fr }
  .how-head         { grid-template-columns:1fr }
  .cta-inner        { flex-direction:column; align-items:flex-start }
  .hero             { padding-top:120px }
  
  .hero-glow, .cta-wrap .glowc, .auth-glow { display:none }
  nav.scrolled { backdrop-filter:none; -webkit-backdrop-filter:none; background:rgba(10,11,13,.95) }
}
.mobile-menu {
  position:fixed; inset:0; z-index:99;
  background:rgba(10,11,13,.97);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; opacity:0; visibility:hidden;
  transition:opacity .3s, visibility .3s;
}
.mobile-menu.open { opacity:1; visibility:visible }
.mobile-menu a    { font-size:22px; font-weight:600; color:var(--fg1); padding:14px }
.mobile-menu .btn { margin-top:18px }
