/* =============================================================
   StarsAPI — site.css
   Loaded on every page. Single source of styles.
   ============================================================= */

/* ---------- Self-hosted fonts (no Google Fonts dependency) ----------
   Single-family typography: Geist for all UI text, JetBrains Mono for
   code. WOFF2 files live in /assets/fonts/. Latin subset only.
   --------------------------------------------------------------- */
@font-face {
  font-family: 'Geist';
  src: url('../fonts/geist-variable.woff2') format('woff2');
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/jetbrains-mono-400.woff2') format('woff2');
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/jetbrains-mono-500.woff2') format('woff2');
  font-style: normal;
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('../fonts/jetbrains-mono-600.woff2') format('woff2');
  font-style: normal;
  font-weight: 600;
  font-display: swap;
}

/* ---------- Fallback font with matched metrics ----------
   System sans-serifs stretched to match Geist's pixels. Prevents
   layout shift while Geist downloads. Apply once for both display
   and body since we use one family.
   --------------------------------------------------------- */
@font-face {
  font-family: 'Geist Fallback';
  src: local('Arial'), local('Helvetica Neue'), local('Helvetica');
  ascent-override: 96.5%;
  descent-override: 21.5%;
  line-gap-override: 0%;
  size-adjust: 101.5%;
}

/* ---------- design tokens ---------- */
:root {
  --font-display: 'Geist', 'Geist Fallback', system-ui, -apple-system, sans-serif;
  --font-body: 'Geist', 'Geist Fallback', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;

  --container: 1240px;
  --radius-sm: 6px;
  --radius: 14px;
  --radius-lg: 22px;

  --transition: 200ms cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

/* dark (default) */
[data-theme="dark"] {
  --bg: #08090f;
  --bg-1: #0e1019;
  --bg-2: #161928;
  --bg-3: #1d2138;
  --border: #1f2538;
  --border-strong: #2a3150;
  --text: #ecedf3;
  --text-2: #a8aec5;
  --text-3: #707692;
  --amber: #f5b041;
  --amber-soft: #f5b04122;
  --amber-strong: #ffc24d;
  --purple: #a78bfa;
  --purple-soft: #a78bfa1f;
  --teal: #2dd4bf;
  --teal-soft: #2dd4bf1f;
  --rose: #f472b6;
  --rose-soft: #f472b61f;
  --blue: #60a5fa;
  --blue-soft: #60a5fa1f;
  --orange: #fb923c;
  --orange-soft: #fb923c1f;
  --green: #34d399;
  --green-soft: #34d3991f;
  --cyan: #22d3ee;
  --cyan-soft: #22d3ee1f;
  --shadow-md: 0 1px 0 rgba(255,255,255,.04) inset, 0 8px 24px -10px rgba(0,0,0,.6);
  --shadow-lg: 0 1px 0 rgba(255,255,255,.05) inset, 0 30px 60px -25px rgba(0,0,0,.7);
  --grain-opacity: .35;
  --code-bg: #0d1119;
  --code-border: #1c2236;
  --header-bg: rgba(8, 9, 15, 0.78);
}

/* Italic globally disabled — emphasis is achieved through weight + color.
   This prevents browser default italic on <em>/<i> tags from triggering
   "faux italic" (synthesized slant) since we don't load Geist italic. */
em, i, cite, address, dfn, var { font-style: normal; }

/* light */
[data-theme="light"] {
  /* Backgrounds — clean white with subtle stone tones (not warm cream) */
  --bg: #ffffff;
  --bg-1: #fafaf9;
  --bg-2: #f5f5f4;
  --bg-3: #e7e5e4;
  --border: #e7e5e4;
  --border-strong: #d6d3d1;

  /* Text — deep slate-black for crisp headings */
  --text: #0c0a09;
  --text-2: #44403c;
  --text-3: #a8a29e;

  /* Accents — saturated for punch on white. Soft variants at higher
     opacity (~14%) so atmospheric gradients still register. */
  --amber: #d97706;
  --amber-soft: #d9770624;
  --amber-strong: #fbbf24;
  --purple: #7c3aed;
  --purple-soft: #7c3aed1f;
  --teal: #0d9488;
  --teal-soft: #0d94881f;
  --rose: #db2777;
  --rose-soft: #db27771f;
  --blue: #2563eb;
  --blue-soft: #2563eb1f;
  --orange: #ea580c;
  --orange-soft: #ea580c1f;
  --green: #059669;
  --green-soft: #0596691f;
  --cyan: #0891b2;
  --cyan-soft: #0891b21f;
  --shadow-md: 0 1px 0 rgba(255,255,255,.9) inset, 0 4px 14px -6px rgba(15,23,42,.10);
  --shadow-lg: 0 1px 0 rgba(255,255,255,.9) inset, 0 20px 50px -22px rgba(15,23,42,.18);
  --grain-opacity: .06;
  --code-bg: #0f1117;
  --code-border: #1c2236;
  --header-bg: rgba(255, 255, 255, 0.85);
}

/* ----------------------------------------------------------
   Light-theme polish — these rules fire ONLY in light mode.
   They give italic headings a "polished gold" gradient text
   effect (because flat amber on white reads as rust),
   richer button presence, and deeper eyebrow labels.
   ---------------------------------------------------------- */
[data-theme="light"] .hero h1 em,
[data-theme="light"] .section-head h2 em,
[data-theme="light"] .system-title em,
[data-theme="light"] .stat-r .num em,
[data-theme="light"] .ai-panel-head h3 em,
[data-theme="light"] .cta-inner h2 em {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 50%, #92400e 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
  font-weight: 500;
}

/* Button: dramatic amber-400 → amber-600 gradient with a richer amber halo
   so it lifts off the white page — same vibrancy ratio the dark button has
   against its dark surroundings. */
[data-theme="light"] .btn-primary {
  background: linear-gradient(180deg, #fbbf24 0%, #f59e0b 50%, #d97706 100%);
  border-color: #b45309;
  box-shadow:
    0 1px 0 rgba(255,255,255,.55) inset,
    0 0 0 1px rgba(180, 83, 9, .12),
    0 12px 28px -10px rgba(217, 119, 6, .55);
}
[data-theme="light"] .btn-primary:hover {
  box-shadow:
    0 1px 0 rgba(255,255,255,.6) inset,
    0 0 0 1px rgba(180, 83, 9, .18),
    0 16px 36px -10px rgba(217, 119, 6, .65);
}

/* Eyebrow labels (uppercase amber) — deeper amber-700 in light mode so they
   read as confident accent instead of faded orange. */
[data-theme="light"] .section-head .f-eyebrow { color: #b45309; }

/* ---------- base ---------- */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; overflow-x: clip; }

/* Anchor-link offset: when the URL has a #fragment, scroll the target down
   by 88px (header height ~68px + breathing room) so it isn't buried under
   the sticky header. Applies to anything addressable by id, broadly. */
:target,
[id] {
  scroll-margin-top: 88px;
}
@media (max-width: 1100px) {
  :target,
  [id] {
    scroll-margin-top: 76px;  /* mobile header is 60px tall */
  }
}
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  overflow-x: clip;
  transition: background-color 250ms ease, color 250ms ease;
}
body::before {
  content: '';
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  opacity: var(--grain-opacity);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
  mix-blend-mode: overlay;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; }
img, svg { display: block; max-width: 100%; }
::selection { background: var(--amber); color: #08090f; }

/* typography helpers */
.f-display {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -.025em;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
  line-height: 1.02;
}
.f-mono { font-family: var(--font-mono); font-variation-settings: normal; }
.f-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text-3);
  font-weight: 500;
}

.container { max-width: var(--container); margin: 0 auto; padding: 0 28px; position: relative; z-index: 2; }
@media (max-width: 720px) { .container { padding: 0 20px; } }

/* skip nav */
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--amber); color: #08090f;
  padding: 10px 16px; border-radius: 6px;
  font-weight: 600; font-size: 13px;
  z-index: 1000;
}
.skip-link:focus { left: 16px; top: 16px; }

/* ===========================================================
   HEADER
   =========================================================== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--header-bg);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--border);
}
.header-inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 28px;
  height: 68px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}
@media (max-width: 1100px) { .header-inner { grid-template-columns: auto minmax(0, 1fr) auto; gap: 12px; padding: 0 14px; height: 60px; } }

.logo {
  grid-column: 1;
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-body);
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -.025em;
  color: var(--text);
  flex-shrink: 0;
}
.logo em { font-style: normal; font-weight: 700; color: var(--amber); margin-left: 1px; }
.logo-mark { width: 30px; height: 30px; display: inline-flex; color: var(--amber); }
.logo-mark svg { width: 100%; height: 100%; }

/* search bar (header) */
.header-search {
  grid-column: 2;
  display: flex; align-items: center; gap: 10px;
  height: 40px;
  padding: 0 14px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-3);
  transition: border-color var(--transition);
  max-width: 420px;
  width: 100%;
  justify-self: center;
}
.header-search:hover, .header-search:focus-within {
  border-color: var(--border-strong);
  color: var(--text-2);
}
.header-search svg { width: 14px; height: 14px; flex-shrink: 0; }
.header-search input {
  flex: 1; min-width: 0;
  background: transparent;
  border: none; outline: none;
  font: inherit; font-size: 14px;
  color: var(--text);
}
.header-search input::placeholder { color: var(--text-3); }
.header-search kbd {
  font-family: var(--font-mono);
  font-size: 10.5px;
  padding: 2px 6px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-3);
}
@media (max-width: 1100px) { .header-search { display: none; } }

/* primary nav (right side) */
.header-right {
  grid-column: 3;
  display: flex; align-items: center; gap: 4px;
  flex-shrink: 0;
  justify-self: end;
}
.nav-primary {
  display: flex; align-items: center; gap: 2px;
}
.nav-link {
  display: inline-flex;
  align-items: center;
  position: relative;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-2);
  transition: color var(--transition), background var(--transition);
  white-space: nowrap;
}
.nav-link:hover { color: var(--text); background: var(--bg-2); }
.nav-link.is-active { color: var(--amber); }
.nav-link svg.caret { width: 12px; height: 12px; margin-left: 4px; opacity: .55; transition: transform var(--transition); }
.nav-item { position: relative; }
.nav-item:hover .nav-link svg.caret { transform: rotate(180deg); }

/* Invisible hover bridge: extends the nav-link's hover area down across
   the 6px visual gap between the link and its dropdown panel, so moving
   the cursor toward the dropdown items doesn't break the :hover state.
   Only applied to triggers that actually have a dropdown. */
.nav-item:has(.nav-dropdown) > .nav-link::after {
  content: '';
  position: absolute;
  top: 100%;
  left: -10px;
  right: -10px;
  height: 14px;
}

.nav-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%) translateY(-6px);
  opacity: 0; pointer-events: none;
  width: 340px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px;
  box-shadow: var(--shadow-lg);
  transition: opacity var(--transition), transform var(--transition);
}
.nav-item:hover .nav-dropdown,
.nav-item:focus-within .nav-dropdown {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.dd-link {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 12px; border-radius: 8px;
  font-size: 14px; color: var(--text-2);
  transition: background var(--transition), color var(--transition);
  position: relative;
}
.dd-link:hover { background: var(--bg-2); color: var(--text); }
.dd-icon {
  flex: 0 0 32px; width: 32px; height: 32px;
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-2); color: var(--text-2);
  transition: background var(--transition), color var(--transition);
}
.dd-icon svg { width: 18px; height: 18px; }
.dd-link:hover .dd-icon { background: var(--bg-3, var(--bg-1)); color: var(--text); }
.dd-text { display: flex; flex-direction: column; min-width: 0; flex: 1 1 auto; padding-right: 56px; }
.dd-link b { display: block; color: var(--text); font-weight: 600; font-size: 14px; margin-bottom: 2px; }
.dd-link .dd-text span { color: var(--text-3); font-size: 12.5px; line-height: 1.4; }
.dd-link .badge {
  font-family: var(--font-mono);
  position: absolute; top: 12px; right: 12px;
  font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  padding: 3px 6px; border-radius: 999px;
  background: var(--green-soft); color: var(--green);
}

@media (max-width: 1100px) { .nav-primary { display: none; } }

.header-actions { display: flex; align-items: center; gap: 8px; }

.theme-toggle {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2);
  transition: color var(--transition), border-color var(--transition), transform var(--transition);
}
.theme-toggle:hover { color: var(--amber); border-color: var(--amber); transform: rotate(20deg); }
.theme-toggle svg { width: 16px; height: 16px; }
[data-theme="dark"] .theme-toggle .ico-sun { display: block; }
[data-theme="dark"] .theme-toggle .ico-moon { display: none; }
[data-theme="light"] .theme-toggle .ico-sun { display: none; }
[data-theme="light"] .theme-toggle .ico-moon { display: block; }

/* Mobile-only search icon — replaces the full search bar below 1100px */
.search-icon {
  display: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  align-items: center; justify-content: center;
  color: var(--text-2);
  cursor: pointer;
  transition: color var(--transition), border-color var(--transition);
}
.search-icon:hover { color: var(--amber); border-color: var(--amber); }
.search-icon svg { width: 15px; height: 15px; }
@media (max-width: 1100px) { .search-icon { display: inline-flex; } }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 14px; font-weight: 600;
  border: 1px solid transparent;
  transition: all var(--transition);
  white-space: nowrap;
  font-family: inherit;
}
.btn-ghost { color: var(--text-2); }
.btn-ghost:hover { color: var(--text); background: var(--bg-2); }
.btn-outline { color: var(--text); border-color: var(--border-strong); background: transparent; }
.btn-outline:hover { background: var(--bg-2); border-color: var(--text-3); }
.btn-primary {
  color: #08090f;
  background: linear-gradient(180deg, var(--amber-strong), var(--amber));
  border-color: color-mix(in oklab, var(--amber) 75%, #000);
  box-shadow: 0 1px 0 rgba(255,255,255,.25) inset, 0 8px 22px -10px var(--amber);
}
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 1px 0 rgba(255,255,255,.3) inset, 0 12px 30px -10px var(--amber); }
.btn-lg { padding: 14px 26px; font-size: 15px; }

@media (max-width: 1100px) {
  /* Below 1100px both header buttons go into the mobile drawer footer */
  .header-actions .btn-ghost,
  .header-actions .btn-primary { display: none; }
}

.mobile-toggle {
  display: none;
  width: 40px; height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  align-items: center; justify-content: center;
}
@media (max-width: 1100px) { .mobile-toggle { display: inline-flex; } }

/* ===========================================================
   QUICK-LINK BAR (horizontally scrollable dev pills under header)
   Mirrors the Quick Start / SDK / OpenAPI strip from roxyapi.com.
   =========================================================== */
.quick-bar {
  background: var(--bg-1);
  border-bottom: 1px solid var(--border);
  position: relative;
  z-index: 5;
}
.quick-strip {
  display: flex;
  gap: 8px;
  padding: 12px 0;
  overflow-x: auto;
  max-width: 100%;
  min-width: 0;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
  scrollbar-width: none;          /* Firefox */
}
.quick-strip::-webkit-scrollbar { display: none; }   /* Chrome/Safari */
/* Center the pills on desktop where they all fit. On mobile keep them
   flush-left so the horizontal scroll behavior stays intuitive. */
@media (min-width: 1101px) {
  .quick-strip { justify-content: center; }
}
.quick-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  scroll-snap-align: start;
  flex-shrink: 0;
  transition: border-color var(--transition), background var(--transition), color var(--transition);
}
.quick-pill:hover {
  border-color: var(--text-3);
  background: var(--bg-2);
}
.quick-pill svg {
  width: 14px; height: 14px;
  color: var(--amber);
  flex-shrink: 0;
}
/* Fade on the right edge to hint at horizontal scroll on narrow viewports.
   Skipped on desktop where the pills typically all fit. */
@media (max-width: 1100px) {
  .quick-bar::after {
    content: '';
    position: absolute;
    right: 0; top: 0; bottom: 0;
    width: 56px;
    background: linear-gradient(to right, transparent, var(--bg-1));
    pointer-events: none;
  }
}

/* ===========================================================
   MOBILE DRAWER (slide-over panel)
   =========================================================== */

/* Overlay backdrop — click to close */
.mobile-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, .55);
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  z-index: 150;
  opacity: 0;
  pointer-events: none;
  transition: opacity 250ms var(--ease-out);
}
.mobile-overlay.is-open { opacity: 1; pointer-events: auto; }

/* Drawer panel */
.mobile-drawer {
  display: none;
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(380px, 88vw);
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: -12px 0 36px -8px rgba(0, 0, 0, .5);
  z-index: 200;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 280ms var(--ease-out);
}
.mobile-drawer.is-open { transform: translateX(0); }

@media (max-width: 1100px) {
  .mobile-drawer { display: flex; }
}

/* Drawer header bar */
.md-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.md-title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -.01em;
}
.md-close {
  width: 36px; height: 36px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2);
  transition: color var(--transition), border-color var(--transition);
}
.md-close:hover { color: var(--text); border-color: var(--text-3); }
.md-close svg { width: 16px; height: 16px; }

/* Scrollable body */
.md-body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 14px 16px;
  -webkit-overflow-scrolling: touch;
}

.md-section { margin-bottom: 4px; }
.md-section:last-child { margin-bottom: 0; }
.md-section-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--text-3);
  margin: 0;
  padding: 6px 14px 2px;
}

/* Menu links — icon + label + optional badge */
.md-link {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 11px 14px;
  border-radius: 10px;
  color: var(--text);
  font-size: 15px;
  font-weight: 500;
  transition: background var(--transition);
  text-decoration: none;
}
.md-link:hover { background: var(--bg-1); }
.md-link:active { background: var(--bg-2); }
.md-link .md-icon {
  width: 22px; height: 22px;
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--amber);  /* default — overridden per-item by inline color in product icons */
  opacity: .9;
}
.md-link .md-icon svg { width: 18px; height: 18px; }
.md-link .md-label { flex: 1; min-width: 0; }
.md-link .md-badge {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 3px 7px;
  border-radius: 999px;
  background: var(--green-soft);
  color: var(--green);
  flex-shrink: 0;
}

/* Color the icon per-section to match the product accent. We use nth-of-type
   tricks inside the APIs section so each gets its own brand color, matching
   the dom-card grid. */
.md-section:nth-of-type(1) .md-link:nth-of-type(1) .md-icon { color: var(--amber);  }
.md-section:nth-of-type(1) .md-link:nth-of-type(2) .md-icon { color: var(--purple); }
.md-section:nth-of-type(1) .md-link:nth-of-type(3) .md-icon { color: var(--blue);   }
.md-section:nth-of-type(1) .md-link:nth-of-type(4) .md-icon { color: var(--teal);   }
.md-section:nth-of-type(1) .md-link:nth-of-type(5) .md-icon { color: var(--cyan);   }
.md-section:nth-of-type(1) .md-link:nth-of-type(6) .md-icon { color: var(--rose);   }
.md-section:nth-of-type(1) .md-link:nth-of-type(7) .md-icon { color: var(--orange); }
.md-section:nth-of-type(1) .md-link:nth-of-type(8) .md-icon { color: var(--green);  }

/* Sticky CTA at the bottom */
.md-foot {
  padding: 16px 20px;
  border-top: 1px solid var(--border);
  background: var(--bg);
  flex-shrink: 0;
}
.md-foot .btn { width: 100%; }

/* Lock body scroll while drawer is open */
body.no-scroll { overflow: hidden; }

/* ===========================================================
   SEARCH MODAL — opens when the search icon (mobile) or the
   header search bar (desktop) is clicked. Filters a static
   JSON index embedded in window.SEARCH_INDEX.
   =========================================================== */
.search-modal {
  position: fixed; inset: 0;
  z-index: 250;
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 20px 20px;
}
.search-modal.is-open { display: flex; }
@media (max-width: 720px) { .search-modal { padding: 12px; } }

.search-modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, .55);
  -webkit-backdrop-filter: blur(4px);
          backdrop-filter: blur(4px);
}
.search-modal-panel {
  position: relative;
  width: 100%;
  max-width: 640px;
  max-height: calc(100vh - 100px);
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.5);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: searchPop 180ms var(--ease-out);
}
@keyframes searchPop {
  from { opacity: 0; transform: translateY(-8px) scale(.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}
@media (max-width: 720px) { .search-modal-panel { max-height: calc(100vh - 24px); } }

.search-modal-head {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.search-modal-head .search-icon-svg {
  width: 18px; height: 18px;
  color: var(--text-3);
  flex-shrink: 0;
}
.search-modal-head input {
  flex: 1; min-width: 0;
  background: transparent;
  border: none; outline: none;
  font: inherit;
  font-size: 16px;
  color: var(--text);
}
.search-modal-head input::placeholder { color: var(--text-3); }
.search-modal-close {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--text-3);
  cursor: pointer;
  transition: color var(--transition), border-color var(--transition);
}
.search-modal-close:hover { color: var(--text); border-color: var(--text-3); }

.search-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 8px;
}
.search-hint {
  padding: 28px 24px;
  text-align: center;
  color: var(--text-3);
  font-size: 14px;
}
.search-result {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
  color: var(--text);
  cursor: pointer;
}
.search-result + .search-result { margin-top: 2px; }
.search-result:hover,
.search-result.is-active { background: var(--bg-2); }

.search-result-kind {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: 4px 7px;
  border-radius: 4px;
  background: var(--bg-3);
  color: var(--text-2);
  flex-shrink: 0;
  min-width: 64px;
  text-align: center;
}
.search-result-kind[data-kind="API"]      { background: var(--amber-soft);  color: var(--amber); }
.search-result-kind[data-kind="Endpoint"] { background: var(--purple-soft); color: var(--purple); }
.search-result-kind[data-kind="Page"]     { background: var(--teal-soft);   color: var(--teal); }
.search-result-kind[data-kind="Docs"]     { background: var(--blue-soft);   color: var(--blue); }

.search-result-text { min-width: 0; overflow: hidden; }
.search-result-title {
  font-size: 14.5px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-result-desc {
  font-size: 12.5px;
  color: var(--text-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
}
.search-result mark {
  background: var(--amber-soft);
  color: var(--amber);
  padding: 0 2px;
  border-radius: 2px;
}

.search-modal-foot {
  display: flex;
  gap: 18px;
  padding: 10px 18px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-3);
  flex-shrink: 0;
}
.search-modal-foot kbd {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 2px 5px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-2);
  margin-right: 4px;
}
@media (max-width: 480px) { .search-modal-foot { display: none; } }

/* ===========================================================
   HERO (homepage)
   =========================================================== */
.hero {
  position: relative;
  padding: 88px 0 100px;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  text-align: center;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(700px 380px at 80% 0%, var(--purple-soft), transparent 65%),
    radial-gradient(600px 380px at 20% 100%, var(--teal-soft), transparent 65%),
    radial-gradient(500px 360px at 50% 40%, var(--amber-soft), transparent 70%);
}
.hero::after {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .25;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
          mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
}
.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 12.5px; color: var(--text-2);
  margin-bottom: 26px;
}
.hero-tag .pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--teal);
  box-shadow: 0 0 0 0 color-mix(in oklab, var(--teal) 60%, transparent);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--teal) 60%, transparent); }
  70% { box-shadow: 0 0 0 8px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5.2vw, 64px);
  font-weight: 600;
  line-height: 1.08;
  letter-spacing: -.025em;
  margin: 0 auto 22px;
  max-width: 820px;
}
/* gradient sweep for the first line — gold → lavender, matching live starsapi.com (#f59e0b → #a78bfa) */
.hero h1 .gradient {
  background-image: linear-gradient(135deg, #f59e0b 30%, #a78bfa 100%);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
          color: transparent;
  font-weight: 600;
}
.hero h1 em { font-style: normal; color: var(--amber); font-weight: 500; }
.hero-sub {
  font-size: 18px;
  color: var(--text-2);
  max-width: 620px;
  margin: 0 auto 32px;
  line-height: 1.55;
}
.hero-sub b { color: var(--text); font-weight: 600; }

/* domain pills row (under the headline) */
.hero-pills {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
  max-width: 880px;
  margin: 0 auto 36px;
}
.hero-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px 7px 12px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 13px;
  color: var(--text-2);
  transition: all var(--transition);
}
.hero-pill:hover { color: var(--text); transform: translateY(-1px); }
.hero-pill svg { width: 14px; height: 14px; }
/* per-product pill colors */
.hero-pill.amber  { color: var(--amber);  background: var(--amber-soft);  border-color: transparent; }
.hero-pill.purple { color: var(--purple); background: var(--purple-soft); border-color: transparent; }
.hero-pill.blue   { color: var(--blue);   background: var(--blue-soft);   border-color: transparent; }
.hero-pill.teal   { color: var(--teal);   background: var(--teal-soft);   border-color: transparent; }
.hero-pill.rose   { color: var(--rose);   background: var(--rose-soft);   border-color: transparent; }
.hero-pill.orange { color: var(--orange); background: var(--orange-soft); border-color: transparent; }
.hero-pill.green  { color: var(--green);  background: var(--green-soft);  border-color: transparent; }
.hero-pill.cyan   { color: var(--cyan);   background: var(--cyan-soft);   border-color: transparent; }

/* Featured pills (AI Voice + AI Chat) — pulsing glow + "live" indicator */
.hero-pill--featured {
  position: relative;
  padding-left: 24px;
  font-weight: 600;
  box-shadow: 0 0 0 0 currentColor;
  animation: pill-glow 2.4s ease-in-out infinite;
}
.hero-pill--featured::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 6px currentColor;
  animation: pill-dot-pulse 1.4s ease-in-out infinite;
}
.hero-pill--featured:hover {
  transform: translateY(-2px) scale(1.02);
  filter: brightness(1.08);
}
@keyframes pill-glow {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, currentColor 30%, transparent); }
  50%      { box-shadow: 0 0 18px 2px color-mix(in srgb, currentColor 40%, transparent); }
}
@keyframes pill-dot-pulse {
  0%, 100% { opacity: 1; transform: translateY(-50%) scale(1); }
  50%      { opacity: 0.5; transform: translateY(-50%) scale(1.4); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-pill--featured,
  .hero-pill--featured::before { animation: none; }
}

.hero-cta { display: inline-flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

/* Ship-promise line — sits between pills and CTAs on its own row */
.hero-ship {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  margin: 24px auto 16px;
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--amber-soft);
  border: 1px solid color-mix(in srgb, var(--amber) 25%, transparent);
  font-size: 14px;
  color: var(--text-2);
}
.hero-ship svg { width: 14px; height: 14px; color: var(--amber); flex: 0 0 14px; }
.hero-ship b   { color: var(--amber); font-weight: 700; }
@media (max-width: 480px) {
  .hero-ship { font-size: 13px; padding: 7px 12px; }
}
.hero-trust {
  display: flex; flex-wrap: wrap; gap: 22px;
  margin-top: 40px;
  justify-content: center;
}
.trust-item { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--text-2); }
.trust-item b { color: var(--text); }
.trust-item svg { width: 14px; height: 14px; color: var(--amber); }

/* ===========================================================
   SECTION BASE
   =========================================================== */
section.block {
  padding: 100px 0;
  position: relative;
  border-bottom: 1px solid var(--border);
}
@media (max-width: 720px) { section.block { padding: 64px 0; } }

.section-head { max-width: 720px; margin-bottom: 56px; }
.section-head .f-eyebrow { color: var(--amber); margin-bottom: 14px; display: block; }
.section-head h2 {
  font-family: var(--font-display);
  font-size: clamp(26px, 3.4vw, 42px);
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.15;
  margin: 0 0 18px;
}
.section-head h2 em { font-style: normal; color: var(--amber); font-weight: 500; }
.section-head p { font-size: 17px; color: var(--text-2); margin: 0; max-width: 600px; }

/* ===========================================================
   DOMAINS GRID (homepage)
   =========================================================== */
.domains-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 980px) { .domains-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .domains-grid { grid-template-columns: 1fr; } }

.dom-card {
  position: relative;
  padding: 32px 28px;
  background: var(--bg);
  display: flex; flex-direction: column;
  transition: background var(--transition);
  cursor: pointer;
  min-height: 260px;
}
.dom-card:hover { background: var(--bg-1); }
.dom-card .dom-icon {
  width: 44px; height: 44px;
  border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.dom-card .dom-icon svg { width: 22px; height: 22px; }
.dom-card.accent-amber  .dom-icon { background: var(--amber-soft);  color: var(--amber); }
.dom-card.accent-purple .dom-icon { background: var(--purple-soft); color: var(--purple); }
.dom-card.accent-blue   .dom-icon { background: var(--blue-soft);   color: var(--blue); }
.dom-card.accent-teal   .dom-icon { background: var(--teal-soft);   color: var(--teal); }
.dom-card.accent-rose   .dom-icon { background: var(--rose-soft);   color: var(--rose); }
.dom-card.accent-orange .dom-icon { background: var(--orange-soft); color: var(--orange); }
.dom-card.accent-green  .dom-icon { background: var(--green-soft);  color: var(--green); }
.dom-card.accent-cyan   .dom-icon { background: var(--cyan-soft);   color: var(--cyan); }

.dom-card h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 450;
  margin: 0 0 8px;
  letter-spacing: -.015em;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
}
.dom-card .dom-count {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-3);
  letter-spacing: .05em;
  margin-bottom: 14px;
}
.dom-card p { color: var(--text-2); font-size: 14.5px; margin: 0 0 auto; line-height: 1.5; }
.dom-card .dom-arrow {
  margin-top: 18px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600;
  transition: gap var(--transition);
}
.dom-card.accent-amber  .dom-arrow { color: var(--amber); }
.dom-card.accent-purple .dom-arrow { color: var(--purple); }
.dom-card.accent-blue   .dom-arrow { color: var(--blue); }
.dom-card.accent-teal   .dom-arrow { color: var(--teal); }
.dom-card.accent-rose   .dom-arrow { color: var(--rose); }
.dom-card.accent-orange .dom-arrow { color: var(--orange); }
.dom-card.accent-green  .dom-arrow { color: var(--green); }
.dom-card.accent-cyan   .dom-arrow { color: var(--cyan); }
.dom-card:hover .dom-arrow { gap: 12px; }

.dom-card .dom-badge {
  position: absolute; top: 14px; right: 14px;
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--bg-2);
  color: var(--text-2);
  border: 1px solid var(--border);
}
.dom-card.accent-amber  .dom-badge { background: var(--amber-soft);  color: var(--amber);  border-color: transparent; }
.dom-card.accent-rose   .dom-badge { background: var(--rose-soft);   color: var(--rose);   border-color: transparent; }
.dom-card.accent-green  .dom-badge { background: var(--green-soft);  color: var(--green);  border-color: transparent; }

/* ===========================================================
   PRODUCT PAGE LAYOUT
   =========================================================== */
.product-hero {
  position: relative;
  padding: 40px 0 64px;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.product-hero::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(800px 400px at 70% 0%, var(--accent-glow, var(--amber-soft)), transparent 70%);
}
.product-hero[data-accent="amber"]  { --accent-glow: var(--amber-soft);  --accent: var(--amber);  --accent-strong: var(--amber-strong); }
.product-hero[data-accent="purple"] { --accent-glow: var(--purple-soft); --accent: var(--purple); --accent-strong: var(--purple); }
.product-hero[data-accent="blue"]   { --accent-glow: var(--blue-soft);   --accent: var(--blue);   --accent-strong: var(--blue); }
.product-hero[data-accent="teal"]   { --accent-glow: var(--teal-soft);   --accent: var(--teal);   --accent-strong: var(--teal); }
.product-hero[data-accent="rose"]   { --accent-glow: var(--rose-soft);   --accent: var(--rose);   --accent-strong: var(--rose); }
.product-hero[data-accent="orange"] { --accent-glow: var(--orange-soft); --accent: var(--orange); --accent-strong: var(--orange); }
.product-hero[data-accent="green"]  { --accent-glow: var(--green-soft);  --accent: var(--green);  --accent-strong: var(--green); }
.product-hero[data-accent="cyan"]   { --accent-glow: var(--cyan-soft);   --accent: var(--cyan);   --accent-strong: var(--cyan); }

.breadcrumb {
  display: flex; gap: 8px; align-items: center;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 18px;
}
.breadcrumb a:hover { color: var(--text); }
.breadcrumb svg { width: 10px; height: 10px; opacity: .5; flex: 0 0 10px; }

.product-hero .product-icon {
  width: 56px; height: 56px;
  border-radius: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent-glow);
  color: var(--accent);
  margin-bottom: 24px;
}
.product-hero .product-icon svg { width: 28px; height: 28px; }

/* "World's first" badge above H1 — accent-colored, pulsing border */
.product-hero .product-firstbadge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  padding: 7px 14px 7px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .04em;
  font-weight: 500;
  text-transform: none;
  animation: firstbadge-pulse 3s ease-in-out infinite;
}
.product-hero .product-firstbadge svg { width: 14px; height: 14px; flex: 0 0 14px; }
.product-hero .product-firstbadge strong { font-weight: 700; letter-spacing: .03em; text-transform: uppercase; }
.product-hero .product-firstbadge .dot-sep { color: color-mix(in srgb, var(--accent) 50%, transparent); margin: 0 2px; }
@keyframes firstbadge-pulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 30%, transparent); }
  50%      { box-shadow: 0 0 14px 1px color-mix(in srgb, var(--accent) 35%, transparent); }
}
@media (prefers-reduced-motion: reduce) {
  .product-hero .product-firstbadge { animation: none; }
}

.product-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(30px, 4.2vw, 52px);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -.022em;
  margin: 0 0 18px;
  max-width: 800px;
}
.product-hero h1 em { font-style: normal; color: var(--accent); font-weight: 500; }
.product-hero .lede { font-size: 18px; color: var(--text-2); max-width: 640px; line-height: 1.6; margin: 0 0 28px; }
.product-hero .hero-cta-row { display: flex; gap: 12px; flex-wrap: wrap; margin: 0 0 32px; }

/* Page-level accent — set via [data-page-accent] on a wrapper around the page */
[data-page-accent="rose"]   { --page-accent: var(--rose);   --page-accent-soft: var(--rose-soft); }
[data-page-accent="purple"] { --page-accent: var(--purple); --page-accent-soft: var(--purple-soft); }
[data-page-accent] .howit-h2 em,
[data-page-accent] .response-h2 em,
[data-page-accent] .marquee-h2 em {
  font-style: normal;
  color: var(--page-accent);
  font-weight: inherit;
}

/* Pills label as a section header above the pill row, not inline beside it */
[data-page-accent] .marquee-pills-block {
  margin-top: 40px;
  text-align: center;
}
[data-page-accent] .marquee-pills-block .pills-label {
  display: block;
  width: 100%;
  margin: 0 auto 14px;
  font: 600 11px var(--font-mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--page-accent);
  text-align: center;
}
[data-page-accent] .marquee-pills-block .pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}

/* Offering cards — make them a bit more refined */
[data-page-accent] .offering-card {
  position: relative;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
[data-page-accent] .offering-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  border-radius: 12px 12px 0 0;
  background: linear-gradient(90deg, transparent, var(--page-accent), transparent);
  opacity: 0;
  transition: opacity .2s ease;
}
[data-page-accent] .offering-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--page-accent) 40%, var(--border));
  background: color-mix(in srgb, var(--page-accent) 4%, var(--bg-1));
}
[data-page-accent] .offering-card:hover::before { opacity: 1; }
[data-page-accent] .offering-card h4 .glyph {
  background: color-mix(in srgb, var(--page-accent) 14%, var(--bg-2));
  color: var(--page-accent);
}
[data-page-accent] .offering-card ul li::marker { color: var(--page-accent); }
.product-hero .stat-row {
  display: flex; flex-wrap: wrap; gap: 28px;
  padding: 22px 0 0;
  border-top: 1px dashed var(--border);
  margin-top: 32px;
}
.product-hero .stat {
  display: flex; flex-direction: column;
}
.product-hero .stat .num {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 600;
  color: var(--text);
  line-height: 1;
}
.product-hero .stat .num em { font-style: normal; color: var(--accent); }
.product-hero .stat .lab { font-family: var(--font-mono); font-size: 10.5px; color: var(--text-3); text-transform: uppercase; letter-spacing: .14em; margin-top: 6px; }

/* features row (4 across) */
.feature-row {
  border-bottom: 1px solid var(--border);
}
.feature-row-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  margin: 36px 0;
}
@media (max-width: 860px) { .feature-row-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .feature-row-grid { grid-template-columns: 1fr; } }
.feature-cell {
  padding: 32px 28px;
  background: var(--bg);
}
.feature-cell h4 {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 500;
  margin: 0 0 6px;
  letter-spacing: -.01em;
}
.feature-cell p { color: var(--text-2); font-size: 14px; line-height: 1.55; margin: 0; }

/* endpoint groups */
.system-section { padding: 100px 0; border-bottom: 1px solid var(--border); position: relative; }
@media (max-width: 720px) { .system-section { padding: 64px 0; } }

.system-header {
  display: grid; grid-template-columns: 1fr auto;
  align-items: end; gap: 32px;
  margin-bottom: 40px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
@media (max-width: 720px) { .system-header { grid-template-columns: 1fr; align-items: start; } }
.system-id {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
}
.system-title {
  font-family: var(--font-display);
  font-size: clamp(32px, 4.2vw, 54px);
  font-weight: 350;
  line-height: 1.05;
  letter-spacing: -.03em;
  margin: 0 0 14px;
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 1;
}
.system-title em { font-style: normal; color: var(--amber); }
.system-blurb { color: var(--text-2); font-size: 16px; max-width: 560px; margin: 0; }
.system-stats { display: flex; gap: 24px; }
.stat-r { text-align: right; }
.stat-r .num {
  font-family: var(--font-display);
  font-size: 36px; font-weight: 350;
  color: var(--text); line-height: 1;
  font-variation-settings: "opsz" 144, "SOFT" 60, "WONK" 1;
}
.stat-r .num em { font-style: normal; color: var(--amber); }
.stat-r .lab { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); text-transform: uppercase; letter-spacing: .14em; margin-top: 6px; }

.eg-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media (max-width: 980px) { .eg-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .eg-grid { grid-template-columns: 1fr; } }

.eg {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px 22px 18px;
  display: flex; flex-direction: column;
  transition: border-color var(--transition), transform var(--transition);
}
.eg:hover { border-color: var(--border-strong); transform: translateY(-2px); }
.eg-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; gap: 10px; }
.eg-head h4 {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 500;
  letter-spacing: -.012em;
  margin: 0;
  font-variation-settings: "opsz" 144, "SOFT" 30, "WONK" 0;
}
.eg-count { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: .08em; }
.eg p.eg-desc { color: var(--text-2); font-size: 13.5px; margin: 0 0 14px; line-height: 1.5; }
.eg ul { list-style: none; margin: 0; padding: 0; }
.eg li {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-2);
  padding: 6px 0;
  border-top: 1px dashed var(--border);
}
.eg li:first-child { border-top: 1px solid var(--border); margin-top: 4px; padding-top: 10px; }
.eg li .method {
  font-size: 9.5px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--purple-soft);
  color: var(--purple);
  letter-spacing: .1em;
  flex-shrink: 0;
}
.eg li .method.post { background: var(--amber-soft); color: var(--amber); }
.eg li .path { color: var(--text-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.eg li:hover .path { color: var(--text); }

/* ===========================================================
   AI ASTROLOGER PERSONAS
   =========================================================== */
.ai-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 860px) { .ai-grid { grid-template-columns: 1fr; } }
.ai-panel {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 28px 24px;
}
.ai-panel-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 6px; }
.ai-panel-head h3 {
  font-family: var(--font-display);
  font-size: 26px; font-weight: 450;
  letter-spacing: -.02em; margin: 0;
}
.ai-panel-head h3 em { font-style: normal; color: var(--amber); }
.ai-panel-head .tag {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--text-3);
  text-transform: uppercase; letter-spacing: .1em;
}
.ai-panel > p { color: var(--text-2); font-size: 14px; margin: 0 0 20px; }
.ai-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (max-width: 540px) { .ai-list { grid-template-columns: 1fr; } }
.ai-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: border-color var(--transition);
}
.ai-item:hover { border-color: var(--amber); }
.ai-avatar {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  color: var(--bg);
  flex-shrink: 0;
}
.ai-meta { min-width: 0; }
.ai-name { font-family: var(--font-display); font-weight: 500; font-size: 15px; line-height: 1.2; }
.ai-spec { font-family: var(--font-mono); font-size: 10.5px; color: var(--text-3); text-transform: uppercase; letter-spacing: .08em; margin-top: 3px; }

/* ===========================================================
   CODE WINDOW
   =========================================================== */
.code-section { background: var(--bg-1); }
.code-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 56px;
  align-items: center;
}
@media (max-width: 980px) { .code-grid { grid-template-columns: 1fr; gap: 32px; } }

.code-tabs { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.code-tab {
  padding: 8px 14px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: 13px; font-weight: 500;
  font-family: var(--font-mono);
  transition: all var(--transition);
}
.code-tab:hover { color: var(--text); border-color: var(--text-3); }
.code-tab.is-active { background: var(--amber); color: #08090f; border-color: var(--amber); }

.code-window {
  background: var(--code-bg);
  border: 1px solid var(--code-border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.code-window-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px;
  border-bottom: 1px solid var(--code-border);
  background: rgba(255,255,255,.02);
}
.code-window-bar .dots { display: flex; gap: 6px; }
.code-window-bar .dots span { width: 10px; height: 10px; border-radius: 50%; background: #2a3148; }
.code-window-bar .endpoint {
  font-family: var(--font-mono); font-size: 11.5px;
  color: #a8aec5;
  margin-left: auto;
  display: flex; gap: 8px; align-items: center;
}
.code-window-bar .endpoint .verb {
  background: #1d4f3f; color: #6ee7c7;
  padding: 2px 6px; border-radius: 4px; font-weight: 700; font-size: 10px;
}
.code-window-bar .endpoint .verb.get { background: #1d3a5f; color: #93c5fd; }
.code-window pre {
  margin: 0; padding: 22px 24px;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 12.5px;
  line-height: 1.6;
  color: #cdd2e6;
  max-height: 480px;
}
.code-window pre .k { color: #a78bfa; }
.code-window pre .s { color: #f5b041; }
.code-window pre .n { color: #6ee7c7; }
.code-window pre .c { color: #6b7088; }
.code-window pre .b { color: #f47b9c; }

.code-panes > .code-pane { display: none; }
.code-panes > .code-pane.is-active { display: block; animation: fadeIn .25s ease-out; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

.code-feature ul { list-style: none; margin: 24px 0 0; padding: 0; }
.code-feature li { display: flex; gap: 12px; padding: 14px 0; border-top: 1px solid var(--border); }
.code-feature li:first-child { border-top: none; padding-top: 0; }
.code-feature li svg { width: 18px; height: 18px; color: var(--amber); flex-shrink: 0; margin-top: 3px; }
.code-feature li b { display: block; color: var(--text); font-size: 15px; margin-bottom: 2px; font-weight: 600; }
.code-feature li span { color: var(--text-2); font-size: 14px; }

/* ===========================================================
   STATS / WHY GRID
   =========================================================== */
.why-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (max-width: 860px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .why-grid { grid-template-columns: 1fr; } }
.why-cell {
  padding: 32px 28px;
  background: var(--bg);
  display: flex; flex-direction: column;
  min-height: 200px;
}
.why-cell .why-num {
  font-family: var(--font-display);
  font-size: 56px;
  font-weight: 300;
  line-height: 1;
  letter-spacing: -.04em;
  color: var(--amber);
  margin-bottom: 14px;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.why-cell h4 {
  font-family: var(--font-display);
  font-size: 17px; font-weight: 500;
  margin: 0 0 6px;
  letter-spacing: -.01em;
}
.why-cell p { color: var(--text-2); font-size: 13.5px; margin: 0; line-height: 1.5; }

/* ===========================================================
   PRICING
   =========================================================== */
.price-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 860px) { .price-grid { grid-template-columns: 1fr; } }

.price-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px;
  display: flex; flex-direction: column;
  position: relative;
}
.price-card.featured {
  border-color: var(--amber);
  background: linear-gradient(180deg, var(--amber-soft) 0%, var(--bg-1) 30%);
}
.price-card .price-badge {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  background: var(--amber); color: #08090f;
  padding: 5px 12px; border-radius: 999px;
}
.price-card h3 {
  font-family: var(--font-display);
  font-size: 26px; font-weight: 450;
  margin: 0 0 6px; letter-spacing: -.02em;
}
.price-card .tier-desc { color: var(--text-2); font-size: 14px; margin: 0 0 24px; }
.price-card .price {
  font-family: var(--font-display);
  font-size: 56px; font-weight: 350;
  line-height: 1; letter-spacing: -.03em;
  margin-bottom: 4px;
  font-variation-settings: "opsz" 144, "SOFT" 60, "WONK" 1;
}
.price-card .price .currency { font-size: 24px; vertical-align: top; margin-right: 4px; color: var(--text-2); }
.price-card .price .period { font-size: 16px; color: var(--text-3); margin-left: 4px; }
.price-card .billed { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); letter-spacing: .08em; text-transform: uppercase; margin-bottom: 24px; }
.price-card ul { list-style: none; padding: 0; margin: 0 0 28px; flex: 1; }
.price-card li { display: flex; gap: 10px; padding: 8px 0; font-size: 14px; color: var(--text-2); border-top: 1px dashed var(--border); }
.price-card li:first-child { border-top: none; }
.price-card li svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--green); margin-top: 2px; }
.price-card .btn { width: 100%; }

/* ===========================================================
   CTA BLOCK
   =========================================================== */
.cta-block {
  background:
    radial-gradient(800px 400px at 20% 30%, var(--amber-soft), transparent 60%),
    radial-gradient(600px 400px at 80% 70%, var(--purple-soft), transparent 60%),
    var(--bg-1);
  padding: 80px 0;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}
.cta-block::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 50% 50%, var(--border) 1px, transparent 1px);
  background-size: 30px 30px;
  opacity: .25;
  -webkit-mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
          mask-image: linear-gradient(180deg, transparent, #000 30%, #000 70%, transparent);
}
.cta-inner { position: relative; text-align: center; max-width: 720px; margin: 0 auto; }
.cta-inner h2 {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 350;
  letter-spacing: -.03em;
  line-height: 1.05;
  margin: 0 0 18px;
  font-variation-settings: "opsz" 144, "SOFT" 70, "WONK" 1;
}
.cta-inner h2 em { font-style: normal; color: var(--amber); }
.cta-inner p { font-size: 18px; color: var(--text-2); margin: 0 0 32px; }
.cta-buttons { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer {
  background: var(--bg-1);
  padding: 72px 0 32px;
  position: relative;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr repeat(4, 1fr);
  gap: 40px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--border);
}
@media (max-width: 980px) {
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 540px) { .footer-top { grid-template-columns: 1fr; } }

.footer-brand .logo { margin-bottom: 16px; }
.footer-brand p { color: var(--text-2); font-size: 14px; max-width: 320px; margin: 0 0 20px; line-height: 1.6; }
.footer-social { display: flex; gap: 8px; }
.footer-social a {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--bg-2);
  border: 1px solid var(--border);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-2);
  transition: all var(--transition);
}
.footer-social a:hover { background: var(--amber); color: #08090f; border-color: var(--amber); }
.footer-social svg { width: 16px; height: 16px; }

.footer-col h5 {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--text-3);
  margin: 0 0 16px;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: var(--text-2); font-size: 14px; transition: color var(--transition); }
.footer-col a:hover { color: var(--amber); }
.new-tag { font-size: 9px; font-weight: 700; padding: 2px 5px; border-radius: 3px; background: var(--amber); color: #08090f; margin-left: 6px; vertical-align: middle; letter-spacing: .08em; text-transform: uppercase; font-family: var(--font-mono); }

.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 32px;
  flex-wrap: wrap; gap: 20px;
}
.footer-bottom p { color: var(--text-3); font-size: 13px; margin: 0; }
.footer-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-2);
}
.footer-status .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); }

/* ===========================================================
   UTILITIES
   =========================================================== */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out); }
.reveal.is-in { opacity: 1; transform: translateY(0); }

/* prose for docs/legal pages */
.prose { max-width: 720px; }
.prose h2 { font-family: var(--font-display); font-size: 32px; font-weight: 400; letter-spacing: -.02em; margin: 48px 0 16px; }
.prose h3 { font-family: var(--font-display); font-size: 22px; font-weight: 500; margin: 32px 0 10px; }
.prose p { color: var(--text-2); margin: 0 0 16px; line-height: 1.7; }
.prose code { font-family: var(--font-mono); font-size: 13px; background: var(--bg-2); padding: 2px 6px; border-radius: 4px; color: var(--amber); }
.prose pre { background: var(--code-bg); color: #cdd2e6; padding: 18px 22px; border-radius: var(--radius); overflow-x: auto; margin: 16px 0; font-family: var(--font-mono); font-size: 13px; line-height: 1.6; border: 1px solid var(--code-border); }
.prose ul { padding-left: 22px; color: var(--text-2); }
.prose li { margin: 6px 0; line-height: 1.6; }

/* ===========================================================
   FAQ SECTION (auto-included at bottom of product/marketing pages)
   =========================================================== */
.faq-section {
  padding: 96px 0 112px;
  border-top: 1px solid var(--border);
  position: relative;
}
.faq-head {
  max-width: 720px;
  margin: 0 auto 48px;
  text-align: center;
}
.faq-h2 {
  font-family: var(--font-display);
  font-size: clamp(26px, 3.4vw, 40px);
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--text);
  margin: 0;
}
.faq-list {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.faq-item {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .2s var(--ease-out), background .2s var(--ease-out);
}
.faq-item[open] {
  border-color: color-mix(in oklab, var(--amber) 35%, var(--border));
  background: color-mix(in oklab, var(--amber) 4%, var(--bg-1));
}
.faq-item:hover:not([open]) {
  border-color: color-mix(in oklab, var(--text) 18%, var(--border));
}
.faq-q {
  list-style: none;
  cursor: pointer;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-size: 16px;
  font-weight: 500;
  color: var(--text);
  user-select: none;
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q > span { flex: 1; line-height: 1.45; }
.faq-chevron {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--text-3);
  transition: transform .25s var(--ease-out), color .2s var(--ease-out);
}
.faq-item[open] .faq-chevron {
  transform: rotate(180deg);
  color: var(--amber);
}
.faq-a {
  padding: 0 24px 22px;
  color: var(--text-2);
  font-size: 15px;
  line-height: 1.65;
  max-width: 680px;
}
@media (max-width: 720px) {
  .faq-section { padding: 64px 0 80px; }
  .faq-head { margin-bottom: 32px; }
  .faq-q { padding: 18px 18px; font-size: 15px; }
  .faq-a { padding: 0 18px 18px; font-size: 14px; }
}

/* ===========================================================
   RELATED APIs SECTION (cross-product internal linking)
   =========================================================== */
.related-section {
  padding: 88px 0 100px;
  border-top: 1px solid var(--border);
}
.related-head {
  max-width: 720px;
  margin: 0 auto 40px;
  text-align: center;
}
.related-h2 {
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.2;
  color: var(--text);
  margin: 0;
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  max-width: 1080px;
  margin: 0 auto;
}
.related-card {
  display: flex;
  flex-direction: column;
  padding: 26px 24px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--text);
  transition: border-color .2s var(--ease-out), background .2s var(--ease-out), transform .2s var(--ease-out);
  min-height: 180px;
}
.related-card:hover {
  border-color: color-mix(in oklab, var(--accent, var(--amber)) 50%, var(--border));
  background: color-mix(in oklab, var(--accent, var(--amber)) 5%, var(--bg-1));
  transform: translateY(-2px);
}
.related-card[data-accent="amber"]  { --accent: var(--amber); }
.related-card[data-accent="purple"] { --accent: var(--purple); }
.related-card[data-accent="blue"]   { --accent: var(--blue); }
.related-card[data-accent="teal"]   { --accent: var(--teal); }
.related-card[data-accent="rose"]   { --accent: var(--rose); }
.related-card[data-accent="orange"] { --accent: var(--orange); }
.related-card[data-accent="green"]  { --accent: var(--green); }
.related-card-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent, var(--amber));
  margin-bottom: 8px;
}
.related-card-title {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -.01em;
  line-height: 1.25;
  color: var(--text);
  margin: 0 0 8px;
}
.related-card-desc {
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.55;
  margin: 0 0 18px;
  flex: 1;
}
.related-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 500;
  color: var(--accent, var(--amber));
  margin-top: auto;
}
.related-card-cta svg {
  width: 14px;
  height: 14px;
  transition: transform .2s var(--ease-out);
}
.related-card:hover .related-card-cta svg {
  transform: translateX(3px);
}
@media (max-width: 720px) {
  .related-section { padding: 56px 0 72px; }
  .related-grid { grid-template-columns: 1fr; gap: 14px; }
  .related-card { padding: 22px 20px; min-height: auto; }
}

/* ===========================================================
   AI ASTROLOGER PAGES — shared section styles
   Used by /products/ai-chat-astrologer and /products/ai-voice-astrologer
   =========================================================== */

/* --- "How it works" numbered steps --- */
.howit-section { padding: 96px 0 64px; border-top: 1px solid var(--border); }
.howit-head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.howit-h2 { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 600; letter-spacing: -.02em; line-height: 1.15; margin: 0 0 16px; color: var(--text); }
.howit-blurb { color: var(--text-2); font-size: 16px; line-height: 1.7; margin: 0; }
.howit-steps {
  list-style: none;
  padding: 0; margin: 0;
  max-width: 820px; margin-left: auto; margin-right: auto;
  display: flex; flex-direction: column;
  position: relative;
}
.howit-steps::before {
  content: ''; position: absolute;
  left: 27px; top: 24px; bottom: 24px;
  width: 2px; background: linear-gradient(to bottom, var(--border) 0%, var(--border) 100%);
  opacity: .6;
}
.howit-steps li { display: flex; align-items: flex-start; gap: 22px; padding: 12px 0; position: relative; z-index: 1; }
.step-num {
  width: 56px; height: 56px; flex-shrink: 0;
  border-radius: 50%;
  background: var(--bg-1);
  border: 2px solid var(--border);
  color: var(--text);
  font-family: var(--font-display); font-weight: 600; font-size: 22px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.step-body { padding-top: 8px; }
.step-body h4 { font-family: var(--font-display); font-size: 18px; font-weight: 600; margin: 0 0 6px; color: var(--text); }
.step-body p { color: var(--text-2); margin: 0; line-height: 1.65; font-size: 15px; }
.step-body code { font-family: var(--font-mono); font-size: 12.5px; background: var(--bg-2); padding: 2px 6px; border-radius: 4px; color: var(--amber); }

/* --- Persona grid (5 cards) --- */
.persona-section { padding: 96px 0; border-top: 1px solid var(--border); }
.persona-head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.persona-h2 { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 600; letter-spacing: -.02em; line-height: 1.15; margin: 0 0 16px; color: var(--text); }
.persona-blurb { color: var(--text-2); font-size: 16px; line-height: 1.7; margin: 0; }
.persona-grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  max-width: 1180px; margin: 0 auto;
}
.persona-card {
  background: var(--bg-1); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 26px 22px; display: flex; flex-direction: column; gap: 6px;
  transition: border-color .2s var(--ease-out), background .2s var(--ease-out);
}
.persona-card:hover { border-color: color-mix(in oklab, var(--rose) 45%, var(--border)); background: color-mix(in oklab, var(--rose) 4%, var(--bg-1)); }
.persona-avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: linear-gradient(135deg, var(--rose), color-mix(in oklab, var(--rose) 60%, var(--amber)));
  color: white; font-family: var(--font-display); font-weight: 600; font-size: 22px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 12px;
}
.persona-avatar-voice {
  background: linear-gradient(135deg, var(--purple), color-mix(in oklab, var(--purple) 60%, var(--blue)));
  font-size: 24px;
}
.persona-name { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--text); margin: 0; }
.persona-school { color: var(--text-2); font-size: 13px; font-weight: 500; }
.persona-lang { color: var(--text-3); font-size: 12.5px; font-family: var(--font-mono); }
.persona-tone { color: var(--text-2); font-size: 14px; line-height: 1.55; margin: 6px 0 12px; }
.persona-key {
  font-family: var(--font-mono); font-size: 11.5px;
  background: var(--bg-2); padding: 3px 8px; border-radius: 4px;
  color: var(--amber); align-self: flex-start;
  margin-top: auto;
}

/* --- Integration code blocks --- */
.integration-section, .response-section { padding: 96px 0; border-top: 1px solid var(--border); }
.integration-head, .response-head { max-width: 760px; margin: 0 auto 48px; text-align: center; }
.integration-h2, .response-h2 { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 600; letter-spacing: -.02em; line-height: 1.15; margin: 0 0 16px; color: var(--text); }
.integration-blurb, .response-blurb { color: var(--text-2); font-size: 16px; line-height: 1.7; margin: 0; }
.integration-blurb code, .response-blurb code { font-family: var(--font-mono); font-size: 13px; background: var(--bg-2); padding: 2px 6px; border-radius: 4px; color: var(--amber); }

.code-block {
  max-width: 920px;
  margin: 28px auto 0;
  background: var(--code-bg, #0f0f17);
  border: 1px solid var(--code-border, #1f1f2c);
  border-radius: var(--radius);
  overflow: hidden;
}
.code-label {
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--text-3);
  padding: 12px 18px;
  border-bottom: 1px solid var(--code-border, #1f1f2c);
  background: color-mix(in oklab, var(--code-bg, #0f0f17) 80%, var(--bg-2));
}
.code-block pre {
  margin: 0; padding: 20px 22px;
  font-family: var(--font-mono); font-size: 13px;
  line-height: 1.65; color: #cdd2e6;
  overflow-x: auto;
}
.code-block pre code { font-family: inherit; background: none; padding: 0; color: inherit; font-size: inherit; }

/* --- Platform requirements grid (4 cards) --- */
.platform-section { padding: 96px 0; border-top: 1px solid var(--border); }
.platform-head { max-width: 760px; margin: 0 auto 56px; text-align: center; }
.platform-h2 { font-family: var(--font-display); font-size: clamp(26px, 3.4vw, 40px); font-weight: 600; letter-spacing: -.02em; line-height: 1.15; margin: 0 0 16px; color: var(--text); }
.platform-blurb { color: var(--text-2); font-size: 16px; line-height: 1.7; margin: 0; }
.platform-blurb code { font-family: var(--font-mono); font-size: 13px; background: var(--bg-2); padding: 2px 6px; border-radius: 4px; color: var(--amber); }
.platform-grid {
  display: grid; gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  max-width: 1180px; margin: 0 auto;
}
.platform-card {
  background: var(--bg-1); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 26px 24px;
}
.platform-icon { font-size: 30px; line-height: 1; margin-bottom: 16px; }
.platform-card h3 { font-family: var(--font-display); font-size: 19px; font-weight: 600; margin: 0 0 14px; color: var(--text); }
.platform-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.platform-card li { font-size: 13.5px; line-height: 1.55; color: var(--text-2); }
.platform-card li strong { color: var(--text); font-weight: 500; }
.platform-card li code { font-family: var(--font-mono); font-size: 12px; background: var(--bg-2); padding: 1px 5px; border-radius: 3px; color: var(--amber); }

/* --- Mobile tuning --- */
@media (max-width: 720px) {
  .howit-section, .persona-section, .integration-section, .response-section, .platform-section { padding: 56px 0; }
  .howit-head, .persona-head, .integration-head, .response-head, .platform-head { margin-bottom: 32px; }
  .howit-steps::before { left: 22px; }
  .step-num { width: 44px; height: 44px; font-size: 18px; }
  .howit-steps li { gap: 16px; }
  .platform-grid, .persona-grid { grid-template-columns: 1fr; gap: 14px; }
  .code-block pre { padding: 16px 14px; font-size: 12px; }
}

/* ===========================================================
   VOICE PAGE — "World-first" Marquee Section
   Lives between hero and feature row on /products/ai-voice-astrologer
   =========================================================== */

.marquee-section {
  padding: 88px 0 104px;
  position: relative;
  background:
    radial-gradient(ellipse 60% 80% at 15% 0%, color-mix(in oklab, var(--purple) 12%, transparent), transparent 70%),
    radial-gradient(ellipse 60% 80% at 85% 100%, color-mix(in oklab, var(--rose) 8%, transparent), transparent 70%),
    var(--bg-0);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.marquee-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border-radius: 100px;
  background: color-mix(in oklab, var(--purple) 14%, var(--bg-1));
  border: 1px solid color-mix(in oklab, var(--purple) 40%, var(--border));
  color: color-mix(in oklab, var(--purple) 75%, white);
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
  margin-bottom: 28px;
}
.marquee-badge svg { width: 14px; height: 14px; color: var(--amber); fill: var(--amber); }

.marquee-h2 {
  font-family: var(--font-display);
  font-size: clamp(30px, 4.6vw, 56px);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--text);
  margin: 0 0 24px;
  max-width: 980px;
}
.marquee-h2 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--purple) 0%, var(--rose) 50%, var(--amber) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.marquee-lede {
  font-size: clamp(15.5px, 1.6vw, 18px);
  line-height: 1.65;
  color: var(--text-2);
  margin: 0 0 56px;
  max-width: 820px;
}

.marquee-pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  margin-bottom: 56px;
}
.pillar {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 28px 26px;
  transition: border-color .2s var(--ease-out), transform .2s var(--ease-out);
}
.pillar:hover {
  border-color: color-mix(in oklab, var(--purple) 35%, var(--border));
  transform: translateY(-2px);
}
.pillar-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: color-mix(in oklab, var(--purple) 18%, var(--bg-1));
  color: color-mix(in oklab, var(--purple) 80%, white);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.pillar-icon svg { width: 22px; height: 22px; }
.pillar h4 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}
.pillar p {
  color: var(--text-2);
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

.marquee-pills-block {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.pills-label {
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-3);
  padding-top: 10px;
  min-width: 90px;
}
.pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex: 1;
}
.pill {
  display: inline-flex;
  align-items: center;
  padding: 7px 14px;
  border-radius: 100px;
  font-size: 13.5px;
  font-weight: 500;
  background: var(--bg-1);
  border: 1px solid var(--border);
  color: var(--text);
  transition: border-color .2s var(--ease-out), background .2s var(--ease-out);
}
.pill:hover {
  border-color: color-mix(in oklab, var(--purple) 40%, var(--border));
  background: color-mix(in oklab, var(--purple) 6%, var(--bg-1));
}
.pill-more {
  background: transparent;
  border-style: dashed;
  border-color: color-mix(in oklab, var(--text-3) 30%, var(--border));
  color: var(--text-3);
  font-style: normal;
}

@media (max-width: 720px) {
  .marquee-section { padding: 56px 0 64px; }
  .marquee-lede { margin-bottom: 36px; }
  .marquee-pillars { gap: 14px; margin-bottom: 36px; }
  .pillar { padding: 22px 20px; }
  .marquee-pills-block { gap: 10px; }
  .pills-label { padding-top: 0; min-width: 100%; }
}

/* ===========================================================
   MARQUEE — rose accent variant (used by chat page)
   Overrides the default purple-tinted marquee for data-accent="rose"
   =========================================================== */

.marquee-section[data-accent="rose"] {
  background:
    radial-gradient(ellipse 60% 80% at 15% 0%, color-mix(in oklab, var(--rose) 12%, transparent), transparent 70%),
    radial-gradient(ellipse 60% 80% at 85% 100%, color-mix(in oklab, var(--amber) 8%, transparent), transparent 70%),
    var(--bg-0);
}

.marquee-section[data-accent="rose"] .marquee-badge {
  background: color-mix(in oklab, var(--rose) 14%, var(--bg-1));
  border-color: color-mix(in oklab, var(--rose) 40%, var(--border));
  color: color-mix(in oklab, var(--rose) 75%, white);
}

.marquee-section[data-accent="rose"] .pillar-icon {
  background: color-mix(in oklab, var(--rose) 18%, var(--bg-1));
  color: color-mix(in oklab, var(--rose) 80%, white);
}

.marquee-section[data-accent="rose"] .pillar:hover {
  border-color: color-mix(in oklab, var(--rose) 35%, var(--border));
}

.marquee-section[data-accent="rose"] .pill:hover {
  border-color: color-mix(in oklab, var(--rose) 40%, var(--border));
  background: color-mix(in oklab, var(--rose) 6%, var(--bg-1));
}

.marquee-section[data-accent="rose"] .marquee-lede code,
.marquee-section[data-accent="rose"] .pillar p code {
  background: var(--bg-2);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 12.5px;
  padding: 2px 6px;
  border-radius: 4px;
}

/* ===========================================================
   CODE TABS — used on AI product pages for multi-language samples
   =========================================================== */

.code-tabs {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  margin: 24px 0;
}

.code-tabs-headers {
  display: flex;
  flex-wrap: nowrap;
  gap: 2px;
  padding: 8px;
  background: color-mix(in oklab, var(--bg-2) 80%, var(--bg-0));
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.code-tabs-headers::-webkit-scrollbar { height: 4px; }
.code-tabs-headers::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

.code-tabs-headers button {
  padding: 7px 16px;
  background: transparent;
  border: 0;
  color: var(--text-dim);
  font-family: var(--font-mono);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 6px;
  white-space: nowrap;
  transition: color .15s, background .15s;
  letter-spacing: 0.01em;
}
.code-tabs-headers button:hover {
  color: var(--text);
  background: color-mix(in oklab, var(--bg-0) 50%, transparent);
}
.code-tabs-headers button.active {
  color: var(--text);
  background: var(--bg-0);
  box-shadow: inset 0 -2px 0 var(--rose);
}
.code-tabs[data-accent="purple"] .code-tabs-headers button.active {
  box-shadow: inset 0 -2px 0 var(--purple);
}

.code-tabs-pane {
  display: none;
  padding: 0;
}
.code-tabs-pane.active { display: block; }

.code-tabs-pane pre {
  margin: 0;
  background: var(--bg-0);
  border: 0;
  border-radius: 0;
  padding: 18px 22px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--text);
  overflow-x: auto;
}
.code-tabs-pane pre + pre {
  border-top: 1px dashed var(--border);
}

.code-tabs-pane .code-sub-label {
  padding: 12px 22px 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--rose);
  background: var(--bg-0);
  border-top: 1px dashed var(--border);
}
.code-tabs[data-accent="purple"] .code-tabs-pane .code-sub-label {
  color: var(--purple);
}
.code-tabs-pane .code-sub-label:first-child {
  border-top: 0;
}

/* ===========================================================
   ASTROLOGY DEPTH — capability grid on AI product pages
   =========================================================== */

.depth-section {
  padding: 100px 0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%, color-mix(in oklab, var(--rose) 8%, transparent), transparent 70%),
    var(--bg-0);
}
.depth-section[data-accent="purple"] {
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%, color-mix(in oklab, var(--purple) 8%, transparent), transparent 70%),
    var(--bg-0);
}

.depth-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}
.depth-h2 {
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.15;
  font-weight: 600;
  margin: 14px 0 18px;
  letter-spacing: -0.015em;
}
.depth-h2 em {
  font-style: normal;
  background: linear-gradient(135deg, var(--rose) 0%, var(--amber) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.depth-section[data-accent="purple"] .depth-h2 em {
  background: linear-gradient(135deg, var(--purple) 0%, var(--rose) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.depth-blurb {
  font-size: 16px;
  color: var(--text-dim);
  line-height: 1.65;
}

.depth-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
}
.depth-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 22px 22px 24px;
  transition: border-color .2s;
}
.depth-card:hover {
  border-color: color-mix(in oklab, var(--rose) 35%, var(--border));
}
.depth-section[data-accent="purple"] .depth-card:hover {
  border-color: color-mix(in oklab, var(--purple) 35%, var(--border));
}
.depth-card h4 {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}
.depth-card h4 svg {
  width: 16px;
  height: 16px;
  color: var(--rose);
  flex-shrink: 0;
}
.depth-section[data-accent="purple"] .depth-card h4 svg {
  color: var(--purple);
}
.depth-card p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text-dim);
}
.depth-card code {
  background: var(--bg-2);
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 11.5px;
  padding: 1px 5px;
  border-radius: 3px;
}

/* ===========================================================
   PAYLOAD / RESPONSE SIDE-BY-SIDE CARDS
   =========================================================== */
.io-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
  gap: 20px;
  margin-top: 32px;
}
.io-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.io-card-head {
  padding: 14px 20px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
}
.io-card-head .method {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  background: color-mix(in oklab, var(--rose) 18%, var(--bg-0));
  color: var(--rose);
  letter-spacing: 0.05em;
}
.io-card-head[data-method="GET"] .method {
  background: color-mix(in oklab, var(--green) 18%, var(--bg-0));
  color: var(--green);
}
.io-card-head[data-method="WSS"] .method {
  background: color-mix(in oklab, var(--purple) 18%, var(--bg-0));
  color: var(--purple);
}
.io-card-head .path {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text);
}
.io-card pre {
  margin: 0;
  background: var(--bg-0);
  padding: 18px 20px;
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.55;
  color: var(--text);
  border: 0;
  border-radius: 0;
  overflow-x: auto;
  max-height: 380px;
}
.io-card .io-split {
  display: grid;
  grid-template-columns: 1fr;
}
.io-card .io-split > div + div {
  border-top: 1px solid var(--border);
}
.io-card .io-split h5 {
  margin: 0;
  padding: 10px 20px;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
}

/* ===========================================================
   CODE TABS — multi-language snippet selector
   =========================================================== */
.code-tabs {
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--bg-1);
  margin: 28px 0;
}
.code-tabs__head {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  background: var(--bg-2);
  overflow-x: auto;
  scrollbar-width: thin;
}
.code-tabs__head::-webkit-scrollbar { height: 4px; }
.code-tabs__head::-webkit-scrollbar-thumb { background: var(--border); }
.code-tabs__btn {
  padding: 12px 18px;
  background: transparent;
  border: 0;
  color: var(--text-dim);
  font: 500 12.5px var(--font-mono);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
  user-select: none;
}
.code-tabs__btn:hover { color: var(--text); }
.code-tabs__btn[aria-selected="true"] {
  color: var(--text);
  border-bottom-color: currentColor;
}
.code-tabs[data-accent="rose"]  .code-tabs__btn[aria-selected="true"] { color: var(--rose); }
.code-tabs[data-accent="purple"].code-tabs__btn[aria-selected="true"],
.code-tabs[data-accent="purple"] .code-tabs__btn[aria-selected="true"] { color: var(--purple); }
.code-tabs[data-accent="amber"] .code-tabs__btn[aria-selected="true"] { color: var(--amber); }
.code-tabs__pane {
  display: none;
  margin: 0;
  padding: 18px 20px;
  font: 12.5px/1.7 var(--font-mono);
  color: var(--text);
  background: var(--bg-0);
  overflow-x: auto;
  white-space: pre;
  max-height: 540px;
  width: 100%;
  box-sizing: border-box;
}
.code-tabs__pane[data-active="true"] { display: block; }
.code-tabs__pane code { font: inherit; color: inherit; background: transparent; padding: 0; }

/* Frame protocol grid — two-column outbound/inbound */
.frames-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin: 28px 0;
}
@media (max-width: 768px) { .frames-grid { grid-template-columns: 1fr; } }
.frames-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px 20px;
}
.frames-card h4 {
  margin: 0 0 14px;
  font: 600 11px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.frames-card[data-dir="out"] h4 { color: var(--rose); }
.frames-card[data-dir="in"]  h4 { color: var(--amber); }
.frames-list { list-style: none; padding: 0; margin: 0; }
.frames-list li {
  padding: 8px 0;
  border-top: 1px solid var(--border);
  font: 12px/1.6 var(--font-mono);
}
.frames-list li:first-child { border-top: 0; }
.frames-list strong {
  display: inline-block;
  color: var(--text);
  background: var(--bg-2);
  padding: 1px 6px;
  border-radius: 4px;
  margin-right: 8px;
  font-weight: 600;
}
.frames-list em {
  color: var(--text-dim);
  font-style: normal;
}

/* Astrology offerings — three-column showcase */
.offerings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.offering-card {
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 22px 22px;
  overflow: hidden;       /* belt-and-suspenders: nothing escapes the card */
  min-width: 0;           /* allow flex/grid children to shrink below content width */
}
.offering-card h4 {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  word-break: break-word;
}
.offering-card h4 .glyph {
  display: inline-block;
  width: 26px; height: 26px;
  border-radius: 6px;
  background: var(--bg-2);
  text-align: center;
  line-height: 26px;
  margin-right: 8px;
  font-size: 14px;
}
.offering-card p {
  margin: 0;
  color: var(--text-dim);
  font-size: 13.5px;
  line-height: 1.6;
  overflow-wrap: anywhere;   /* break long words at any character if needed */
}
.offering-card ul {
  margin: 10px 0 0;
  padding-left: 18px;
  color: var(--text-dim);
  font-size: 13px;
  line-height: 1.75;
}
.offering-card ul li { overflow-wrap: anywhere; }
.offering-card code {
  font: 12px var(--font-mono);
  background: color-mix(in srgb, var(--text) 6%, transparent);
  padding: 1px 5px;
  border-radius: 4px;
  word-break: break-all;     /* code strings can break mid-token to fit */
  overflow-wrap: anywhere;
  white-space: normal;       /* allow wrapping inside <code> in cards */
}


/* ===========================================================
   CONTACT FORM
   =========================================================== */
.starsapi-form {
  max-width: 760px;
  margin: 0 auto;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.form-row { display: contents; }
.form-row--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 640px) {
  .form-row--split { grid-template-columns: 1fr; }
  .starsapi-form  { padding: 22px 20px; }
}
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-size: 13px; font-weight: 500; color: var(--text-2); }
.form-label .req { color: var(--rose); margin-left: 2px; }

.starsapi-form input,
.starsapi-form select,
.starsapi-form textarea {
  width: 100%;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 11px 14px;
  font: 14px var(--font-body);
  color: var(--text);
  transition: border-color 0.15s, box-shadow 0.15s;
  color-scheme: dark;     /* tells the browser to render native controls (dropdown popup, etc.) in dark mode */
}
.starsapi-form select option {
  background: var(--bg-1);
  color: var(--text);
  padding: 8px 12px;
}
.starsapi-form select option:disabled,
.starsapi-form select option[value=""] {
  color: var(--text-3);
}
.starsapi-form input:focus,
.starsapi-form select:focus,
.starsapi-form textarea:focus {
  outline: none;
  border-color: var(--rose);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--rose) 18%, transparent);
}
.starsapi-form textarea { resize: vertical; min-height: 120px; line-height: 1.55; }
.starsapi-form select   { cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23808791' d='M1 1l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

/* Honeypot — visually hidden but kept in DOM */
.hp-trap { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }

.form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.form-fineprint {
  margin: 0;
  font-size: 12.5px;
  color: var(--text-3);
  max-width: 440px;
  line-height: 1.55;
}
.form-fineprint a { color: var(--text-2); text-decoration: underline; }
.form-fineprint a:hover { color: var(--rose); }

.btn-spinner { width: 14px; height: 14px; margin-left: 6px; vertical-align: middle; animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.form-status {
  margin: 6px 0 0;
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 13.5px;
  line-height: 1.55;
  display: none;
}
.form-status--ok  {
  display: block;
  background: var(--green-soft);
  color: var(--green);
  border: 1px solid color-mix(in srgb, var(--green) 30%, transparent);
}
.form-status--err {
  display: block;
  background: color-mix(in srgb, var(--rose) 12%, var(--bg-1));
  color: var(--rose);
  border: 1px solid color-mix(in srgb, var(--rose) 30%, transparent);
}


/* ===========================================================
   LEGAL PAGES — Terms, Privacy, Refund
   =========================================================== */
.legal-hero {
  padding: 80px 0 40px;
  text-align: center;
}
.legal-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 600;
  letter-spacing: -.02em;
  margin: 12px 0 8px;
}
.legal-hero .updated {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-3);
  background: var(--bg-1);
  border: 1px solid var(--border);
  padding: 4px 12px;
  border-radius: 999px;
  margin-top: 12px;
}

.legal-body {
  max-width: 780px;
  margin: 0 auto;
  padding: 40px 0 80px;
  color: var(--text-2);
  font-size: 15.5px;
  line-height: 1.75;
}
.legal-body h2 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--text);
  margin: 40px 0 16px;
  letter-spacing: -.01em;
}
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  margin: 28px 0 10px;
}
.legal-body p  { margin: 0 0 14px; }
.legal-body ul, .legal-body ol { margin: 0 0 16px; padding-left: 24px; }
.legal-body li { margin-bottom: 6px; }
.legal-body strong { color: var(--text); }
.legal-body a { color: var(--rose); text-decoration: underline; }
.legal-body a:hover { color: var(--text); }
.legal-body code {
  font: 12.5px var(--font-mono);
  background: var(--bg-1);
  border: 1px solid var(--border);
  padding: 1px 6px;
  border-radius: 4px;
  color: var(--text);
}
.legal-body .callout {
  background: var(--bg-1);
  border-left: 3px solid var(--amber);
  padding: 14px 18px;
  border-radius: 0 8px 8px 0;
  margin: 18px 0;
  font-size: 14px;
  color: var(--text-2);
}
.legal-toc {
  position: sticky;
  top: 100px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px 22px;
  font-size: 13px;
}
.legal-toc h4 {
  font: 600 11px var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
  margin: 0 0 12px;
}
.legal-toc ol { margin: 0; padding-left: 18px; }
.legal-toc li { margin: 6px 0; line-height: 1.5; }
.legal-toc a  { color: var(--text-2); }
.legal-toc a:hover { color: var(--rose); }


/* ============================================================
   === HERO ART :: START ===
   ----------------------------------------------------------
   Decorative SVG illustrations for the AI Voice + AI Chat
   product page heroes. Designed to be cleanly revertible:
   to remove, delete this entire block (until HERO ART :: END)
   AND delete the `<div class="hero-art">…</div>` block at
   the end of the .product-hero > .container in each of:
     products/ai-voice-astrologer.php
     products/ai-chat-astrologer.php
   Nothing else depends on these styles.
   ============================================================ */
.product-hero .container { position: relative; }

.hero-art {
  position: absolute;
  top: 40px;
  right: 0;
  width: 440px;
  height: 440px;
  pointer-events: none;
  color: var(--accent);
  z-index: 0;
}
.hero-art svg {
  width: 100%;
  height: 100%;
  display: block;
}
.product-hero .container > :not(.hero-art) { position: relative; z-index: 1; }

/* Hide on narrow viewports so it never fights the H1 */
@media (max-width: 1180px) { .hero-art { display: none; } }

/* --- Voice art animations --- */
.hero-art[data-art="voice"] .chart-wheel {
  transform-box: fill-box;
  transform-origin: center;
  animation: hero-art-spin 45s linear infinite;
}
.hero-art[data-art="voice"] .ripple {
  transform-box: fill-box;
  transform-origin: center;
  animation: hero-art-ripple 3.6s ease-out infinite;
  opacity: 0;
}
.hero-art[data-art="voice"] .ripple-2 { animation-delay: 1.2s; }
.hero-art[data-art="voice"] .ripple-3 { animation-delay: 2.4s; }

@keyframes hero-art-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes hero-art-ripple {
  0%   { transform: scale(0.25); opacity: 0.55; }
  100% { transform: scale(1.75); opacity: 0; }
}

/* --- Chat art animations --- */
.hero-art[data-art="chat"] .typing-dot {
  transform-box: fill-box;
  transform-origin: center;
  animation: hero-art-typing 1.4s ease-in-out infinite;
}
.hero-art[data-art="chat"] .typing-dot-2 { animation-delay: 0.2s; }
.hero-art[data-art="chat"] .typing-dot-3 { animation-delay: 0.4s; }
.hero-art[data-art="chat"] .chart-wheel-a { transform-box: fill-box; transform-origin: center; animation: hero-art-wobble-a 18s ease-in-out infinite; }
.hero-art[data-art="chat"] .chart-wheel-b { transform-box: fill-box; transform-origin: center; animation: hero-art-wobble-b 18s ease-in-out infinite; }

@keyframes hero-art-typing {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30%           { transform: translateY(-3px); opacity: 1; }
}
@keyframes hero-art-wobble-a {
  0%, 100% { transform: rotate(-3deg); }
  50%      { transform: rotate(3deg); }
}
@keyframes hero-art-wobble-b {
  0%, 100% { transform: rotate(3deg); }
  50%      { transform: rotate(-3deg); }
}

@media (prefers-reduced-motion: reduce) {
  .hero-art *,
  .hero-art [class*="chart-wheel"],
  .hero-art .ripple,
  .hero-art .typing-dot { animation: none !important; }
}
/* === HERO ART :: END === */

/* ============================================================
   /products/ — APIs browse page
   ============================================================ */

/* Compact hero (not full product-hero) */
.apis-hero {
  padding: 64px 0 32px;
  text-align: center;
}
.apis-hero .f-eyebrow {
  display: inline-block;
  color: var(--amber);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.apis-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 48px);
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.1;
  margin: 0 0 16px;
}
.apis-hero h1 em { font-style: normal; color: var(--amber); font-weight: 500; }
.apis-hero .lede {
  font-size: 16px;
  color: var(--text-2);
  line-height: 1.65;
  max-width: 620px;
  margin: 0 auto;
}

/* Shared section heads */
.apis-section-head { text-align: center; max-width: 720px; margin: 0 auto 36px; }
.apis-section-head h2 {
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 600;
  letter-spacing: -.01em;
  margin: 0 0 8px;
}
.apis-section-head p {
  color: var(--text-2);
  font-size: 15px;
  margin: 0;
}

/* USE-CASE PICKER */
.apis-usecases { background: var(--bg-0); }

.apis-usecase-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 980px) {
  .apis-usecase-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .apis-usecase-grid { grid-template-columns: 1fr; }
}

.apis-usecase-card {
  display: flex;
  flex-direction: column;
  padding: 22px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: transform .18s, border-color .18s, background .18s;
  position: relative;
  overflow: hidden;
}
.apis-usecase-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--card-accent, var(--text-3));
  opacity: 0;
  transition: opacity .2s;
}
.apis-usecase-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--card-accent, var(--text-2)) 35%, var(--border));
  background: var(--bg-2);
}
.apis-usecase-card:hover::before { opacity: 1; }

/* Per-accent variables on the card */
.apis-usecase-card.accent-amber   { --card-accent: var(--amber);   }
.apis-usecase-card.accent-purple  { --card-accent: var(--purple);  }
.apis-usecase-card.accent-rose    { --card-accent: var(--rose);    }
.apis-usecase-card.accent-teal    { --card-accent: var(--teal);    }
.apis-usecase-card.accent-blue    { --card-accent: var(--blue);    }
.apis-usecase-card.accent-cyan    { --card-accent: var(--cyan);    }
.apis-usecase-card.accent-orange  { --card-accent: var(--orange);  }
.apis-usecase-card.accent-green   { --card-accent: var(--green);   }

.apis-usecase-eyebrow {
  display: block;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--card-accent, var(--text-2));
  font-weight: 600;
  margin-bottom: 8px;
}
.apis-usecase-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  line-height: 1.35;
  margin: 0 0 10px;
  color: var(--text);
}
.apis-usecase-desc {
  margin: 0 0 14px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.6;
  flex: 1;
}
.apis-usecase-foot {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-size: 12px;
}
.apis-usecase-foot-label {
  color: var(--text-3);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 10.5px;
  margin-right: 2px;
}
.apis-usecase-foot-product {
  color: var(--card-accent, var(--text-2));
  font-weight: 600;
}
.apis-usecase-foot-plus {
  color: var(--text-3);
  font-weight: 600;
  margin: 0 1px;
}

/* CATEGORIES */
.apis-categories { background: var(--bg-1); padding-top: 64px; padding-bottom: 64px; }

.apis-category { margin-bottom: 44px; }
.apis-category:last-child { margin-bottom: 0; }

.apis-category-head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.apis-category-head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--text);
}
.apis-category-kicker {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: .04em;
}
.apis-category-count {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
}

.apis-category-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 980px) { .apis-category-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 540px) { .apis-category-grid { grid-template-columns: 1fr; } }

.apis-cat-card {
  display: block;
  padding: 18px;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: transform .18s, border-color .18s, background .18s;
  position: relative;
  overflow: hidden;
}
.apis-cat-card:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--cat-accent, var(--text-2)) 35%, var(--border));
  background: var(--bg-2);
}
.apis-cat-card.accent-amber   { --cat-accent: var(--amber);   }
.apis-cat-card.accent-purple  { --cat-accent: var(--purple);  }
.apis-cat-card.accent-rose    { --cat-accent: var(--rose);    }
.apis-cat-card.accent-teal    { --cat-accent: var(--teal);    }
.apis-cat-card.accent-blue    { --cat-accent: var(--blue);    }
.apis-cat-card.accent-cyan    { --cat-accent: var(--cyan);    }
.apis-cat-card.accent-orange  { --cat-accent: var(--orange);  }
.apis-cat-card.accent-green   { --cat-accent: var(--green);   }

.apis-cat-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.apis-cat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 9px;
  background: color-mix(in srgb, var(--cat-accent) 16%, transparent);
  color: var(--cat-accent);
  flex-shrink: 0;
}
.apis-cat-icon svg { width: 18px; height: 18px; }
.apis-cat-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.apis-cat-badge {
  font-size: 10px;
  color: var(--cat-accent);
  background: color-mix(in srgb, var(--cat-accent) 16%, transparent);
  padding: 3px 8px;
  border-radius: 999px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.apis-cat-meta {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  letter-spacing: .08em;
  margin-bottom: 8px;
}
.apis-cat-desc {
  margin: 0 0 12px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.5;
}
.apis-cat-link {
  color: var(--cat-accent);
  font-size: 12.5px;
  font-weight: 600;
}


/* ============================================================
   /products/location-api — demo, integration, migration guide
   ============================================================ */

/* DEMO */
.loc-demo {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 24px;
  max-width: 1080px;
  margin: 0 auto;
  align-items: start;
}
@media (max-width: 820px) {
  .loc-demo { grid-template-columns: 1fr; }
}

.loc-demo-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
}
.loc-demo-inputwrap { position: relative; }
.loc-demo-inputwrap input {
  width: 100%;
  padding: 14px 16px;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  font: 15px var(--font-body);
  color-scheme: dark;
  transition: border-color .15s, box-shadow .15s;
}
.loc-demo-inputwrap input:focus {
  outline: none;
  border-color: var(--green);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 18%, transparent);
}
.loc-demo-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0; right: 0;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  max-height: 260px;
  overflow: auto;
  z-index: 10;
  list-style: none;
  margin: 0; padding: 6px;
  font-size: 14px;
}
.loc-demo-results li {
  padding: 10px 12px;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  transition: background .12s;
}
.loc-demo-results li:hover { background: color-mix(in srgb, var(--green) 12%, transparent); color: var(--text); }
.loc-demo-id { font-family: var(--font-mono); font-size: 11px; color: var(--text-3); }
.loc-demo-noresult { padding: 12px; color: var(--text-3); font-size: 13px; cursor: default; }
.loc-demo-noresult:hover { background: transparent; }

.loc-demo-output {
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.loc-demo-output-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
}
.loc-demo-output-title {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-3);
}
.loc-demo-output-status {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
}
.loc-demo-output-status.is-ok { color: var(--green); }
.loc-demo-pre {
  margin: 0;
  padding: 16px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--text);
  overflow-x: auto;
  white-space: pre;
  min-height: 200px;
}
.loc-demo-foot {
  max-width: 1080px;
  margin: 24px auto 0;
  color: var(--text-3);
  font-size: 13px;
  text-align: center;
}
.loc-demo-foot code { font-family: var(--font-mono); font-size: 12px; background: var(--bg-2); padding: 2px 6px; border-radius: 4px; }

/* STEPS */
.loc-step {
  max-width: 1080px;
  margin: 0 auto 40px;
  padding: 26px;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 14px;
}
.loc-step-head {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.loc-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--green-soft);
  color: var(--green);
  font-weight: 700;
  font-family: var(--font-mono);
  font-size: 14px;
  flex-shrink: 0;
}
.loc-step-head h3 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
}
.loc-step-method {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--text-2);
  font-family: var(--font-mono);
}
.loc-step-method .method {
  background: var(--green-soft);
  color: var(--green);
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 600;
  font-size: 10.5px;
  letter-spacing: .04em;
}
.loc-step-method code {
  background: var(--bg-0);
  padding: 3px 7px;
  border-radius: 4px;
  font-size: 11.5px;
  color: var(--text-2);
}
.loc-step-desc {
  margin: 0 0 18px;
  color: var(--text-2);
  font-size: 14.5px;
  line-height: 1.65;
}
.loc-step-desc code { font-family: var(--font-mono); font-size: 12.5px; background: var(--bg-0); padding: 2px 6px; border-radius: 4px; color: var(--text); }
.loc-step-note {
  margin: 16px 0 0;
  padding: 12px 16px;
  background: var(--bg-0);
  border-left: 3px solid var(--green);
  border-radius: 0 6px 6px 0;
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.65;
}
.loc-step-note strong { color: var(--text); }
.loc-step-note code { font-family: var(--font-mono); font-size: 12px; background: var(--bg-1); padding: 2px 6px; border-radius: 4px; color: var(--green); }

.loc-codepair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 720px) { .loc-codepair { grid-template-columns: 1fr; } }

.loc-code-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
}
.loc-code {
  margin: 0;
  padding: 14px 16px;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--text);
  overflow-x: auto;
  white-space: pre;
}
.loc-code code { background: transparent; padding: 0; color: inherit; }

.loc-clients-h {
  max-width: 1080px;
  margin: 50px auto 8px;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  color: var(--text);
}
.loc-clients-blurb {
  max-width: 1080px;
  margin: 0 auto 18px;
  color: var(--text-2);
  font-size: 14.5px;
}

/* MIGRATION GUIDE */
.loc-mig-h {
  max-width: 1080px;
  margin: 36px auto 14px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
}
.loc-mig-table {
  max-width: 1080px;
  margin: 0 auto 20px;
  overflow-x: auto;
}
.loc-mig-table table {
  width: 100%;
  border-collapse: collapse;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  font-size: 14px;
}
.loc-mig-table th,
.loc-mig-table td {
  padding: 13px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.loc-mig-table th {
  background: var(--bg-2);
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: .04em;
  color: var(--text-2);
}
.loc-mig-table tr:last-child td { border-bottom: none; }
.loc-mig-table td code {
  font-family: var(--font-mono);
  font-size: 12px;
  background: var(--bg-2);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--text);
}
.loc-mig-table td strong { color: var(--green); }
.loc-mig-note {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  margin-left: 4px;
}
.loc-mig-caveat {
  max-width: 1080px;
  margin: 8px auto 0;
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.6;
}
.loc-mig-caveat a { color: var(--green); text-decoration: underline; }

.loc-mig-swap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  max-width: 1080px;
  margin: 0 auto 36px;
}
@media (max-width: 880px) { .loc-mig-swap { grid-template-columns: 1fr; } }
.loc-mig-side { background: var(--bg-0); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.loc-mig-side-head {
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
}
.loc-mig-side-head--out { background: color-mix(in srgb, var(--rose) 10%, var(--bg-2)); color: var(--rose); }
.loc-mig-side-head--in  { background: color-mix(in srgb, var(--green) 10%, var(--bg-2)); color: var(--green); }
.loc-mig-side .loc-code {
  border: none;
  border-radius: 0;
  background: transparent;
}

.loc-mig-steps {
  max-width: 1080px;
  margin: 0 auto 16px;
  padding-left: 24px;
  color: var(--text-2);
  font-size: 14.5px;
  line-height: 1.8;
}
.loc-mig-steps li { margin-bottom: 8px; }
.loc-mig-steps strong { color: var(--text); }
.loc-mig-steps code {
  font-family: var(--font-mono);
  font-size: 12.5px;
  background: var(--bg-0);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--green);
}
.loc-mig-steps a { color: var(--green); }


/* Location fields-purpose table */
.loc-fields-table {
  margin: 18px 0 0;
  overflow-x: auto;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.loc-fields-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.loc-fields-table th,
.loc-fields-table td {
  padding: 11px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.loc-fields-table th {
  background: var(--bg-2);
  font-weight: 600;
  font-size: 12px;
  color: var(--text-2);
  letter-spacing: .04em;
}
.loc-fields-table tr:last-child td { border-bottom: none; }
.loc-fields-table td code {
  font-family: var(--font-mono);
  font-size: 12.5px;
  background: var(--bg-2);
  padding: 2px 7px;
  border-radius: 4px;
  color: var(--text);
  display: inline-block;
  margin: 1px 0;
}
.loc-fields-table tr.loc-fields-required td { background: color-mix(in srgb, var(--green) 6%, transparent); }
.loc-fields-table tr.loc-fields-required td:first-child { border-left: 3px solid var(--green); padding-left: 11px; }
.loc-fields-table tr.loc-fields-required td code {
  background: color-mix(in srgb, var(--green) 18%, var(--bg-2));
  color: var(--green);
  font-weight: 600;
}
.loc-fields-table td strong { color: var(--green); }
.loc-fields-table td em { color: var(--text); font-style: italic; }


/* Location "Why use it" — heading block matches feature-grid width below */
.loc-why-head {
  margin: 0 0 36px;
}

/* Location page — page-scoped accent override.
   Default .section-head h2 em is amber across the site; on this page,
   all heading <em> tags use the page's green accent. */
[data-page="location"] .section-head h2 em,
[data-page="location"] .loc-why-head h2 em,
[data-page="location"] .product-hero h1 em {
  font-style: normal;
  color: var(--green) !important;
  font-weight: 500;
  -webkit-text-fill-color: var(--green); /* defeats any gradient from light-mode */
  background: none !important;
}


/* ============================================================
   Code picker — dropdown variant of code-tabs
   Used on /products/location-api for client snippets
   ============================================================ */
.code-picker {
  max-width: 1080px;
  margin: 28px auto;
  background: var(--bg-1);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.code-picker__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
}
.code-picker__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-3);
}
.code-picker__menu { position: relative; }
.code-picker__trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 220px;
  padding: 7px 10px 7px 14px;
  background: var(--bg-0);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  font: 500 13px var(--font-mono);
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
  text-align: left;
}
.code-picker__trigger:hover { border-color: color-mix(in srgb, var(--green) 40%, var(--border)); }
.code-picker__trigger[aria-expanded="true"] {
  border-color: var(--green);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green) 18%, transparent);
}
.code-picker__current { flex: 1; }
.code-picker__trigger svg {
  width: 14px;
  height: 14px;
  color: var(--green);
  transition: transform .18s;
}
.code-picker__trigger[aria-expanded="true"] svg { transform: rotate(180deg); }

.code-picker__list {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  margin: 0; padding: 4px;
  list-style: none;
  background: var(--bg-0);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
  z-index: 50;
}
.code-picker__list li {
  padding: 10px 14px;
  border-radius: 5px;
  cursor: pointer;
  color: var(--text);
  font: 500 13px var(--font-mono);
  transition: background .12s, color .12s;
}
.code-picker__list li:hover {
  background: color-mix(in srgb, var(--green) 12%, transparent);
  color: var(--text);
}
.code-picker__list li.is-selected {
  background: color-mix(in srgb, var(--green) 18%, transparent);
  color: var(--green);
}
.code-picker__pane {
  display: none;
  margin: 0;
  padding: 18px 20px;
  font: 12.5px/1.7 var(--font-mono);
  color: var(--text);
  background: var(--bg-0);
  overflow-x: auto;
  white-space: pre;
  max-height: 540px;
  width: 100%;
  box-sizing: border-box;
}
.code-picker__pane[data-active="true"] { display: block; }
.code-picker__pane code { font: inherit; color: inherit; background: transparent; padding: 0; }

