/* Shared styles for sub-pages (terms, privacy, about, careers) */
/* Fonts loaded via <link> tags in HTML for non-blocking rendering */

:root {
  --brand-50:#eef3ff; --brand-100:#dde7ff; --brand-200:#bfd0ff; --brand-300:#95b0ff;
  --brand-400:#6a87fb; --brand-500:#4361ee; --brand-600:#3548d4; --brand-700:#2a39ad;
  --brand-800:#24308a; --brand-900:#1e2870;

  --slate-0:#ffffff; --slate-50:#fafafa; --slate-100:#f4f5f7; --slate-200:#e7e9ee;
  --slate-300:#d1d5db; --slate-400:#9ca3af; --slate-500:#6b7280; --slate-600:#4b5563;
  --slate-700:#374151; --slate-800:#1f2937; --slate-900:#111827; --slate-950:#0a0d14;

  --bg: #ffffff;
  --fg: #111827; --fg-muted: #4b5563; --fg-subtle: #6b7280;
  --border: #e7e9ee; --border-strong: #d1d5db;

  --font-sans: 'Geist','Inter',system-ui,-apple-system,sans-serif;
  --font-mono: 'Geist Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--fg);
  font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--brand-200); color: var(--brand-900); }

/* ── top nav ─────────────────────────────────────── */
.topnav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.82); backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--border);
}
.topnav-inner {
  max-width: 1240px; margin: 0 auto; padding: 16px 24px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.topnav-brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; letter-spacing: -0.015em; font-size: 17px; }
.topnav-brand svg { display: block; }
.topnav-links { display: flex; align-items: center; gap: 24px; font-size: 14px; color: var(--fg-muted); }
.topnav-links a { transition: color 120ms; }
.topnav-links a:hover { color: var(--fg); }
.topnav-cta {
  display: inline-flex; align-items: center; gap: 8px; height: 38px; padding: 0 16px;
  background: var(--slate-950); color: #fff; border-radius: 9999px; font-size: 13px; font-weight: 500;
  transition: transform 120ms, background 120ms;
}
.topnav-cta:hover { transform: translateY(-1px); }
@media (max-width: 720px) { .topnav-links a:not(.topnav-cta) { display: none; } }

/* ── page hero ───────────────────────────────────── */
.page-hero {
  padding: 96px 24px 64px; max-width: 1240px; margin: 0 auto;
  border-bottom: 1px solid var(--border);
}
.page-hero .eyebrow {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em;
  color: var(--fg-subtle); text-transform: uppercase; margin-bottom: 16px;
}
.page-hero h1 {
  font-size: clamp(44px, 6vw, 76px); font-weight: 600; letter-spacing: -0.045em;
  line-height: 1.02; margin: 0 0 20px; text-wrap: balance;
}
.page-hero .lede {
  font-size: 18px; color: var(--fg-muted); line-height: 1.55; max-width: 640px; margin: 0;
}
.page-hero .updated { margin-top: 24px; font-size: 13px; color: var(--fg-subtle); font-family: var(--font-mono); }

/* ── content layout (legal pages) ────────────────── */
.legal-layout {
  max-width: 1240px; margin: 0 auto; padding: 64px 24px 120px;
  display: grid; grid-template-columns: 260px 1fr; gap: 64px;
}
@media (max-width: 960px) { .legal-layout { grid-template-columns: 1fr; gap: 32px; } }

.toc {
  position: sticky; top: 96px; align-self: start;
  font-size: 13px; line-height: 1.55;
  max-height: calc(100vh - 120px); overflow-y: auto;
}
.toc-title {
  font-size: 11px; font-family: var(--font-mono); letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-subtle); margin-bottom: 16px;
}
.toc ol { list-style: none; padding: 0; margin: 0; counter-reset: tocnum; }
.toc li { counter-increment: tocnum; }
.toc a {
  display: flex; gap: 12px; padding: 7px 0; color: var(--fg-muted);
  border-bottom: 1px solid transparent; transition: color 120ms;
}
.toc a:before {
  content: counter(tocnum, decimal-leading-zero);
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-subtle); flex-shrink: 0;
}
.toc a:hover { color: var(--fg); }
@media (max-width: 960px) { .toc { position: static; max-height: none; } }

.legal-body { max-width: 760px; font-size: 16px; line-height: 1.7; color: var(--fg); }
.legal-body h2 {
  font-size: 32px; font-weight: 600; letter-spacing: -0.025em; line-height: 1.15;
  margin: 80px 0 20px; padding-top: 32px; border-top: 1px solid var(--border);
  counter-reset: sub;
}
.legal-body h2:first-child { margin-top: 0; border-top: 0; padding-top: 0; }
.legal-body h2 .num {
  display: block; font-family: var(--font-mono); font-size: 12px; color: var(--fg-subtle);
  letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; font-weight: 500;
}
.legal-body h3 {
  font-size: 19px; font-weight: 600; letter-spacing: -0.01em;
  margin: 40px 0 12px; color: var(--fg);
}
.legal-body p { margin: 0 0 16px; color: var(--fg-muted); }
.legal-body ul { margin: 0 0 20px; padding-left: 0; list-style: none; }
.legal-body li {
  position: relative; padding-left: 22px; margin-bottom: 8px; color: var(--fg-muted);
}
.legal-body li:before {
  content: ''; position: absolute; left: 4px; top: 12px;
  width: 6px; height: 1px; background: var(--border-strong);
}
.legal-body strong { color: var(--fg); font-weight: 600; }
.legal-body .callout {
  padding: 18px 22px; background: var(--slate-50); border: 1px solid var(--border);
  border-radius: 12px; margin: 24px 0; font-size: 14px; color: var(--fg-muted);
}
.legal-body .callout-all-caps {
  background: #fef9ef; border-color: #fde68a;
}

/* ── footer (shared minimal) ─────────────────────── */
.page-footer { border-top: 1px solid var(--border); padding: 48px 24px 40px; }
.page-footer-inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
  font-size: 13px; color: var(--fg-subtle); font-family: var(--font-mono);
}
.page-footer-inner a { color: var(--fg-muted); transition: color 120ms; }
.page-footer-inner a:hover { color: var(--fg); }
.page-footer-inner .dot { width: 6px; height: 6px; border-radius: 50%; background: #10b981; display: inline-block; margin-right: 6px; }

/* ── reveal ──────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 700ms cubic-bezier(.16,1,.3,1), transform 700ms cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }
