/* ---------- Base / Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
html,body{height:100%}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial;
  line-height:1.5;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  -webkit-tap-highlight-color:transparent;
  font-size:clamp(15px,1.9vw,17px);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
.no-js .sr-only{position:static}

/* ---------- Theme ---------- */
:root{
  --bg:#ffffff; --surface:#f6f7f9; --text:#0b0b0c; --muted:#6b7280;
  --primary:#0f62fe; --ring:rgba(15,98,254,.35);
  --card:#ffffff; --border:#e5e7eb; --shadow:0 10px 30px rgba(0,0,0,.08);
  --header-h:64px;
}
@media (max-width:560px){ :root{ --header-h:56px } }

@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    --bg:#0b0b0c; --surface:#151517; --text:#f6f7f9; --muted:#b7bbc6;
    --primary:#7AA2FF; --ring:rgba(122,162,255,.40);
    --card:#111113; --border:#2b2e33; --shadow:0 10px 30px rgba(0,0,0,.50);
  }
}
:root[data-theme="dark"]{
  --bg:#0b0b0c; --surface:#151517; --text:#f6f7f9; --muted:#b7bbc6;
  --primary:#7AA2FF; --ring:rgba(122,162,255,.40);
  --card:#111113; --border:#2b2e33; --shadow:0 10px 30px rgba(0,0,0,.50);
}
:root[data-theme="light"]{
  --bg:#ffffff; --surface:#f6f7f9; --text:#0b0b0c; --muted:#6b7280;
  --primary:#0f62fe; --ring:rgba(15,98,254,.35);
  --card:#ffffff; --border:#e5e7eb; --shadow:0 10px 30px rgba(0,0,0,.08);
}
.theme-animate *{transition:background-color .18s linear,color .18s linear,border-color .18s linear}

/* ---------- Helpers ---------- */
.container{width:min(1120px,92vw);margin-inline:auto;padding-inline:clamp(14px,3.5vw,0)}
.sr-only{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.section-title{font-size:clamp(24px,3.5vw,36px);letter-spacing:-.02em;margin:36px 0 18px}
.lede{color:var(--muted);font-size:clamp(16px,1.3vw,18px);max-width:65ch}
.muted{color:var(--muted)}
.skip-link,a[href="#main"]{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;
  z-index:10050;
  padding-top:max(0px,env(safe-area-inset-top));
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  backdrop-filter:saturate(180%) blur(14px);
  background:var(--bg);
  border-bottom:1px solid var(--border);
}
.site-header.elevated{box-shadow:0 6px 24px rgba(0,0,0,.06)}
.header-inner{display:grid;grid-template-columns:1fr auto auto;align-items:center;padding:16px 0;gap:16px;min-height:var(--header-h)}

.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}
.brand-name{font-weight:700;letter-spacing:.2px}
.logo-jg{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-weight:800;font-size:14px;line-height:1;letter-spacing:.5px;color:var(--text)}
.logo-jg--sm{width:20px;height:20px;font-size:11px;border-radius:6px}

.site-nav{display:flex;align-items:center}
.nav-toggle{display:none;background:transparent;border:0;padding:8px;border-radius:10px}
.nav-toggle .bar{display:block;width:22px;height:2px;background:var(--text);margin:5px 0;border-radius:2px}

.nav-menu{display:flex;list-style:none;gap:24px;margin:0 24px 0 0;padding:0}
.nav-menu a{color:var(--text);text-decoration:none;font-weight:500;opacity:.9}
.nav-menu a:hover{opacity:1}
.header-actions{display:flex;gap:10px;align-items:center}

/* Dropdowns (desktop) */
.has-menu{position:relative;--hover-gap:12px;padding-bottom:var(--hover-gap)}
.nav-link{background:transparent;border:0;padding:12px 0;font:inherit;color:var(--text);cursor:pointer;opacity:.9}
.has-menu:hover .nav-link,.has-menu:focus-within .nav-link{opacity:1}
.dropdown{
  position:absolute;left:0;top:calc(100% - var(--hover-gap));
  display:none;gap:24px;z-index:10060;
  padding:22px 24px;background:var(--card);
  border:1px solid color-mix(in oklab, var(--border), black 12%);
  border-radius:16px;
  box-shadow:0 22px 70px rgba(0,0,0,.22);
  min-width:720px;
}
.dropdown a{display:block;padding:10px 8px;text-decoration:none;color:var(--text);border-radius:8px;min-height:40px;display:flex;align-items:center}
.dropdown a:hover{background:color-mix(in oklab,var(--surface),transparent 15%);text-decoration:none}
.dropdown h4{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.dropdown .dropdown-col{min-width:260px}
.dropdown .highlight{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px}
.dropdown .eyebrow{margin:0 0 4px;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.dropdown .big-link{font-weight:700;text-decoration:none}
.has-menu[aria-expanded="true"] .dropdown{display:grid;grid-auto-flow:column}

/* Buttons */
.btn{--btn-bg:var(--surface);--btn-text:var(--text);--btn-border:var(--border);display:inline-flex;align-items:center;justify-content:center;gap:10px;text-decoration:none;font-weight:600;border-radius:12px;padding:12px 16px;border:1px solid var(--btn-border);color:var(--btn-text);background:var(--btn-bg);transition:transform .12s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease;min-height:44px}
.btn:hover{transform:translateY(-1px)}
.btn:focus-visible{outline:3px solid var(--ring);outline-offset:2px}
.btn.primary{--btn-bg:var(--text);--btn-text:var(--bg);--btn-border:var(--text)}
.btn.ghost{--btn-bg:transparent;--btn-border:color-mix(in oklab,var(--border),transparent 50%)}
.btn.small{padding:10px 14px;border-radius:10px}

/* Theme segmented toggle (desktop) */
.theme-switch{display:inline-flex;gap:6px;padding:6px;border:1px solid var(--border);border-radius:999px;background:var(--surface)}
.theme-opt{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:0;background:transparent;border-radius:999px;font-weight:600;color:var(--muted);cursor:pointer}
.theme-opt svg{width:16px;height:16px;fill:currentColor;opacity:.9}
.theme-opt.is-active{background:var(--text);color:var(--bg);box-shadow:var(--shadow)}
.theme-opt:focus-visible{outline:3px solid var(--ring);outline-offset:2px}
@media (max-width:560px){.theme-opt .label{display:none}.theme-opt{padding:8px 10px}}

/* Compact theme icon (phones) */
.theme-icon{
  display:none;margin-left:8px;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface);color:var(--text);align-items:center;justify-content:center;
}
.theme-icon svg{width:18px;height:18px;display:none}
[data-theme="light"] .theme-icon .sun{display:block}
[data-theme="dark"]  .theme-icon .moon{display:block}
@media (prefers-color-scheme: light){ :root:not([data-theme]) .theme-icon .sun{display:block} }
@media (prefers-color-scheme: dark) { :root:not([data-theme]) .theme-icon .moon{display:block} }
.theme-icon:focus-visible{outline:3px solid var(--ring);outline-offset:2px}

/* ---------- Hero ---------- */
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:32px;align-items:center;padding:clamp(28px,5vw,56px) 0}
.hero h1{font-size:clamp(28px,7vw,64px);line-height:1.05;letter-spacing:-.02em;margin:0 0 12px}
.gradient-text{background:conic-gradient(from 180deg at 50% 50%,#7AA2FF,#7c7dff,#d07aff,#7AA2FF);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-actions{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}

/* Hero SVG */
.hero-visual svg{width:100%;height:auto;background:var(--card);border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow);display:block}

/* ---------- Sections / Cards ---------- */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px;min-height:190px}
.card header h3{margin:0;font-size:18px}
.card p{margin:0 0 6px}
.arrow{margin-top:auto;text-decoration:none;font-weight:600;color:var(--text)}
.arrow::after{content:" →";transition:transform .15s ease;display:inline-block}
.arrow:hover::after{transform:translateX(3px)}

/* ---------- Breadcrumb / CTA / Footer ---------- */
.breadcrumb{font-size:14px;color:var(--muted)}
.breadcrumb a{text-decoration:none;color:inherit}
.breadcrumb a:hover{text-decoration:underline}

.cta{text-align:center;padding:40px 0 56px}
.cta-form{display:flex;justify-content:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.cta-form input{padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:var(--card);color:var(--text);min-width:260px}
.cta-form input:focus-visible{outline:3px solid var(--ring);outline-offset:2px}

.site-footer{border-top:1px solid var(--border);padding:28px 0;background:color-mix(in oklab,var(--bg),black 1%);padding-bottom:max(28px,env(safe-area-inset-bottom))}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:14px}
.footer-links{list-style:none;display:flex;gap:16px;margin:0;padding:0}
.footer-links a{color:var(--muted);text-decoration:none}
.footer-links a:hover{color:var(--text)}
.footer-brand{display:flex;align-items:center;gap:8px;color:var(--muted)}

/* ---------- Responsive ---------- */

/* Keep phone header minimal: brand | burger | theme icon */
@media (max-width:900px){
  .header-inner{grid-template-columns:1fr auto auto}
  .header-actions{display:none}
  .nav-toggle{display:inline-block}
  .theme-icon{display:inline-flex}
}

/* (Old in-header overlay kept for safety, but portal layer now handles mobile) */
@media (max-width:960px){
  .site-header .nav-menu{display:none}
  .has-menu{padding-bottom:0}
  .nav-link{width:100%;text-align:left;font-weight:700}
  .dropdown{position:static;display:block;padding:6px 0;border:0;box-shadow:none;min-width:0;background:transparent}
}

/* Collapse layout/content */
@media (max-width:960px){
  .hero{grid-template-columns:1fr;gap:20px}
  .hero-visual{order:2}
  .hero-copy{order:1}
  .product-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:820px){.product-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.product-grid{grid-template-columns:1fr}.brand-name{display:none}.logo-jg{width:22px;height:22px;font-size:12px;border-radius:6px}}

/* ---------- iOS scroll lock when menu open ---------- */
html.nav-locked, body.nav-locked{
  overflow:hidden;height:100%;overscroll-behavior:contain;touch-action:none;
}

/* ---------- BIGGER, CLEARER DROPDOWNS ---------- */
@media (min-width:961px){
  .nav-menu{gap:28px}
  .nav-link{font-size:16px;padding:14px 0}
}

/* ---------- NEW: Mobile menu portal layer (topmost) ---------- */
.nav-layer{
  position:fixed; left:0; right:0;
  top:calc(var(--header-h) + env(safe-area-inset-top)); bottom:0;
  z-index:2147483647; /* max */
  background:var(--card);
  border-top:1px solid var(--border);
  box-shadow:0 20px 60px rgba(0,0,0,.22);
  display:none;
  overflow:auto; -webkit-overflow-scrolling:touch;
}
.nav-layer.is-open{ display:block }
.nav-layer .nav-menu{
  display:flex; flex-direction:column; gap:8px;
  padding:18px 20px 32px;
}
.nav-layer .nav-link{
  font-size:20px; padding:16px 0; font-weight:700; text-align:left;
}
.nav-layer .dropdown{
  padding:6px 0; border:0; box-shadow:none; background:transparent; min-width:0;
}
.nav-layer .dropdown .dropdown-col + .dropdown-col{
  margin-top:8px; padding-top:8px; border-top:1px solid var(--border);
}
.nav-layer .dropdown a{
  font-size:17px; line-height:1.4; padding:14px 0; min-height:44px; display:flex; align-items:center;
}

/* Dim the page under the portal */
.nav-scrim{
  position:fixed; left:0; right:0;
  top:calc(var(--header-h) + env(safe-area-inset-top)); bottom:0;
  background:rgba(0,0,0,.45);
  z-index:2147483646; display:none; pointer-events:none;
}
.nav-scrim.is-open{ display:block }

/* ======================================================================
   Long-form Policy Styling (Privacy & Terms)
   ====================================================================== */

.policy{
  max-width:70ch;
  margin: 0 auto 48px;
  line-height:1.75;
  font-size:1.02rem;
}
.policy p{margin:0 0 14px}
.policy p + p{margin-top:8px}
.policy a{
  text-decoration:underline;
  text-underline-offset:3px;
}
.policy h2{
  margin: 18px 0 12px;
  letter-spacing:-.01em;
}
.policy h3{
  margin: 18px 0 8px;
  font-weight:700;
}
.policy h4{
  margin: 12px 0 6px;
  color:var(--muted);
  font-weight:600;
}
.policy ul{
  margin: 8px 0 16px 1.2rem;
  padding:0;
}
.policy li + li{margin-top:6px}

/* Keep anchored headings visible under sticky header */
.policy h2, .policy h3, .policy h4 { scroll-margin-top: calc(var(--header-h) + 16px); }

/* Key facts box (effective date, contact, etc.) */
.policy .keyfacts{
  display:grid;
  grid-template-columns: 1fr;
  gap: 6px 16px;
  margin:12px 0 18px;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--surface);
}
.policy .keyfacts dt{font-weight:600;color:var(--muted)}
.policy .keyfacts dd{margin:0}

@media (min-width:700px){
  .policy .keyfacts{ grid-template-columns: max-content 1fr }
  .policy .keyfacts > div{ display:contents } /* dt + dd line up cleanly */
}

/* In-page TOC chips */
.policy-toc{ padding-top:0; padding-bottom:0; margin-top:-4px }
.policy-toc ul{
  display:flex; gap:14px; flex-wrap:wrap;
  padding:10px 0 0; margin:0; list-style:none;
}
.policy-toc a{
  display:inline-block;
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:8px;
  text-decoration:none;
  color:inherit;
}
.policy-toc a:hover{ background:color-mix(in oklab, var(--surface), transparent 10%) }
/* Narrow centered column for long-form pages (privacy/terms) */
.container.narrow{
  width: min(820px, 92vw);
  margin-inline: auto;
}

/* Optional: let the intro paragraph span full width inside the narrow column */
.container.narrow .lede{ max-width: none; }
