@import url("./primitives.css");
@import url("./tokens.css");

::selection{background:#0054ad;color:#f9fafb}
::-moz-selection{background:#0054ad;color:#f9fafb}

/* =============================================================
   DESIGN TOKENS - PRIMARY #0054ad
============================================================= */
:root {
  --pri:      #0054ad;
  --fs-button: 14px;
  --pri-d:    #003f88;
  --pri-lo:   rgba(0,84,173,.10);
  --pri-lo2:  rgba(0,84,173,.16);
  --pri-glo:  rgba(0,84,173,.30);
  --pri-bdr:  rgba(0,84,173,.28);
  --pri-bdr2: rgba(0,84,173,.50);

  --gold:     #CCDDEF;
  --green:    #22c55e;
  --cyan:     #22d3ee;
  --amber:    #f59e0b;
  --red:      #ef4444;

  --ease:    cubic-bezier(.16,1,.3,1);
  --spring:  cubic-bezier(.34,1.56,.64,1);
  --r:       12px;
  --r-lg:    20px;
  --r-xl:    28px;
  --nav-h:   64px;

  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-7: 3rem;
  --space-8: 4rem;

  --page-section-y: clamp(var(--space-7), 8vw, calc(var(--space-8) * 1.75));
  --page-hero-top: var(--space-6);
  --page-hero-pad-y: clamp(64px, 8vw, 88px);
}

/* ── Dark theme - deep primary-navy ── */
:root,
html[data-theme="dark"],
html[data-theme="system"].os-dark {
  --bg:       #000000;
  --bg2:      #0a0a0a;
  --bg3:      #121212;
  --surf:     rgba(255,255,255,.048);
  --surf2:    rgba(255,255,255,.088);
  --bdr:      rgba(255,255,255,.13);
  --bdr-hi:   var(--pri-bdr);
  --text:     #eceff8;
  --muted:    #9aa8bb;
  --dim:      #32405a;
  --head:     #f2ece4;
  --nav-bg:   rgba(0,0,0,.92);
  --drw-bg:   #0a0a0a;
  --card-bg:  #0a0a0a;
  --code-bg:  #050505;
  --code-border: rgba(255,255,255,.07);
  --code-toolbar-border: rgba(255,255,255,.05);
  --code-comment: #4a5568;
  --code-keyword: #79c0ff;
  --code-string: #a5d6ff;
  --code-number: #ffa657;
  --code-operator: #ff7b72;
  --code-property: #c9d1d9;
  --sh:       0 2px 4px rgba(0,0,0,.40),0 8px 36px rgba(0,0,0,.30);
  --sh-pri:   0 8px 44px rgba(0,84,173,.45);
  --sm1: rgba(0,84,173,.12);
  --sm2: rgba(204,221,239,.07);
  --sm3: rgba(80,40,200,.06);
  --grad: linear-gradient(135deg,var(--head) 0%,var(--pri) 55%,var(--gold) 100%);
  --hero-bg:  #020c1e;
  --hero-orb1: radial-gradient(circle at 28% 28%, rgba(110, 185, 255, .38), rgba(0, 84, 173, .08) 52%, transparent 74%);
  --hero-orb2: radial-gradient(circle at 62% 42%, rgba(0, 84, 173, .40), rgba(0, 84, 173, .10) 56%, transparent 78%);
  --hero-orb3: radial-gradient(circle at 50% 50%, rgba(245, 158, 11, .18), rgba(245, 158, 11, .04) 54%, transparent 78%);
}


/* ── Light theme ── */
html[data-theme="light"],
html[data-theme="system"].os-light {
  --bg:       #edf3fc;
  --bg2:      #ffffff;
  --bg3:      #f5f8fc;
  --surf:     rgba(0,0,0,.038);
  --surf2:    rgba(0,0,0,.072);
  --bdr:      rgba(0,0,0,.082);
  --bdr-hi:   var(--pri-bdr);
  --text:     #0f172a;
  --muted:    #556070;
  --dim:      #94a3b8;
  --head:     #0f172a;
  --nav-bg:   rgba(255,255,255,.92);
  --drw-bg:   #ffffff;
  --card-bg:  #ffffff;
  --code-bg:  #f8fafc;
  --code-border: rgba(15,23,42,.14);
  --code-toolbar-border: rgba(15,23,42,.10);
  --code-comment: #64748b;
  --code-keyword: #1d4ed8;
  --code-string: #0f766e;
  --code-number: #b45309;
  --code-operator: #be123c;
  --code-property: #0f172a;
  --sh:       0 1px 3px rgba(0,0,0,.06),0 8px 32px rgba(0,0,0,.08);
  --sh-pri:   0 8px 44px rgba(0,84,173,.32);
  --sm1: rgba(0,84,173,.07);
  --sm2: rgba(180,140,60,.05);
  --sm3: rgba(80,40,200,.04);
  --grad: linear-gradient(135deg,#0d1629 0%,var(--pri) 55%,var(--gold) 100%);
  --hero-bg:  #dce9f8;
  --hero-orb1: radial-gradient(circle at 25% 30%, rgba(0, 84, 173, .24), rgba(0, 84, 173, .06) 56%, transparent 78%);
  --hero-orb2: radial-gradient(circle at 68% 38%, rgba(59, 130, 246, .24), rgba(59, 130, 246, .07) 58%, transparent 80%);
  --hero-orb3: radial-gradient(circle at 50% 50%, rgba(245, 158, 11, .12), rgba(245, 158, 11, .03) 56%, transparent 78%);
}


/* =============================================================
   RESET + BASE
============================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);color:var(--text);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  padding-top:var(--nav-h);line-height:1.6;
}
@media(max-width:768px){:root{--nav-h:58px}}
h1,h2,h3,h4,h5,h6{font-family:'Poppins',sans-serif;line-height:1.1;color:var(--head);font-weight:700;letter-spacing:-.01em}

/* Heading type utilities (sizing lives here, not on semantic h1-h6 tags) */
.type-display{
  font-size:var(--fs-h1-desktop);
  font-weight:var(--fw-h1);
  letter-spacing:-.03em;
  line-height:1.02;
}
.type-section{
  font-size:var(--fs-h2-desktop);
  font-weight:var(--fw-h2);
  letter-spacing:-.02em;
  line-height:1.08;
}
.type-card-title{
  font-size:var(--type-card-title);
  font-weight:var(--fw-h4);
  letter-spacing:-.015em;
  line-height:1.2;
}
.type-eyebrow,
.type-label{
  font-family:'Inter',sans-serif;
  font-size:11px;
  font-weight:600;
  line-height:1.25;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
}
p{font-size:var(--fs-body-desktop);font-weight:var(--fw-body);line-height:1.6;max-width:68ch}
small,.text-small,.meta{font-size:var(--fs-small-desktop);font-weight:var(--fw-small);line-height:1.5}
a{text-decoration:none;color:inherit}
button{font-family:'Inter',sans-serif;cursor:pointer;border:none;background:none}
button,.btn{font-size:var(--fs-button);text-transform:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--pri);outline-offset:2px;border-radius:4px}

html.t-anim *,html.t-anim *::before,html.t-anim *::after{
  transition:background-color .3s ease,border-color .3s ease,
    color .3s ease,box-shadow .3s ease !important;
}

body::after{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:.020;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Responsive typography scale */
@media (max-width: 1024px) {
  .type-display { font-size: var(--fs-h1-tablet); }
  .type-section { font-size: var(--fs-h2-tablet); }
  p { font-size: var(--fs-body-tablet); }
  small, .text-small, .meta { font-size: var(--fs-small-tablet); }
}

@media (max-width: 768px) {
  .type-display { font-size: var(--fs-h1-mobile); }
  .type-section { font-size: var(--fs-h2-mobile); }
  .type-eyebrow,
  .type-label { font-size: 10px; }
  p { font-size: var(--fs-body-mobile); }
  small, .text-small, .meta { font-size: var(--fs-small-mobile); }

  .btn:not(.nav-start-global),
  button:not(.ham):not(.drw-close):not(.nav-start-global) {
    min-height: 48px;
  }
}

section:not(.hero-sec) {
  margin-block: 0;
  padding-block: var(--page-section-y);
}

main > .page-hero:first-of-type {
  margin-block-start: 0;
  padding-block-start: var(--page-hero-top);
}

main > .page-section:first-of-type {
  padding-block-start: var(--page-section-y);
}

main > section:first-child,
#main-content > section:first-child {
  margin-block-start: 0;
}

/* =============================================================
   AMBIENT GLOWS
============================================================= */
.amb{position:fixed;pointer-events:none;z-index:0;border-radius:50%;filter:blur(110px)}
.amb1{width:800px;height:800px;top:-260px;right:-200px;
  background:radial-gradient(circle,rgba(0,84,173,.08) 0%,transparent 70%)}
.amb2{width:500px;height:500px;bottom:-120px;left:-150px;
  background:radial-gradient(circle,rgba(204,221,239,.055) 0%,transparent 70%)}

/* =============================================================
   LAYOUT
============================================================= */
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
@media(max-width:1024px){.wrap{padding:0 28px}}
@media(max-width:768px){.wrap{padding:0 20px}}

/* =============================================================
   ATOMS
============================================================= */
.pill{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'Inter',sans-serif;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--pri);background:var(--pri-lo);
  border:1px solid var(--pri-bdr);
  padding:5px 13px;border-radius:999px;
}
.pill .dot{width:5px;height:5px;border-radius:50%;background:var(--pri);animation:blink 2s ease-in-out infinite}
.pill.no-uppercase{text-transform:none;letter-spacing:.02em}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}

.gt{color:var(--pri);background:none;-webkit-background-clip:initial;-webkit-text-fill-color:currentColor;background-clip:initial}

/* Buttons - pill shape */
.btn i{font-size:17px;line-height:1}
.btn-p{background:var(--pri);color:#F9FAFB}
.btn-p:hover{box-shadow:var(--interactive-hover-shadow)}
.btn-o{background:transparent;color:var(--muted);border:1px solid var(--bdr)}
.btn-o:hover{background:var(--surf2);color:var(--text);border-color:var(--interactive-border-contrast)}

/* Section head helpers */
.slbl{margin-bottom:16px}
.sh2{font-size:var(--type-section);font-weight:700;letter-spacing:-.03em;color:var(--head)}
.ss{font-size:var(--type-body);color:var(--muted);line-height:1.8;max-width:460px;margin-top:14px}

/* Scroll reveal */
.rv{opacity:0;transform:translateY(22px);transition:opacity .72s var(--ease),transform .72s var(--ease)}
.rv.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.10s}.d2{transition-delay:.20s}.d3{transition-delay:.30s}
.d4{transition-delay:.40s}.d5{transition-delay:.50s}

/* =============================================================
   SMOKE CARDS + ICON OVERLAY + VERTICAL LABEL
============================================================= */
.smoke{position:relative;overflow:hidden}
.smoke::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 8%  25%,var(--sm1) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 80%,var(--sm2) 0%,transparent 55%),
    radial-gradient(ellipse 50% 60% at 50%  0%, var(--sm3) 0%,transparent 50%);
  opacity:.8;transition:opacity .4s;
}
.smoke:hover::before{opacity:1}
.io{
  position:absolute;right:-18px;bottom:-18px;
  font-size:120px;line-height:1;
  color:var(--pri);opacity:.04;
  pointer-events:none;z-index:0;
  transition:opacity .4s,transform .45s var(--ease);
}
.smoke:hover .io{opacity:.09;transform:scale(1.07) rotate(-5deg)}
.z{position:relative;z-index:1}

.ghost{
  position:absolute;right:-8px;top:-6px;
  font-family:'Poppins',sans-serif;font-size:96px;font-weight:900;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(0,84,173,.09);
  pointer-events:none;user-select:none;z-index:0;
}

/* Vertical card label */
.vert{
  position:absolute;left:0;top:0;bottom:0;width:44px;
  display:flex;align-items:center;justify-content:center;
  writing-mode:vertical-lr;transform:rotate(180deg);
  font-family:'Poppins',sans-serif;font-size:8px;font-weight:700;
  letter-spacing:.24em;text-transform:uppercase;color:var(--dim);
  border-right:1px solid var(--bdr);z-index:2;
  background:linear-gradient(180deg,transparent,var(--pri-lo),transparent);
}
@media(max-width:1024px){.vert{display:none}}

/* =============================================================
   NAVBAR
============================================================= */
nav#mainNav{
  position:fixed;inset:0 0 auto;z-index:900;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  width:min(1240px,100%);
  left:50%;
  right:auto;
  transform:translateX(-50%);
  padding:0 40px;
  background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid var(--bdr);
  transition:background .3s,border-color .3s;
}
@supports(padding-left:env(safe-area-inset-left)){
  nav#mainNav{
    padding-left:max(40px,env(safe-area-inset-left));
    padding-right:max(40px,env(safe-area-inset-right));
  }
}
@media(max-width:1024px){nav#mainNav{padding:0 24px}}
@media(max-width:768px){nav#mainNav{padding:0 16px}}

.nav-logo{
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  font-family:'Poppins',sans-serif;font-size:18px;font-weight:700;
  letter-spacing:-.03em;color:var(--text);
}
.nav-logo-mark{
  width:30px;height:30px;border-radius:8px;
  background:linear-gradient(135deg,var(--pri),var(--pri-d));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px var(--pri-glo);flex-shrink:0;
}
.nav-logo-mark i{font-size:16px;color:#F9FAFB}

.nav-links{
  display:flex;align-items:center;gap:2px;
  position:absolute;left:0;transform:none;
}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--muted);
  padding:7px 14px;border-radius:8px;
  transition:color .15s,background .15s;
}
.nav-links a:hover{color:var(--text);background:var(--surf)}
@media(max-width:768px){.nav-links{display:none}}

.nav-r{display:flex;align-items:center;gap:8px;flex-shrink:0}

.nav-chip{
  display:flex;align-items:center;gap:7px;
  font-family:'Inter',sans-serif;font-size:10px;
  color:var(--muted);background:var(--surf);
  border:1px solid var(--bdr);padding:5px 12px;border-radius:999px;white-space:nowrap;
}
.ndot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--green);animation:blink 2s infinite}
@media(max-width:768px){.nav-chip{display:none}}

/* "Start" nav button - always visible beside hamburger */
.nav-start{
  display:flex;
  padding:8px 4px;
}

/* Hamburger - polished rounded square */
.ham{
  width:35px;height:35px;border-radius:8px;
  background:var(--surf);border:1px solid var(--bdr);
  display:none;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;
  transition:background .2s,border-color .2s,box-shadow .2s;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  box-shadow:0 1px 3px rgba(0,0,0,.12);
}
.ham:hover{background:var(--surf2);border-color:var(--bdr-hi);box-shadow:0 2px 8px rgba(0,84,173,.18)}
.ham span{
  display:block;height:1.5px;border-radius:2px;background:var(--text);
  transition:width .36s var(--ease),transform .36s var(--ease);
}
.ham span:nth-child(1){width:20px}
.ham span:nth-child(2){width:13px}
.ham.open span:nth-child(1){width:18px;transform:translateY(4.25px) rotate(45deg)}
.ham.open span:nth-child(2){width:18px;transform:translateY(-4.25px) rotate(-45deg)}
@media(max-width:768px){.ham{display:flex}}

/* =============================================================
   DRAWER - minimalist, stunning
============================================================= */
.drw-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;
  transition:opacity .38s ease;
}
.drw-overlay.open{opacity:1;pointer-events:auto}

.drw{
  position:fixed;top:0;right:0;bottom:0;z-index:1001;
  width:320px;max-width:90vw;
  background:var(--drw-bg);
  border-left:1px solid var(--bdr);
  display:flex;flex-direction:column;
  transform:translateX(110%);
  transition:transform .44s var(--ease);
  overflow:hidden;
}
.drw.open{transform:translateX(0)}
@supports(padding-right:env(safe-area-inset-right)){.drw{padding-right:env(safe-area-inset-right)}}
@supports(padding-bottom:env(safe-area-inset-bottom)){.drw{padding-bottom:env(safe-area-inset-bottom)}}

/* Glowing left edge */
.drw::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:2px;z-index:3;
  background:linear-gradient(180deg,transparent 0%,var(--pri) 35%,var(--gold) 70%,transparent 100%);
  opacity:.7;
}

/* Deep ambient inside drawer */
.drw-amb{
  position:absolute;bottom:-80px;right:-80px;
  width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,var(--pri-lo) 0%,transparent 70%);
  pointer-events:none;z-index:0;
}

/* ── Drawer header - mirrors navbar ── */
.drw-header{
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;
  position:relative;z-index:2;flex-shrink:0;
  border-bottom:1px solid var(--bdr);
  background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
}
.drw-close{
  width:34px;height:34px;border-radius:10px;
  background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;
  color:var(--dim);font-size:17px;
  transition:background .2s,color .2s,border-color .2s;
  touch-action:manipulation;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.drw-close:hover{background:rgba(239,68,68,.12);color:var(--red);border-color:rgba(239,68,68,.3)}

/* ── Drawer body ── */
.drw-body{flex:1;overflow-y:auto;position:relative;z-index:1;padding:20px 0 8px;-webkit-overflow-scrolling:touch}
.drw-body::-webkit-scrollbar{width:2px}
.drw-body::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:2px}

/* Nav links */
.drw-nav{padding:0 16px;display:flex;flex-direction:column;gap:2px}
.drw-nav a,
.drw-nav span.is-disabled{
  display:flex;align-items:center;gap:14px;
  padding:13px 14px;border-radius:11px;
  font-size:14.5px;font-weight:500;color:var(--muted);
  border:1px solid transparent;
  -webkit-tap-highlight-color:transparent;position:relative;
}
.drw-nav a i.ni,
.drw-nav span.is-disabled i.ni{font-size:19px;color:var(--dim);transition:color .15s;flex-shrink:0}
.drw-nav a .nb{
  margin-left:auto;font-size:9px;font-family:'Inter',sans-serif;font-weight:700;
  letter-spacing:.06em;background:var(--pri-lo);color:var(--pri);
  border:1px solid var(--pri-bdr);padding:2px 7px;border-radius:999px;
}
.drw-nav a:hover{background:var(--surf2);color:var(--text)}
.drw-nav a:hover i.ni{color:var(--pri)}

/* Thin divider */
.drw-line{height:1px;background:var(--bdr);margin:16px 28px}

/* ── Drawer footer ── */
.drw-foot{
  padding:20px 28px 24px;
  border-top:1px solid var(--bdr);
  position:relative;z-index:2;flex-shrink:0;
}

/* Social row */
.drw-socials{display:flex;gap:7px;margin-bottom:16px}
.drw-theme-toggle{
  width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  margin-bottom:16px;padding:10px 12px;border-radius:10px;
  border:1px solid var(--bdr);background:var(--surf);color:var(--text);
  font:600 12px/1.3 'Inter',sans-serif;cursor:pointer;
}
.drw-theme-toggle:hover{border-color:var(--pri-bdr);background:var(--pri-lo);color:var(--pri)}
.dsoc{
  width:34px;height:34px;border-radius:9px;
  background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:16px;
}
.dsoc:hover{background:var(--pri-lo);color:var(--pri);border-color:var(--pri-bdr)}

/* CTA */
.drw-cta{
  display:flex;align-items:center;justify-content:center;gap:9px;
  width:100%;padding:14px 24px;border-radius:11px;
  background:var(--pri);color:#F9FAFB;font-size:14.5px;font-weight:700;
  letter-spacing:-.01em;
  transition:box-shadow .22s,transform .22s var(--ease);
  touch-action:manipulation;position:relative;overflow:hidden;
}
.drw-cta::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.14) 0%,transparent 60%);pointer-events:none}
.drw-cta i{font-size:18px}
.drw-cta:hover{box-shadow:var(--interactive-hover-shadow);transform:translateY(calc(-1 * var(--interactive-hover-lift)))}

/* =============================================================
   HERO
============================================================= */
.hero-wrap{
  position:relative;
  border-bottom:1px solid var(--bdr);
  box-shadow:0 8px 48px rgba(0,0,0,.18),0 1px 0 var(--bdr);
  margin-bottom:0;
}
/* Hero section wrapper */
.hero-sec{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--bdr);
  background:
    radial-gradient(120% 95% at 8% 5%, color-mix(in srgb, var(--pri) 28%, transparent), transparent 62%),
    radial-gradient(90% 70% at 92% 18%, color-mix(in srgb, var(--gold) 14%, transparent), transparent 68%),
    linear-gradient(155deg,
      color-mix(in srgb,var(--card-bg) 88%,var(--pri) 12%) 0%,
      color-mix(in srgb,var(--card-bg) 95%,var(--bg2) 5%) 55%,
      color-mix(in srgb,var(--card-bg) 88%,var(--pri) 12%) 100%
    );
  isolation:isolate;
}

.landing-hero::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    linear-gradient(115deg, transparent 0%, color-mix(in srgb, var(--pri) 12%, transparent) 48%, transparent 100%),
    repeating-linear-gradient(120deg, color-mix(in srgb,var(--bdr) 82%,transparent) 0 1px, transparent 1px 32px);
  opacity:.34;
  -webkit-mask-image:radial-gradient(ellipse 84% 74% at 50% 38%, black 32%, transparent 86%);
  mask-image:radial-gradient(ellipse 84% 74% at 50% 38%, black 32%, transparent 86%);
}

.landing-hero::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:radial-gradient(64% 58% at 50% 42%, color-mix(in srgb, var(--pri) 22%, transparent), transparent 76%);
  mix-blend-mode:soft-light;
  opacity:.55;
}

.landing-hero-inner{
  position:relative;
  z-index:1;
  max-width:760px;
  margin:0 auto;
  text-align:center;
  padding:clamp(64px,8vw,94px) 40px clamp(58px,7vw,84px);
}

.landing-orb{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  background:var(--hero-orb1);
}
.landing-orb1{width:320px;height:320px;top:-110px;left:-90px;background:var(--hero-orb2);filter:blur(2px)}
.landing-orb2{width:210px;height:210px;top:40px;right:46px;background:var(--hero-orb1);filter:blur(1px)}
.landing-orb3{width:120px;height:120px;top:175px;right:230px;background:var(--hero-orb2)}
.landing-orb4{width:130px;height:130px;bottom:18px;left:100px;background:var(--hero-orb3)}
.landing-orb5{width:290px;height:290px;bottom:-120px;right:-70px;background:var(--hero-orb2);filter:blur(2px)}

.hero-pill{font-family:'Inter',sans-serif;letter-spacing:.12em;text-transform:uppercase;color:var(--pri);background:var(--pri-lo);border-color:var(--pri-bdr)}
.hero-pill i{font-size:12px;color:var(--pri)}

.hero-heading-group{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.hero-heading-group .hero-pill{
  margin-bottom:14px;
}

.hero-heading-group .hero-title{
  margin-top:0;
}

.hero-title-stroke{color:var(--head)}
.hero-title-stroke .h-em{color:var(--pri);-webkit-background-clip:initial;-webkit-text-fill-color:initial;background:transparent;-webkit-text-stroke:0;filter:none}
.hero h1,
.landing-hero h1{font-size:clamp(42px,6.6vw,84px);font-weight:800;letter-spacing:-.04em;color:var(--head);line-height:1.03;margin-top:18px}
.hero-sub-hero{color:var(--muted);max-width:60ch;margin:20px auto 0;line-height:1.74}

.hero-proof{
  list-style:none;
  margin:24px auto 0;
  padding:0;
  max-width:720px;
  display:grid;
  gap:10px;
  text-align:left;
}
.hero-proof li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  border:1px solid var(--bdr);
  border-radius:12px;
  background:color-mix(in srgb,var(--card-bg) 92%,var(--pri) 8%);
  color:var(--text);
  line-height:1.5;
  font-size:14.5px;
}
.hero-proof i{color:var(--pri);font-size:16px;transform:translateY(1px)}
.hero-ctas{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:30px;flex-wrap:wrap}
.hero-ctas-hero .btn-o{background:transparent;color:var(--muted);border:1px solid var(--bdr)}
.hero-ctas-hero .btn-o:hover{background:var(--surf2);color:var(--text);border-color:var(--bdr-hi)}

@media(max-width:768px){
  .landing-hero-inner{padding:58px 20px 64px}
  .landing-orb2{right:14px}
  .landing-orb3{right:92px;top:160px}
  .hero-proof{margin-top:20px}
  .hero-proof li{font-size:14px;padding:11px 12px}
}

/* =============================================================
   MARQUEE
============================================================= */
.mq-i i{font-size:13px;color:var(--pri)}

/* =============================================================
   STATEMENT
============================================================= */
.stmt{padding:120px 0}
@media(max-width:768px){.stmt{padding:80px 0}}

.stmt-h{font-size:clamp(30px,3.8vw,50px);font-weight:800;letter-spacing:-.034em;color:var(--head)}
.stmt-body{font-size:15.5px;color:var(--muted);line-height:1.8;margin-top:16px;max-width:420px}

/* =============================================================
   ENGINE SECTION
============================================================= */
.eng{padding:120px 0}
@media(max-width:768px){.eng{padding:80px 0}}
.sec-hdr{margin-bottom:56px}

.eng-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--bdr);border-radius:var(--r-lg);
  overflow:hidden;background:var(--bdr);gap:1px;
  max-width:1180px;margin:0 auto;
}
@media(max-width:1060px){.eng-grid{grid-template-columns:1fr}}

.ec{
  background:var(--card-bg);padding:38px;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:var(--interactive-transition);
  border:1px solid transparent;
}
.ec:hover{background:var(--bg3);border-color:var(--interactive-border-contrast);transform:translateY(calc(-1 * var(--interactive-hover-lift)))}
.ec.first{padding-left:52px}

.ec-tag{font-family:'Inter',sans-serif;font-size:9px;text-transform:uppercase;letter-spacing:.12em;color:var(--pri);margin-bottom:6px;position:relative;z-index:1}
.ec-h{font-family:'Poppins',sans-serif;font-size:var(--type-card-title);font-weight:700;letter-spacing:-.015em;line-height:1.2;color:var(--head);margin-bottom:10px;position:relative;z-index:1}
.ec-d{font-size:13px;color:var(--muted);line-height:1.7;position:relative;z-index:1;flex:1}
.ec-ico-wrap{
  width:44px;height:44px;border-radius:11px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;color:var(--pri);
  margin-bottom:22px;flex-shrink:0;position:relative;z-index:1;
}
.steps{display:flex;flex-direction:column;margin-top:18px;position:relative;z-index:1}
.si{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--bdr)}
.si:last-child{border-bottom:none}
.sn{
  width:24px;height:24px;border-radius:50%;background:var(--pri);color:#F9FAFB;
  font-size:10px;font-weight:700;font-family:'Inter',sans-serif;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.si-t{font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.si-d{font-size:12px;color:var(--muted);line-height:1.55}
.cw{margin-top:20px;background:var(--code-bg);border-radius:10px;border:1px solid var(--code-border);overflow:hidden;position:relative;z-index:1}
.cw-bar{padding:9px 12px;border-bottom:1px solid var(--code-toolbar-border);display:flex;align-items:center;gap:5px}
.cwd{width:8px;height:8px;border-radius:50%}
.cwd:nth-child(1){background:#ff5f57}.cwd:nth-child(2){background:#ffbd2e}.cwd:nth-child(3){background:#28c940}
pre{padding:14px 16px;font-family:'Inter',sans-serif;font-size:11.5px;line-height:1.85;overflow-x:auto;tab-size:2}
.cc{color:var(--code-comment)}.ck{color:var(--code-keyword)}.cs{color:var(--code-string)}.cn{color:var(--code-number)}.co{color:var(--code-operator)}.cp{color:var(--code-property)}
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:18px;position:relative;z-index:1}
.chip{background:var(--surf);border-color:var(--bdr);color:var(--muted)}
.chip i{font-size:12px;color:var(--pri)}
.docs-link{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:600;color:var(--pri);
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  padding:9px 16px;border-radius:9px;margin-top:18px;
  position:relative;z-index:1;
  transition:background .2s,box-shadow .2s;
}
.docs-link:hover{background:var(--pri-lo2);box-shadow:0 4px 18px var(--pri-glo)}
.docs-link i{font-size:14px}
.enforcement-mobile{display:none}
.enforcement-mobile-card{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px;border-radius:10px;
  border:1px solid var(--bdr);
  background:var(--card-bg);
}
.enforcement-mobile-card + .enforcement-mobile-card{margin-top:8px}
.enforcement-mobile-num{
  width:24px;height:24px;border-radius:999px;
  background:var(--pri);color:#F9FAFB;
  display:inline-flex;align-items:center;justify-content:center;
  font:700 10px/1 'Inter',sans-serif;flex-shrink:0;
}
.enforcement-mobile-card h4{
  margin:1px 0 2px;
  font-family:'Poppins',sans-serif;
  font-size:12.5px;font-weight:600;color:var(--text);
}
.enforcement-mobile-card p{
  margin:0;
  font-size:11.5px;line-height:1.5;color:var(--muted);
}
@media(max-width:768px){
  .enforcement-steps-desktop{display:none}
  .enforcement-mobile{display:block;margin-top:18px}
}

/* =============================================================
   GOVERNANCE
============================================================= */
.gov{padding:0 0 120px}
@media(max-width:768px){.gov{padding-bottom:80px}}
.gov-g{display:grid;grid-template-columns:9fr 7fr;gap:20px;align-items:stretch}
@media(max-width:1100px){.gov-g{grid-template-columns:1fr}}

.gov-big{
  background:var(--card-bg);border:1px solid var(--bdr);
  border-radius:var(--r-lg);padding:48px;
  display:flex;flex-direction:column;
}
@media(max-width:768px){.gov-big{padding:30px}}
.gov-h{font-size:clamp(24px,2.8vw,34px);font-weight:800;letter-spacing:-.033em;color:var(--head);line-height:1.12;margin-bottom:12px;position:relative;z-index:1}
.gov-d{font-size:14px;color:var(--muted);line-height:1.78;max-width:440px;margin-bottom:28px;position:relative;z-index:1}

.twin{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px;position:relative;z-index:1}
@media(max-width:600px){.twin{grid-template-columns:1fr}}
.ts{
  background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);
  padding:20px;transition:border-color .25s;
}
.ts:hover{border-color:var(--bdr-hi)}
.ts-v{font-family:'Poppins',sans-serif;font-size:34px;font-weight:800;letter-spacing:-.04em;color:var(--head);line-height:1}
.ts-a{font-size:16px;color:var(--pri)}
.ts-l{font-size:11.5px;color:var(--muted);margin-top:7px}

.mini-list{display:flex;flex-direction:column;gap:8px;position:relative;z-index:1}
.mi{
  display:flex;align-items:flex-start;gap:12px;
  padding:13px 14px;border-radius:var(--r);
  background:var(--surf);border:1px solid var(--bdr);
  position:relative;overflow:hidden;
  transition:border-color .2s,transform .22s var(--ease);
}
.mi::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 0% 50%,var(--sm1) 0%,transparent 65%);
  opacity:0;pointer-events:none;transition:opacity .3s;z-index:0;
}
.mi:hover{border-color:var(--bdr-hi);transform:translateX(4px)}
.mi:hover::before{opacity:1}
.mi-ico{width:30px;height:30px;border-radius:8px;background:var(--pri-lo);border:1px solid var(--pri-bdr);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--pri);flex-shrink:0;position:relative;z-index:1}
.mi-t{font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;position:relative;z-index:1}
.mi-d{font-size:12px;color:var(--muted);line-height:1.55;position:relative;z-index:1}

.gov-side{display:flex;flex-direction:column;gap:20px}
.sc{
  background:var(--card-bg);border:1px solid var(--bdr);border-radius:var(--r-lg);
  padding:30px;flex:1;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:border-color .25s;
}
.sc:hover{border-color:var(--bdr-hi)}
.sc-h{font-family:'Poppins',sans-serif;font-size:17px;font-weight:700;color:var(--head);margin-bottom:8px;position:relative;z-index:1}
.sc-d{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:18px;position:relative;z-index:1}
.sc-rows{display:flex;flex-direction:column;gap:8px;position:relative;z-index:1}
.sr{
  display:flex;align-items:flex-start;gap:11px;
  padding:11px 12px;border-radius:9px;
  background:var(--surf);border:1px solid var(--bdr);transition:border-color .2s;
}
.sr:hover{border-color:var(--bdr-hi)}
.sr-ico{width:30px;height:30px;border-radius:8px;background:var(--pri-lo);border:1px solid var(--pri-bdr);display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--pri);flex-shrink:0}
.sr-t{font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:1px;font-family:'Poppins',sans-serif}
.sr-d{font-size:11.5px;color:var(--muted);line-height:1.45}

/* =============================================================
   PROTECTION
============================================================= */
.prot{padding:0 0 120px}
@media(max-width:768px){.prot{padding-bottom:80px}}
.prot-g{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--bdr);border-radius:var(--r-lg);
  overflow:hidden;background:var(--bdr);gap:1px;
}
@media(max-width:1060px){.prot-g{grid-template-columns:1fr}}

.pc{
  background:var(--card-bg);padding:36px 30px;
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:var(--interactive-transition);
  border:1px solid transparent;
}
.pc:hover{background:var(--bg3);border-color:var(--interactive-border-contrast);transform:translateY(calc(-1 * var(--interactive-hover-lift)))}
.pc.first{padding-left:52px}

.pbadge{
  display:inline-flex;align-items:center;gap:5px;
  width:fit-content;max-width:100%;
  font-family:'Inter',sans-serif;font-size:9px;
  text-transform:none;letter-spacing:.08em;
  padding:4px 10px;border-radius:999px;
  margin-bottom:24px;align-self:flex-start;position:relative;z-index:1;
}
.pbadge i{font-size:12px}
.pbadge.g{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.22)}
.pbadge.b{background:var(--pri-lo);color:var(--pri);border:1px solid var(--pri-bdr)}
.pbadge.a{background:rgba(245,158,11,.1);color:var(--amber);border:1px solid rgba(245,158,11,.22)}

.p-t{font-family:'Poppins',sans-serif;font-size:var(--type-card-title);font-weight:700;color:var(--head);letter-spacing:-.015em;line-height:1.2;margin-bottom:8px;position:relative;z-index:1}
.p-d{font-size:13px;color:var(--muted);line-height:1.72;margin-bottom:22px;position:relative;z-index:1}
.p-list{display:flex;flex-direction:column;gap:9px;flex:1;position:relative;z-index:1}
.pi{display:flex;align-items:flex-start;gap:10px}
.pi-ico{width:27px;height:27px;border-radius:7px;background:var(--pri-lo);border:1px solid var(--pri-bdr);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--pri);flex-shrink:0}
.pi-t{font-family:'Poppins',sans-serif;font-size:12.5px;font-weight:600;color:var(--text);margin-bottom:1px}
.pi-d{font-size:11.5px;color:var(--muted);line-height:1.5}

/* =============================================================
   CTA
============================================================= */
.cta-s{padding:0 0 120px}
@media(max-width:768px){.cta-s{padding-bottom:80px}}
.cta-b{
  background:var(--bg2);border:1px solid var(--bdr);
  border-radius:var(--r-xl);padding:90px 80px;text-align:center;
  position:relative;overflow:hidden;
}
@media(max-width:1024px){.cta-b{padding:64px 44px}}
@media(max-width:768px){.cta-b{padding:52px 28px}}
.cta-b::before{
  content:'';position:absolute;inset:-24%;
  background:
    radial-gradient(ellipse 72% 52% at 18% 24%,color-mix(in srgb,var(--pri) 32%,transparent) 0%,transparent 68%),
    radial-gradient(ellipse 68% 52% at 86% 70%,color-mix(in srgb,var(--gold) 22%,transparent) 0%,transparent 70%),
    radial-gradient(ellipse 85% 62% at 50% -8%,var(--pri-glo) 0%,transparent 66%);
  opacity:.75;
  pointer-events:none;
  will-change:transform,opacity;
  animation:ctaSmokeDrift 17s ease-in-out infinite alternate;
}
.cta-b::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--pri-glo),transparent);
}
@keyframes ctaSmokeDrift{
  0%{transform:translate3d(-1.5%,0,0) scale(1);opacity:.62}
  50%{transform:translate3d(1.2%,-2.2%,0) scale(1.04);opacity:.8}
  100%{transform:translate3d(.2%,2.2%,0) scale(1.08);opacity:.66}
}
@media (prefers-reduced-motion:reduce){
  .cta-b::before{animation:none}
}
.cta-h{font-size:clamp(30px,5vw,58px);font-weight:900;letter-spacing:-.04em;color:var(--head);line-height:1.06;margin-bottom:16px;position:relative;z-index:1}
.cta-sub{font-size:15.5px;color:var(--muted);max-width:420px;margin:0 auto 34px;line-height:1.75;position:relative;z-index:1}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

.hero-title{font-size:clamp(2rem,8vw,4.5rem);line-height:1.06}
.sh2{font-size:clamp(1.35rem,4.4vw,2.6rem);line-height:1.16}

.br-swiper-label{font-family:'Inter',sans-serif;font-size:9px;letter-spacing:.08em;color:var(--dim);text-transform:none}
.br-swiper-nav-group{display:flex;align-items:center;gap:8px}
.br-swiper-btn{
  width:34px;height:34px;border-radius:10px;border:1px solid var(--bdr);
  background:var(--card-bg);color:var(--text);display:grid;place-items:center;
}
.br-swiper-dots{display:flex;align-items:center;gap:6px}
.swiper-next-preview{
  margin-top:10px;font-size:12px;color:var(--muted);display:-webkit-box;
  -webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;
}

/* =============================================================
   FAQ
============================================================= */
.faq{padding:0 0 140px}
@media(max-width:768px){.faq{padding-bottom:90px}}
.faq-lay{display:grid;grid-template-columns:5fr 8fr;gap:80px;align-items:start}
@media(max-width:1024px){.faq-lay{grid-template-columns:1fr;gap:32px}}
.faq-l{position:sticky;top:calc(var(--nav-h) + 20px)}
@media(max-width:1024px){.faq-l{position:static}}

.faq-list{
  display:flex;flex-direction:column;gap:1px;
  background:var(--bdr);border:1px solid var(--bdr);
  border-radius:var(--r-lg);overflow:hidden;
}
.fi2{background:var(--card-bg);overflow:hidden;transition:background .2s}
.fi2:hover,.fi2.open{background:var(--bg3)}
.fi-q{
  padding:20px 24px;display:flex;align-items:center;
  justify-content:space-between;cursor:pointer;gap:16px;user-select:none;
}
.fi-q:focus-visible{outline:2px solid var(--pri);outline-offset:-2px}
.fi-meta{display:flex;flex-direction:column;gap:8px;min-width:0}
.fi-topic{
  width:max-content;padding:4px 10px;border-radius:999px;
  border:1px solid var(--pri-bdr);background:var(--pri-lo);
  font-size:10px;line-height:1;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--pri);
}
.fi-txt{font-size:14px;font-weight:600;color:var(--text);line-height:1.45}
.fi-read{
  font-size:11.5px;line-height:1.2;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--dim);
}
.fi-arr{
  width:28px;height:28px;border-radius:50%;flex-shrink:0;
  background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:15px;
  transition:transform .3s var(--ease),background .2s,border-color .2s,color .2s;
}
.fi2.open .fi-arr{transform:rotate(180deg);background:var(--pri-lo);border-color:var(--pri-bdr);color:var(--pri)}
.fi-body{
  height:0;
  overflow:hidden;
  visibility:hidden;
  transition:height .34s cubic-bezier(.22,.61,.36,1),visibility 0s linear .34s;
  will-change:height;
}
.fi2.open .fi-body{
  visibility:visible;
  transition:height .34s cubic-bezier(.22,.61,.36,1),visibility 0s linear 0s;
}
.fi-body-inner{overflow:hidden}
.fi-inner{
  margin-top:10px;
  padding:0 24px 20px;
  font-size:14px;
  color:var(--muted);
  line-height:1.8;
  max-width:70ch;
}
@media(max-width:768px){
  .fi-q{padding:16px 18px}
  .fi-inner{padding:0 18px 16px}
}
@media (prefers-reduced-motion:reduce){
  .fi-body{
    transition:none;
    will-change:auto;
  }
}

/* =============================================================
   FOOTER - complete, responsive, theme switcher
============================================================= */
footer{background:var(--bg2);border-top:1px solid var(--bdr)}

.ft-main{
  padding:64px 0 0;
  display:grid;grid-template-columns:repeat(6,1fr);gap:32px;
}
@media(max-width:1100px){.ft-main{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.ft-main{grid-template-columns:repeat(2,1fr);padding:48px 0 0}}
@media(max-width:360px){.ft-main{grid-template-columns:1fr}}

.ft-col-h{
  font-family:'Inter',sans-serif;font-size:9.5px;
  text-transform:uppercase;letter-spacing:.13em;color:var(--dim);margin-bottom:18px;
}
.ft-links{display:flex;flex-direction:column;gap:12px}
.ft-links a{
  display:flex;align-items:center;gap:6px;
  font-size:13.5px;color:var(--muted);transition:color .15s;
}
.ft-links a i{font-size:12px;opacity:0;color:var(--pri);transition:opacity .15s}
.ft-links a:hover{color:var(--text)}
.ft-links a:hover i{opacity:1}

/* Newsletter */
.ft-nl{
  padding:30px 0;border-top:1px solid var(--bdr);margin-top:48px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
@media(max-width:640px){.ft-nl{flex-direction:column;align-items:flex-start;margin-top:36px}}
.ft-nl-form{display:flex;gap:8px;flex-wrap:wrap}
.ft-nl-form input{
  background:var(--bg2);border:1px solid var(--bdr);border-radius:999px 0 0 999px;border-right:none;
  padding:9px 16px;font-size:13px;color:var(--text);
  font-family:'Inter',sans-serif;outline:none;width:220px;
  transition:border-color .2s;
}
.ft-nl-form input::placeholder{color:var(--dim)}
.ft-nl-form input:focus{border-color:var(--bdr-hi)}
@media(max-width:640px){.ft-nl-form input{width:100%}.ft-nl-form{width:100%}}

/* Bottom bar */
.ft-btm{
  padding:20px 0;border-top:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
@media(max-width:900px){.ft-btm{flex-direction:column;align-items:flex-start;gap:14px}}
.ft-copy{font-size:12px;color:var(--dim)}
.ft-socs{display:flex;gap:7px}
.fsoc{
  width:32px;height:32px;border-radius:8px;
  background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:15px;
  transition:background .2s,color .2s,border-color .2s;
}
.fsoc:hover{background:var(--pri-lo);color:var(--pri);border-color:var(--pri-bdr)}
.ft-legal{display:flex;gap:18px;flex-wrap:wrap}
.ft-legal a{font-size:12px;color:var(--dim);transition:color .15s}
.ft-legal a:hover{color:var(--muted)}

/* ── THEME SWITCHER (drop-up) ── */
.theme-sw{position:relative;display:inline-flex}

.tsw-btn{
  display:flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:9px;
  background:var(--surf);border:1px solid var(--bdr);
  font-size:12.5px;font-weight:500;color:var(--muted);
  transition:background .2s,border-color .2s,color .2s;
  cursor:pointer;
}
.tsw-btn:hover{background:var(--surf2);border-color:var(--bdr-hi);color:var(--text)}
.tsw-btn i{font-size:16px}
.tsw-btn .caret{font-size:12px;margin-left:2px;transition:transform .25s var(--ease)}
.theme-sw.open .tsw-btn .caret{transform:rotate(180deg)}

/* Drop-up panel */
.tsw-panel{
  position:absolute;bottom:calc(100% + 8px);left:0;
  min-width:160px;
  background:var(--drw-bg);
  border:1px solid var(--bdr);border-radius:12px;
  padding:6px;
  box-shadow:0 -8px 32px rgba(0,0,0,.28),0 2px 8px rgba(0,0,0,.15);
  opacity:0;pointer-events:none;
  transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease);
  z-index:200;
}
.theme-sw.open .tsw-panel{opacity:1;pointer-events:auto;transform:translateY(0)}

.tsw-opt{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:8px;
  font-size:13px;font-weight:500;color:var(--muted);
  cursor:pointer;transition:background .15s,color .15s;
}
.tsw-opt:hover{background:var(--surf2);color:var(--text)}
.tsw-opt.active{background:var(--pri-lo);color:var(--pri)}
.tsw-opt.active i{color:var(--pri)}
.tsw-opt i{font-size:16px;color:var(--dim);transition:color .15s;flex-shrink:0;width:18px;text-align:center}

/* Footer notice - justified */
.ft-notice{
  background:var(--bg3);border-top:1px solid var(--bdr);
  padding:13px 40px;
  text-align:justify;
  font-size:11px;color:var(--dim);line-height:1.7;
}
@media(max-width:768px){.ft-notice{padding:13px 20px}}
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .ft-notice{padding-bottom:max(13px,calc(env(safe-area-inset-bottom)+9px))}
}

/* =============================================================
   LEGAL DISCLOSURE SECTION
============================================================= */
.legal-sec{
  background:var(--bg2);
  padding:56px 0 100px;
  border-top:1px solid var(--bdr);
}

.legal-sec-no-edge{
  background:transparent;
  border-top:none;
  padding-top:24px;
}

.legal-box{
  background:var(--bg2);
  border:1px solid var(--bdr);
  border-radius:var(--r-lg);
  padding:36px 40px;
  display:flex;flex-direction:column;gap:16px;
  margin-bottom:0;
}
.legal-box p{
  font-size:12px;color:var(--dim);line-height:1.8;
  text-align:justify;
  overflow-wrap:anywhere;
  word-break:break-word;
  max-width:100%;
}
@media(max-width:1024px){
  .legal-box{padding:30px 30px}
  .legal-box p{text-align:left}
}
@media(max-width:768px){
  .legal-box{padding:26px 22px}
  .legal-box p{
    font-size:11.5px;
    line-height:1.7;
  }
}
.legal-tm{
  font-family:'Inter',sans-serif;font-size:10.5px !important;
  color:var(--muted) !important;letter-spacing:.02em;
  padding-bottom:16px;border-bottom:1px solid var(--bdr);
  margin-bottom:2px;
}

/* =============================================================
   TOUCH TARGETS
============================================================= */
@media(max-width:768px){
  .btn{min-height:46px}
  .ham,.tsw-btn{min-height:44px}
  .drw-nav a{min-height:48px}
  .fi-q{padding:18px 20px}
}

/* =============================================================
   PROTECTION - three distinct card layouts
============================================================= */

/* ── Card 1: Timeline (Safeguard) ── */
.pc-timeline{
  display:flex;flex-direction:column;gap:0;
  padding-left:22px;
  border-left:2px solid rgba(34,197,94,.28);
  margin-left:6px;flex:1;
}
.pc-tl-item{position:relative;padding:0 0 22px}
.pc-tl-item:last-child{padding-bottom:0}
.pc-tl-bullet{
  position:absolute;left:-30px;top:4px;
  width:16px;height:16px;border-radius:50%;
  background:rgba(34,197,94,.14);border:1.5px solid var(--green);
  display:flex;align-items:center;justify-content:center;
}
.pc-tl-bullet::after{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--green);
}
.pc-tl-t{font-family:'Poppins',sans-serif;font-size:12.5px;font-weight:700;color:var(--text);margin-bottom:4px}
.pc-tl-d{font-size:11.5px;color:var(--muted);line-height:1.55}

/* ── Card 2: Permission matrix (Security) ── */
.pc-perm{
  display:flex;flex-direction:column;flex:1;gap:0;
}
.pc-perm-row{
  display:flex;align-items:flex-start;gap:13px;
  padding:13px 0;border-bottom:1px solid var(--bdr);
}
.pc-perm-row:first-child{padding-top:0}
.pc-perm-row:last-child{border-bottom:none;padding-bottom:0}
.pc-perm-key{
  flex-shrink:0;margin-top:2px;
  font-family:'Inter',sans-serif;font-size:9px;font-weight:500;letter-spacing:.06em;
  color:var(--pri);background:var(--pri-lo);border:1px solid var(--pri-bdr);
  padding:3px 8px;border-radius:6px;white-space:nowrap;
  min-width:50px;text-align:center;
}
.pc-perm-title{font-family:'Poppins',sans-serif;font-size:12px;font-weight:600;color:var(--text);margin-bottom:3px}
.pc-perm-val{font-size:11.5px;color:var(--muted);line-height:1.5}

/* ── Card 3: Compact efficiency signals ── */
.pc-eff-grid{
  display:grid;
  gap:10px;
}
.pc-eff-item{
  border:1px solid rgba(0,84,173,.2);
  border-radius:12px;
  background:linear-gradient(170deg,rgba(0,84,173,.08),rgba(255,255,255,.01));
  padding:12px;
}
.pc-eff-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.pc-eff-label{
  font-size:11px;
  font-family:'Inter',sans-serif;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dim);
}
.pc-eff-value{
  font-size:13px;
  font-family:'Poppins',sans-serif;
  color:var(--head);
}
.pc-eff-bar{
  margin-top:10px;
  height:8px;
  border-radius:999px;
  border:1px solid rgba(0,84,173,.2);
  background:rgba(0,84,173,.08);
  overflow:hidden;
}
.pc-eff-bar span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--pri),#3b82f6);
}
.pc-eff-desc{
  margin:9px 0 0;
  color:var(--muted);
  font-size:12.5px;
  line-height:1.55;
}
.pc-eff-meta{
  margin-top:10px;
  border:1px dashed rgba(0,84,173,.3);
  background:rgba(0,84,173,.06);
  border-radius:10px;
  padding:9px 10px;
  color:var(--muted);
  font-size:12.5px;
  line-height:1.5;
  display:flex;
  align-items:flex-start;
  gap:7px;
}
.pc-eff-meta i{
  margin-top:1px;
  color:var(--pri);
}

/* =============================================================
   FOOTER - premium improvements
============================================================= */

/* Gradient accent line at top */
footer::before{
  content:'';display:block;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--pri-glo) 30%,rgba(204,221,239,.35) 68%,transparent 100%);
}


/* Improved column headings */
.ft-col-h{
  display:flex;align-items:center;gap:7px;
  font-family:'Inter',sans-serif;font-size:9px;
  text-transform:uppercase;letter-spacing:.15em;color:var(--dim);margin-bottom:20px;
}

/* Newsletter as a card */
.ft-nl{
  padding:28px 32px;
  background:var(--surf);
  border:1px solid var(--bdr);
  border-radius:var(--r-lg);
  margin-top:44px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.ft-nl::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 50% 100% at 0% 50%,var(--sm1) 0%,transparent 70%);
}
.ft-nl > *{position:relative;z-index:1}
@media(max-width:640px){.ft-nl{padding:22px}}

/* Hover lift on social icons */
.fsoc{transition:background .2s,color .2s,border-color .2s,transform .2s}
.fsoc:hover{transform:translateY(calc(-1 * var(--interactive-hover-lift)))}

/* ft-btm margin-top */
.ft-btm{margin-top:44px}


/* ── Newsletter grouped pill ── */
.nl-group{
  display:flex;align-items:stretch;
  background:var(--bg2);
  border:1px solid var(--bdr);
  border-radius:999px;
  overflow:hidden;
  transition:border-color .2s,box-shadow .2s;
  width:100%;max-width:380px;
}
.nl-group:focus-within{border-color:var(--bdr-hi);box-shadow:0 0 0 3px var(--pri-lo)}
.nl-group input{
  flex:1;min-width:0;padding:11px 18px;
  font-size:13px;color:var(--text);
  font-family:'Inter',sans-serif;
  background:transparent;border:none;outline:none;
}
.nl-group input::placeholder{color:var(--dim)}
.nl-group button{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:7px;
  padding:11px 22px;
  background:var(--pri);color:#F9FAFB;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  border:none;cursor:pointer;white-space:nowrap;
  border-radius:0 999px 999px 0;
  transition:background .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.nl-group button::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.13) 0%,transparent 55%);
  pointer-events:none;
}
.nl-group button:hover{background:var(--pri-d);box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.nl-group button i{font-size:15px}
@media(max-width:640px){.nl-group{max-width:100%}}


/* ── Infrastructure stat blocks ── */
.infra-stats{
  display:flex;flex-direction:column;gap:0;
  border:1px solid var(--bdr);border-radius:var(--r);
  overflow:hidden;margin-top:4px;
}
.infra-stat{
  padding:16px 18px;
  border-bottom:1px solid var(--bdr);
  transition:background .2s;
}
.infra-stat:last-child{border-bottom:none}
.infra-stat:hover{background:var(--surf2)}
.infra-stat-top{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;margin-bottom:9px;
}
.infra-stat-num{
  font-family:'Poppins',sans-serif;font-size:22px;font-weight:800;
  letter-spacing:-.04em;color:var(--head);line-height:1;
}
.infra-stat-unit{
  font-size:13px;font-weight:500;color:var(--muted);margin-left:2px;letter-spacing:0;
}
.infra-stat-tag{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Inter',sans-serif;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--pri);background:var(--pri-lo);border:1px solid var(--pri-bdr);
  padding:3px 9px;border-radius:999px;white-space:nowrap;flex-shrink:0;
}
.infra-stat-tag i{font-size:11px}
.infra-signal{
  position:relative;
  height:24px;
  margin-bottom:8px;
  border-radius:8px;
  background:linear-gradient(180deg,rgba(2,6,23,.38),rgba(15,23,42,.16));
  border:1px solid rgba(148,163,184,.2);
  overflow:hidden;
}
.infra-signal-fill{
  position:absolute;
  inset:4px;
  border-radius:6px;
}
.infra-signal-fill::before{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    linear-gradient(90deg,rgba(255,255,255,.22),rgba(255,255,255,0) 40%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.1) 0 1px,transparent 1px 18px),
    linear-gradient(90deg,rgba(0,84,173,.22),rgba(0,84,173,.44));
}
.infra-signal-fill::after{
  content:'';
  position:absolute;
  top:0;
  left:-30%;
  width:30%;
  height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);
  animation:infra-sweep 2.4s linear infinite;
}
.infra-signal-fill-a::before{width:88%}
.infra-signal-fill-b::before{width:100%}
.infra-signal-fill-c::before{width:74%}
.infra-signal-fill-b::after{animation-duration:2.8s}
.infra-signal-fill-c::after{animation-duration:3.2s}
.infra-stat-bar{
  position:relative;
  height:4px;
}
.infra-stat-bar::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,transparent 0%,rgba(0,84,173,.32) 32%,transparent 75%),
    repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 8px,transparent 8px 15px);
  opacity:.35;
  pointer-events:none;
}
.infra-stat-fill{
  position:relative;
  overflow:hidden;
}
.infra-stat-fill::after{
  content:'';
  position:absolute;
  top:50%;
  left:-14px;
  width:14px;
  height:14px;
  transform:translateY(-50%) rotate(45deg);
  border-radius:3px;
  background:linear-gradient(135deg,rgba(255,255,255,.95),rgba(255,255,255,.1));
  box-shadow:0 0 14px rgba(255,255,255,.45);
  animation:current-flow 2s linear infinite;
}
.infra-stat-current .infra-stat-fill::after{animation-duration:1.6s}
.infra-stat-recovery .infra-stat-fill::after{animation-duration:2.3s}
.infra-stat-forecast .infra-stat-fill::after{animation-duration:2.8s}
.infra-stat-desc{font-size:11.5px;color:var(--muted);line-height:1.5}

@keyframes current-flow{
  from{left:-14px;opacity:.15}
  20%{opacity:.9}
  to{left:calc(100% + 14px);opacity:.15}
}
@keyframes metric-scan{
  from{transform:translateX(-55%)}
  to{transform:translateX(55%)}
}
@keyframes infra-sweep{
  from{left:-30%;opacity:.2}
  35%{opacity:.7}
  to{left:100%;opacity:.2}
}

/* ── Newsletter bare (no card) ── */
.ft-nl-bare{
  padding:32px 0;
  border-top:1px solid var(--bdr);
  display:flex;justify-content:center;
}
@media(max-width:640px){.ft-nl-bare{justify-content:stretch}}
.ft-nl-bare .nl-group{max-width:400px;width:100%}


/* =============================================================
   FOOTER BADGES
============================================================= */
.ft-badges{
  display:flex;align-items:stretch;gap:16px;
  padding:20px 40px;
  border-top:1px solid var(--bdr);
  flex-wrap:wrap;
}
@media(max-width:768px){.ft-badges{padding:20px}}

/* Seamium Compatible */
.ftb-compatible{
  display:inline-flex;
  align-items:stretch;
  border:1px solid var(--bdr);
  border-radius:12px;
  padding:0;
  overflow:hidden;
  background:var(--surf);
  transition:border-color .22s,background .22s;
}
.ftb-compatible:hover{border-color:var(--pri-bdr);background:var(--pri-lo)}
.ftb-compatible-inner{display:flex;align-items:center;gap:12px;padding:12px 20px 12px 16px;width:100%}
.ftb-shield{flex-shrink:0;display:flex;align-items:center}
.ftb-compatible-text{display:flex;flex-direction:column;gap:1px}
.ftb-brand{
  font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;
  color:var(--head);letter-spacing:-.02em;line-height:1;
}
.ftb-mark{
  font-family:'Inter',sans-serif;font-size:9.5px;letter-spacing:.06em;
  color:var(--pri);text-transform:uppercase;
}

/* Energy Efficiency Movement */
.ftb-eem{
  display:inline-flex;align-items:center;justify-content:center;
  aspect-ratio:1;
  background:#121212;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
  transition:transform .22s var(--ease),box-shadow .22s;
  flex-shrink:0;
  min-width:64px;
}
.ftb-eem:hover{transform:translateY(calc(-1 * var(--interactive-hover-lift)));box-shadow:0 8px 24px rgba(0,0,0,.4)}
.ftb-eem img{width:40px;height:40px;object-fit:contain;display:block}


/* Hero mobile center alignment */
@media(max-width:768px){
  .hero{min-height:auto;padding:56px 20px;align-items:center;text-align:center}
  .hero-ctas{justify-content:center}
  .hero-sub{text-align:center}
}
@media(max-width:480px){
  .hero{min-height:auto;padding:48px 20px}
  .hero-ctas{flex-direction:column;align-items:center;width:100%}
  .hero-ctas .btn{width:100%;justify-content:center}
}


/* Nav wordmark */
.nav-wordmark{
  font-family:'Poppins',sans-serif;font-size:17px;font-weight:700;
  letter-spacing:-.03em;color:var(--text);
}

/* Footer status chip (moved from nav) */
.ft-status-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'Inter',sans-serif;font-size:10px;
  color:var(--muted);
  white-space:nowrap;
}


/* =============================================================
   ACCESSIBILITY - comprehensive
============================================================= */

/* ── Skip navigation ── */
.skip-link{
  position:fixed;top:-100%;left:0;transform:none;
  z-index:99999;
  padding:12px 28px;border-radius:0 0 12px 12px;
  background:var(--pri);color:#F9FAFB;
  font-family:'Poppins',sans-serif;font-size:14px;font-weight:700;
  text-decoration:none;white-space:nowrap;
  transition:top .18s ease;
  outline:none;
  box-shadow:0 4px 20px rgba(0,84,173,.5);
}
.skip-link:focus{top:0}

/* ── Screen reader only utility ── */
.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;
}
.sr-only-focusable:focus,
.sr-only-focusable:active{
  position:static;width:auto;height:auto;overflow:visible;
  clip:auto;white-space:normal;
}

/* ── Enhanced focus-visible ── */
:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:3px;
  border-radius:4px;
}
/* Richer focus ring for interactive components */
.fi-q:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:-2px;
  border-radius:0;
}
.ham:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:3px;
}
/* Drawer links */
.drw-nav a:focus-visible{
  outline:var(--interactive-focus-ring-width) solid var(--interactive-focus-ring-color);
  outline-offset:0;
  background:var(--surf2);
}
/* Theme options */
.tsw-opt:focus-visible{
  outline:2px solid var(--pri);
  outline-offset:0;
}

/* ── ARIA invalid state - newsletter ── */
.nl-group input[aria-invalid="true"]{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(239,68,68,.15);
}
.nl-error{
  font-size:12px;color:var(--red);margin-top:6px;
  display:flex;align-items:center;gap:5px;
}
.nl-success{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;color:var(--green);font-weight:500;
  margin-top:8px;
  line-height:1.4;
  flex-wrap:wrap;
}
.nl-error[hidden],
.nl-success[hidden]{display:none !important}

@media(max-width:640px){
  .nl-group{
    flex-direction:column;
    border-radius:14px;
    overflow:hidden;
    gap:0;
    max-width:100%;
    border:1px solid var(--bdr);
    background:var(--bg2);
  }
  .nl-group input{
    width:100%;
    min-height:44px;
  }
  .nl-group button{
    width:100%;
    min-height:44px;
    justify-content:center;
    border-radius:0 0 14px 14px;
  }
}

/* ── ARIA announcement region ── */
#a11y-announce{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ── prefers-reduced-motion ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .rv{opacity:1 !important;transform:none !important}
  .rv.in{opacity:1;transform:none}
  .amb{display:none !important}
  .pc-metric-fill{transition:none}
  .pc-metric-fill::after,
  .infra-stat-fill::after{animation:none !important}
}

/* ── prefers-contrast: more ── */
@media(prefers-contrast:more){
  :root,
  html[data-theme="dark"],
  html[data-theme="system"].os-dark{
    --bdr:      rgba(255,255,255,.22);
    --bdr-hi:   rgba(0,84,173,.7);
    --muted:    #b0bdd4;
    --dim:      #6b7a96;
  }
  html[data-theme="light"],
  html[data-theme="system"].os-light{
    --bdr:      rgba(0,0,0,.22);
    --bdr-hi:   rgba(0,84,173,.7);
    --muted:    #3a4560;
    --dim:      #6b7a96;
  }
  .btn-o{border-width:2px}
  .pill{border-width:2px}
  .fi2{border-bottom:1px solid var(--bdr)}
}

/* ── Focus indicator for keyboard navigation mode only ── */
body:not(.using-mouse) :focus{
  outline:2px solid var(--pri);
  outline-offset:3px;
}
body.using-mouse :focus:not(:focus-visible){
  outline:none;
}

/* ── High-visibility drawer focus trap indicator ── */
.drw.open .drw-close:focus-visible{
  background:rgba(239,68,68,.18);
  color:var(--red);
}

/* Utilities migrated from inline styles */
.logo-img{display:block;object-fit:contain;flex-shrink:0}
.logo-img-lg{width:35px;height:35px;border-radius:12px}
.logo-img-sm{width:28px;height:28px;border-radius:10px}
.nav-start-compact{padding:8px 16px;font-size:12.5px}
.nav-start-home{padding:4px}
.drw-logo{font-size:17px}
.nav-wordmark-sm{font-size:16px}
.icon-pri-sm{font-size:13px;color:var(--pri)}
.icon-12{font-size:12px}
.hero-title{margin-top:20px}
.stmt-intro{max-width:760px;margin:0 auto;text-align:center}
.mt-16{margin-top:16px}
.stmt-body-narrow{max-width:520px;margin:16px auto 0}
.slbl-mb16{margin-bottom:16px}
.slbl-mb24{margin-bottom:24px}
.sec-hdr-lg-gap{margin-bottom:40px}
.pc-first-offset{padding-left:52px}
.btn-lg{font-size:14px;padding:13px 32px}
.faq-sub{margin-top:14px;max-width:240px}
.infra-fill-92{width:92%}
.infra-fill-100{width:100%}
.infra-fill-75{width:75%}
.pc-fill-100{width:100%}
.pc-fill-97{width:97%}
.pc-fill-78{width:78%}

/* =============================================================
   PRODUCT PAGE
============================================================= */
.prd-hero{padding:56px 0 30px}
.prd-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center}
.prd-hero-title{font-size:clamp(38px,6.2vw,78px);letter-spacing:-.045em;line-height:.95;margin:16px 0 18px;max-width:11ch}
.prd-hero-sub{font-size:17px;color:var(--muted);max-width:60ch}
.prd-terminal{border:1px solid var(--bdr-hi);background:linear-gradient(180deg,var(--card-bg),rgba(0,84,173,.05));border-radius:18px;overflow:hidden;box-shadow:var(--sh)}
.prd-terminal header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--bdr);font-family:'Inter',sans-serif;font-size:11px;color:var(--muted)}
.prd-terminal .dots{display:flex;gap:6px}
.prd-terminal .dots i{width:8px;height:8px;border-radius:50%;display:block;background:var(--dim)}
.prd-terminal .dots i:nth-child(1){background:#ff5f57}.prd-terminal .dots i:nth-child(2){background:#febc2e}.prd-terminal .dots i:nth-child(3){background:#28c840}
.prd-terminal .live{color:var(--green);font-weight:600}
.prd-terminal ul{padding:14px;display:grid;gap:10px}
.prd-terminal li{display:grid;grid-template-columns:78px 62px 1fr;gap:12px;align-items:center;font-size:12.5px;color:var(--text);font-family:'Inter',sans-serif}
.prd-terminal li span{color:var(--muted)}
.prd-terminal li b{color:var(--pri);font-size:11px;letter-spacing:.08em}
.prd-terminal li em{font-style:normal;opacity:.92}

.prd-shell{padding:26px 0 70px}
.prd-panel{border:1px solid var(--bdr);background:var(--card-bg);border-radius:18px;padding:26px 24px;box-shadow:var(--sh);margin-bottom:20px}
.prd-panel-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:10px}
.prd-panel h2{font-size:clamp(28px,3vw,42px);letter-spacing:-.03em;max-width:14ch}
.prd-panel p{color:var(--muted);font-size:15px;max-width:95ch}
.prd-tags{display:flex;flex-wrap:wrap;gap:8px;max-width:420px;justify-content:flex-end}
.prd-tags span{border:1px solid var(--bdr-hi);color:var(--pri);background:var(--pri-lo);padding:6px 12px;border-radius:999px;font-size:11.5px;font-weight:600}

.prd-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px}
.prd-grid-bottom{margin-top:18px}
.prd-card{background:var(--card-bg);border:1px solid var(--bdr);border-radius:18px;padding:22px;position:relative}
.prd-eyebrow{font-family:'Inter',sans-serif;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:7px}
.prd-card h3{font-size:34px;line-height:1;letter-spacing:-.03em;margin-bottom:12px;color:var(--head)}
.prd-card p{color:var(--muted);font-size:15px;line-height:1.7}
.prd-mini-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}
.prd-mini-grid div{padding:14px;background:var(--surf);border:1px solid var(--bdr);border-radius:12px;display:grid;gap:5px}
.prd-mini-grid strong,.prd-feature-row h4,.prd-stack-list strong{font-size:14px;letter-spacing:-.01em}
.prd-mini-grid span,.prd-feature-row p,.prd-stack-list span{font-size:13px;color:var(--muted)}
.prd-list{display:grid;gap:10px;margin-top:14px}
.prd-list li{display:grid;gap:4px;padding:12px;border:1px solid var(--bdr);border-radius:12px;background:var(--surf)}
.prd-list b{font-size:14px}
.prd-list span{color:var(--muted);font-size:13.5px}
.prd-feature-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:16px}
.prd-feature-row>div,.prd-stack-list>div{background:var(--surf);border:1px solid var(--bdr);border-radius:12px;padding:14px}
.prd-metrics{display:grid;gap:11px;margin-top:15px}
.prd-metrics li{display:flex;justify-content:space-between;gap:20px;padding:12px 0;border-bottom:1px solid var(--bdr)}
.prd-metrics li:last-child{border-bottom:none}
.prd-metrics strong{font-size:24px;letter-spacing:-.03em}
.prd-metrics span{color:var(--muted);font-size:13.5px;text-align:right}
.prd-stack-list{display:grid;gap:10px;margin-top:15px}
.prd-span-2{grid-column:span 2}

@media(max-width:1100px){
  .prd-hero-grid{grid-template-columns:1fr;gap:18px}
  .prd-panel-top{flex-direction:column}
  .prd-tags{justify-content:flex-start}
}
@media(max-width:840px){
  .prd-grid{grid-template-columns:1fr}
  .prd-span-2{grid-column:auto}
  .prd-mini-grid,.prd-feature-row{grid-template-columns:1fr}
  .prd-card h3{font-size:29px}
  .prd-terminal li{grid-template-columns:72px 52px 1fr;font-size:11.5px}
}

/* =============================================================
   SUPPORT PAGE
============================================================= */
.sup-main{padding-bottom:90px}
.sup-hero{padding:38px 0 24px}
.sup-hero-stage{
  position:relative;
  display:grid;
  gap:18px;
  border:1px solid color-mix(in srgb,var(--pri) 32%, var(--bdr));
  background:linear-gradient(140deg,color-mix(in srgb,var(--card-bg) 83%, var(--pri) 17%) 0%,color-mix(in srgb,var(--card-bg) 74%, var(--gold) 26%) 100%);
  border-radius:34px;
  box-shadow:var(--sh);
  padding:clamp(28px,4vw,54px);
  overflow:hidden;
}
.sup-hero-stage::before,.sup-hero-stage::after{
  content:'';position:absolute;pointer-events:none;border-radius:50%
}
.sup-hero-stage::before{width:520px;aspect-ratio:1;right:-170px;top:-220px;background:radial-gradient(circle,rgba(0,84,173,.36) 0%,transparent 72%)}
.sup-hero-stage::after{width:430px;aspect-ratio:1;left:-170px;bottom:-280px;background:radial-gradient(circle,rgba(204,221,239,.2) 0%,transparent 72%)}
.sup-hero-stage > *{position:relative;z-index:1}
.sup-hero h1{font-size:clamp(34px,5vw,66px);letter-spacing:-.035em;line-height:1.02;color:var(--head);margin-bottom:14px;max-width:740px}
.sup-hero p{font-size:16px;color:var(--muted);max-width:670px}
.sup-search{
  margin-top:26px;display:flex;align-items:center;gap:12px;
  background:var(--bg2);border:1px solid var(--bdr-hi);border-radius:999px;padding:9px 10px 9px 16px;
  backdrop-filter:blur(8px);
}
.sup-search i{font-size:18px;color:var(--muted)}
.sup-search input{flex:1;border:0;background:transparent;color:var(--text);font-size:14.5px;font-family:inherit;outline:none}
.sup-search input::placeholder{color:var(--dim)}
.sup-trust{margin-top:16px;display:flex;flex-wrap:wrap;gap:16px 26px;color:var(--muted);font-size:13px;font-weight:500}
.sup-trust span{display:inline-flex;align-items:center;gap:7px}
.sup-trust i{color:var(--pri);font-size:16px}

.sup-quick{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;padding-top:18px;padding-bottom:28px}
.sup-q-card{
  border:1px solid var(--bdr);background:var(--card-bg);border-radius:18px;
  padding:16px;box-shadow:var(--sh);transition:transform .25s var(--ease),border-color .2s,background .2s;
}
.sup-q-card:hover{transform:translateY(-4px);border-color:var(--bdr-hi);background:var(--surf2)}
.sup-q-card i{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;background:var(--pri-lo);color:var(--pri);font-size:21px}
.sup-q-card h2{font-size:20px;letter-spacing:-.02em;margin:14px 0 8px}
.sup-q-card p{font-size:14.5px;color:var(--muted)}

.sup-guides{padding:38px 0}
.sup-hdr{margin-bottom:22px}
.sup-guide-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.sup-guide{
  border:1px solid var(--bdr);background:var(--card-bg);border-radius:20px;padding:24px;box-shadow:var(--sh)
}
.sup-guide h3{font-size:25px;letter-spacing:-.025em;margin-bottom:14px}
.sup-guide ul{display:grid;gap:10px}
.sup-guide li{color:var(--muted);font-size:15px;line-height:1.65;padding-left:18px;position:relative}
.sup-guide li::before{content:'';position:absolute;left:0;top:.7em;width:6px;height:6px;border-radius:50%;background:var(--pri)}

.sup-command{padding:10px 0 30px}
.sup-command-board{
  border:1px solid var(--bdr);
  border-radius:24px;
  padding:24px;
  background:
    radial-gradient(circle at 90% 8%, rgba(0,84,173,.18), transparent 30%),
    linear-gradient(150deg, color-mix(in srgb, var(--card-bg) 86%, var(--pri) 14%), var(--card-bg));
  box-shadow:var(--sh);
}
.sup-command-head h2{font-size:clamp(28px,3.5vw,48px);line-height:1.05;letter-spacing:-.035em;max-width:14ch}
.sup-command-head p{margin-top:12px;color:var(--muted);max-width:74ch}
.sup-metrics{margin-top:22px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.sup-metric{border:1px solid var(--bdr);background:var(--surf);border-radius:16px;padding:16px;display:grid;gap:6px}
.sup-metric span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-family:'Inter',sans-serif}
.sup-metric strong{font-size:33px;line-height:1;letter-spacing:-.03em}
.sup-metric small{font-size:12px;color:var(--muted);line-height:1.45}

.sup-journey{padding:18px 0 30px}
.sup-timeline{
  margin-top:10px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;
  counter-reset:steps;
}
.sup-step{
  position:relative;
  border:1px dashed var(--bdr-hi);
  border-radius:16px;
  padding:16px;
  background:linear-gradient(180deg,var(--card-bg),var(--surf));
}
.sup-step-n{
  width:42px;height:42px;display:grid;place-items:center;border-radius:12px;
  font-size:12px;font-family:'Inter',sans-serif;letter-spacing:.08em;color:var(--pri);
  background:var(--pri-lo);border:1px solid var(--pri-bdr);margin-bottom:12px
}
.sup-step h3{font-size:19px;letter-spacing:-.02em;margin-bottom:8px}
.sup-step p{font-size:14px;color:var(--muted)}

.sup-library{padding:14px 0 34px}
.sup-lib-feature{
  border:1px solid var(--bdr);border-radius:26px;box-shadow:var(--sh);
  background:linear-gradient(165deg,var(--card-bg) 15%,color-mix(in srgb,var(--card-bg) 80%,var(--gold) 20%) 100%);
  padding:24px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center;
}
.sup-lib-copy h2{font-size:clamp(30px,3.9vw,50px);letter-spacing:-.038em;line-height:1.02;max-width:13ch}
.sup-lib-copy p{margin-top:12px;color:var(--muted);max-width:55ch}
.sup-lib-grid{display:grid;gap:10px}
.sup-lib-item{
  border:1px solid var(--bdr);background:var(--bg2);border-radius:14px;
  padding:16px;display:grid;grid-template-columns:30px 1fr;gap:8px 12px;align-items:start;
  transition:transform .24s var(--ease),border-color .2s,background .2s;
}
.sup-lib-item:hover{transform:translateX(5px);border-color:var(--bdr-hi);background:var(--surf2)}
.sup-lib-item i{width:30px;height:30px;border-radius:10px;display:grid;place-items:center;background:var(--pri-lo);color:var(--pri)}
.sup-lib-item span{font-weight:700;letter-spacing:-.01em}
.sup-lib-item small{grid-column:2;color:var(--muted);font-size:13px}

.sup-escalate{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;padding-top:10px}
.sup-es-card,.sup-critical{border:1px solid var(--bdr);background:var(--card-bg);border-radius:22px;box-shadow:var(--sh);padding:24px}
.sup-es-card{display:grid;grid-template-columns:1fr 170px;gap:18px;align-items:center}
.sup-es-card h2{font-size:31px;letter-spacing:-.03em;line-height:1.1;margin-bottom:8px}
.sup-es-card p{color:var(--muted);margin-bottom:12px}
.sup-es-card ul{display:grid;gap:8px}
.sup-es-card li{display:flex;align-items:flex-start;gap:8px;color:var(--muted);font-size:14px}
.sup-es-card li i{color:var(--pri);margin-top:2px}
.sup-qr{
  aspect-ratio:1/1;border-radius:18px;border:1px solid var(--bdr-hi);
  background:repeating-linear-gradient(45deg,var(--pri-lo) 0 8px,transparent 8px 16px),var(--bg2);
  display:grid;place-items:center;font-family:'Inter',sans-serif;color:var(--pri);font-size:14px;letter-spacing:.12em;text-align:center;
}
.sup-critical h3{font-size:30px;line-height:1.06;letter-spacing:-.03em;margin-bottom:10px}
.sup-critical p{color:var(--muted);margin-bottom:18px}
.sup-critical .btn{width:100%;justify-content:center}
.sup-critical-meta{margin-top:12px;font-size:12.5px;color:var(--dim)}

.sup-faq{padding:30px 0 4px}
.sup-faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.sup-faq-item{
  border:1px solid var(--bdr);
  background:var(--card-bg);
  border-radius:16px;
  box-shadow:var(--sh);
  padding:16px;
}
.sup-faq-item summary{
  list-style:none;cursor:pointer;font-size:16px;font-weight:600;letter-spacing:-.01em;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.sup-faq-item summary::-webkit-details-marker{display:none}
.sup-faq-item summary::after{content:'+';font-size:22px;color:var(--pri);line-height:1;transition:transform .2s}
.sup-faq-item[open] summary::after{transform:rotate(45deg)}
.sup-faq-item p{margin-top:10px;color:var(--muted);font-size:14.5px}

@media(max-width:1200px){
  .sup-quick{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sup-metrics,.sup-timeline{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sup-lib-feature{grid-template-columns:1fr}
}
@media(max-width:1024px){
  .sup-guide-grid{grid-template-columns:1fr}
  .sup-escalate{grid-template-columns:1fr}
  .sup-faq-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .sup-main{padding-bottom:64px}
  .sup-search{display:grid;grid-template-columns:22px 1fr;gap:10px;border-radius:16px;padding:14px}
  .sup-search .btn{grid-column:1/-1;justify-content:center}
  .sup-quick{grid-template-columns:1fr}
  .sup-metrics,.sup-timeline{grid-template-columns:1fr}
  .sup-es-card{grid-template-columns:1fr}
  .sup-qr{max-width:210px}
}


/* Contact form integrations */
.iti{width:100%}
.iti__selected-country{background:var(--bg2);border-right:1px solid var(--bdr);border-radius:12px 0 0 12px}
.iti__country-list{background:var(--card-bg);color:var(--text);border:1px solid var(--bdr);box-shadow:var(--sh)}
.iti__country.iti__highlight{background:var(--pri-lo)}
.iti__search-input{background:var(--bg2);color:var(--text);border:1px solid var(--bdr)}
.iti--separate-dial-code .iti__selected-dial-code{color:var(--text)}
.btn.is-loading{opacity:.72;pointer-events:none}
.btn.is-loading i{animation:btn-spin .9s linear infinite}
@keyframes btn-spin{to{transform:rotate(1turn)}}

/* Disabled placeholder affordance for planned links */
.is-disabled{opacity:.64;cursor:not-allowed;text-decoration:none}
.is-disabled[aria-disabled="true"]{pointer-events:none}

/* Landing bento section */
.landing-bento{padding:24px 0 48px;position:relative}
.bento-hdr{margin-bottom:34px}
.landing-bento-pills{
  display:none;
  gap:8px;
  margin:0 auto 20px;
  overflow:auto;
  padding:8px;
  border-radius:999px;
  border:1px solid color-mix(in srgb,var(--bdr) 82%,var(--pri) 18%);
  background:linear-gradient(180deg,color-mix(in srgb,var(--card-bg) 92%,#fff 8%),color-mix(in srgb,var(--card-bg) 84%,var(--bg2) 16%));
  box-shadow:none;
  justify-content:center;
  scroll-padding-inline:8px;
}
.landing-bento-tab{display:inline-flex;align-items:center;gap:6px;border:1px solid color-mix(in srgb,var(--bdr) 85%,var(--pri) 15%);background:color-mix(in srgb,var(--card-bg) 90%,var(--bg2) 10%);color:var(--head);border-radius:999px;padding:8px 14px;font:600 .82rem/1.2 'Inter',sans-serif;white-space:nowrap}
.landing-bento-tab i{font-size:14px;line-height:1}
.landing-bento-tab.active{background:var(--pri);border-color:var(--pri);color:#fff}
.landing-bento-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:18px}
.bento-card{
  position:relative;
  padding:26px;
  border-radius:24px;
  background:var(--card-bg);
  border:1px solid rgba(0,84,173,.14);
  box-shadow:none;
  overflow:hidden;
}
.bento-card::before{content:"";position:absolute;inset:auto -40% -55% auto;width:220px;height:220px;border-radius:999px;background:radial-gradient(circle,rgba(0,84,173,.18),transparent 65%);pointer-events:none}
.bento-card-watermark{position:absolute;right:14px;bottom:12px;font-size:36px;line-height:1;color:rgba(0,84,173,.08);pointer-events:none;z-index:0}
.bento-card > *:not(.bento-card-watermark){position:relative;z-index:1}
.bento-kicker{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#0054ad;background:rgba(0,84,173,.1);padding:6px 10px;border-radius:999px;margin-bottom:14px}
.bento-kicker i{font-size:12px;line-height:1}
.bento-card h3{font-size:clamp(1.15rem,2.5vw,1.6rem);line-height:1.25;letter-spacing:-.02em;margin-bottom:12px;color:var(--head)}
.bento-card p{margin:0;color:#344564;line-height:1.65}
.bento-card-wide{grid-column:span 8;min-height:260px}
.bento-card-tall{grid-column:span 4;grid-row:span 2;min-height:500px}
.bento-card-compact{grid-column:span 3;min-height:200px}
.bento-card-feature{grid-column:span 5;min-height:280px}
.bento-card-accent{grid-column:span 4;min-height:230px}
@media (max-width:1060px){
  .landing-bento{padding:14px 0 38px}
  .landing-bento-pills{display:flex}
  .landing-bento-grid{grid-template-columns:1fr;gap:14px}
  .bento-card,.bento-card-wide,.bento-card-tall,.bento-card-compact,.bento-card-feature,.bento-card-accent{grid-column:span 1;min-height:auto}
  .landing-bento-grid .bento-card{display:none}
  .landing-bento-grid .bento-card.is-active{display:block}
}
@media (max-width:700px){
  .landing-bento{padding:10px 0 34px}
  .landing-bento-pills{
    justify-content:flex-start;
    padding:7px;
    gap:6px;
    margin-bottom:16px;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .landing-bento-pills::-webkit-scrollbar{display:none}
}
