/* ═══════════════════════════════════════════════════════════════════════════
   FactiveLabs v2 design system. Light mode, Vercel-flavor.
   All public pages use this exclusively (no api.css link).
   Dashboard and admin keep their legacy markup; this file overrides their
   COLORS, TYPOGRAPHY, BORDERS via api-dash-* / api-* class targeting so the
   nav and content surfaces visually match the new system. Layout (display,
   grid, position) is left to inline styles / existing rules so JS-driven
   tabs and tables don't break.
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
  --bg: #fafaf7; --bg-card: #ffffff; --bg-sunken: #f4f3ef;
  --bg-code: #0a0a0a; --bg-code-fg: #ededed;
  --border: #e8e6e0; --border-strong: #d6d3cc; --border-hover: #0f6e4d;
  --text: #0a0a0a; --text-soft: #3d3a35; --text-dim: #6c6a64; --text-mute: #9c9890;
  --brand: #0f6e4d; --brand-strong: #095c40; --brand-soft: #e6f3ed; --brand-fg-on: #ffffff;
  --confirmed: #047857; --disputed: #b91c1c; --unclear: #b45309; --skipped: #6b7280;
  --font-sans: 'Geist', 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'Geist Mono', 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:20px; --s-6:24px;
  --s-8:32px; --s-10:40px; --s-12:48px; --s-16:64px; --s-20:80px; --s-24:96px;
  --r-sm:4px; --r-md:6px; --r-lg:10px; --r-xl:14px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 2px 8px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 32px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.04);
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out-back: cubic-bezier(0.34, 1.16, 0.64, 1);
  --dur-fast: 120ms; --dur: 180ms; --dur-slow: 280ms;
  --container: 1180px; --container-narrow: 880px;

  /* Aliases so JS-injected playground styles (--api-*) still resolve. */
  --api-text-dim: var(--text-mute);
  --api-text-muted: var(--text-dim);
  --api-green: var(--brand);
  --api-red: var(--disputed);
  --api-primary: var(--brand);
  --api-border: var(--border);
  --api-surface: var(--bg-card);
  --api-code-bg: var(--bg-sunken);
  --api-mono: var(--font-mono);
  --api-muted: var(--text-mute);
  --api-text: var(--text);
  --api-bg: var(--bg);
  --api-accent: var(--brand);
  --api-accent-light: var(--brand);
  --api-accent-hover: var(--brand-strong);
  --api-accent-dim: var(--brand-soft);
  --api-orange: var(--unclear);
  --api-radius: var(--r-lg);
  --api-radius-sm: var(--r-md);
  --api-font: var(--font-sans);
  --api-heading: var(--font-sans);
  --api-logo: var(--font-sans);
  --api-max-width: var(--container);
  --api-nav-height: 56px;
  --api-border-light: var(--border);
  --api-surface-2: var(--bg-sunken);
  --api-green-dim: var(--brand-strong);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body, body.api-page {
  font-family: var(--font-sans); background: var(--bg); color: var(--text);
  line-height: 1.5; letter-spacing: -0.005em; min-height: 100vh;
}
a { color: inherit; text-decoration: none; }

/* Typography */
h1,h2,h3 { font-weight: 600; letter-spacing: -0.025em; line-height: 1.1; color: var(--text); }
h1 { font-size: clamp(40px, 6vw, 64px); letter-spacing: -0.04em; line-height: 1.04; }
h2 { font-size: clamp(28px, 3.6vw, 40px); letter-spacing: -0.03em; }
h3 { font-size: 17px; letter-spacing: -0.01em; line-height: 1.3; }
p  { color: var(--text-soft); font-size: 15px; line-height: 1.65; }
.mono { font-family: var(--font-mono); font-feature-settings: 'liga' 0; }

/* Layout */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6); }
.container-narrow { width: 100%; max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--s-6); }
section { padding: var(--s-24) 0; border-top: 1px solid var(--border); }
section.no-border { border-top: none; }

.eyebrow { display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-dim); font-weight: 500; }
.eyebrow::before { content:""; width: 14px; height: 1px; background: currentColor; opacity: 0.5; }
.section-head { display: flex; flex-direction: column; gap: var(--s-4); margin-bottom: var(--s-12); max-width: 820px; }
.section-head p { font-size: 16px; color: var(--text-dim); max-width: 60ch; }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  height: 40px; padding: 0 var(--s-5);
  font-family: var(--font-sans); font-size: 14px; font-weight: 500; letter-spacing: -0.005em;
  border-radius: var(--r-md); border: 1px solid transparent; cursor: pointer;
  transition: all var(--dur) var(--ease); white-space: nowrap; user-select: none; }
.btn-primary   { background: var(--text); color: #fff; border-color: var(--text); }
.btn-primary:hover { background: #1a1a1a; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-secondary { background: var(--bg-card); color: var(--text); border-color: var(--border-strong); }
.btn-secondary:hover { border-color: var(--text); background: #fff; }
.btn-ghost     { background: transparent; color: var(--text); }
.btn-ghost:hover { background: var(--bg-sunken); }
.btn-lg { height: 44px; padding: 0 var(--s-6); font-size: 14px; }
.btn-sm { height: 32px; padding: 0 var(--s-4); font-size: 13px; }
.btn-arrow svg { transition: transform var(--dur) var(--ease); }
.btn-arrow:hover svg { transform: translateX(2px); }

/* Nav (new v2) */
.nav { position: sticky; top: 0; z-index: 50;
  background: rgba(250, 250, 247, 0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border); }
.nav-inner { max-width: var(--container); margin: 0 auto; height: 56px;
  display: flex; align-items: center; justify-content: space-between; padding: 0 var(--s-6); }
.logo { display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-sans); font-size: 18px; font-weight: 600; letter-spacing: -0.02em; }
.logo-name span { color: var(--text-dim); font-weight: 500; }
.nav-links { display: flex; align-items: center; gap: var(--s-1); }
.nav-link { font-size: 13.5px; color: var(--text-dim);
  padding: var(--s-2) var(--s-3); border-radius: var(--r-sm);
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease); }
.nav-link:hover { color: var(--text); background: var(--bg-sunken); }
.nav-link.active { color: var(--text); }
.nav-right { display: flex; align-items: center; gap: var(--s-3); }
.nav-toggle { display: none; background: transparent; border: none; padding: var(--s-2); color: var(--text); cursor: pointer; }

/* Mobile menu */
.mobile-menu { display: none; }
@media (max-width: 900px) {
  .nav-links { display: none; }
  .nav-toggle { display: inline-flex; }
  .mobile-menu { display: none; flex-direction: column; gap: var(--s-2);
    border-bottom: 1px solid var(--border); padding: var(--s-4) var(--s-6); background: var(--bg-card); }
  .mobile-menu.open { display: flex; }
  .mobile-menu a { padding: var(--s-2) 0; font-size: 14px; color: var(--text-dim); }
  .mobile-menu a:hover { color: var(--text); }
  .mobile-menu .divider { height: 1px; background: var(--border); margin: var(--s-2) 0; }
}

/* Footer */
.footer { border-top: 1px solid var(--border); padding: var(--s-10) 0 var(--s-12); background: var(--bg); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--s-4); }
.footer-meta { font-family: var(--font-mono); font-size: 12px; color: var(--text-mute); }
.footer-links { display: flex; gap: var(--s-6); }
.footer-links a { font-size: 13px; color: var(--text-dim); transition: color var(--dur) var(--ease); }
.footer-links a:hover { color: var(--text); }

/* Cards */
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
@media (max-width: 880px) { .card-grid { grid-template-columns: 1fr; } }
.card { position: relative; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-6); transition: all var(--dur) var(--ease); }
.card:hover { border-color: var(--border-hover); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.card-icon { width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--r-sm); background: var(--brand-soft); margin-bottom: var(--s-4); }
.card-icon svg { width: 18px; height: 18px; stroke: var(--brand); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.card h3 { margin-bottom: var(--s-2); }
.card p { font-size: 14px; color: var(--text-dim); line-height: 1.6; }
.card code, code.inline { display: inline-block; font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-sunken); padding: 2px 6px; border-radius: var(--r-sm); color: var(--text); border: 1px solid var(--border); }
.card-foot { margin-top: var(--s-5); padding-top: var(--s-4); border-top: 1px solid var(--border); }
.card-foot code { font-size: 12.5px; padding: 4px 8px; }

/* FAQ accordion */
.faq { border-top: 1px solid var(--border); }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-summary { display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-6) 0; font-size: 16px; font-weight: 500; color: var(--text);
  cursor: pointer; list-style: none; transition: color var(--dur) var(--ease); }
.faq-summary::-webkit-details-marker { display: none; }
.faq-summary:hover { color: var(--brand); }
.faq-summary::after { content:""; width: 14px; height: 14px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round'%3E%3Cline x1='12' y1='5' x2='12' y2='19'/%3E%3Cline x1='5' y1='12' x2='19' y2='12'/%3E%3C/svg%3E");
  background-size: contain; transition: transform var(--dur) var(--ease); }
.faq-item[open] .faq-summary::after { transform: rotate(45deg); }
.faq-body { padding: 0 0 var(--s-6); }
.faq-body p { font-size: 14.5px; color: var(--text-dim); max-width: 70ch; line-height: 1.65; }
.faq-body code { font-family: var(--font-mono); font-size: 12.5px;
  background: var(--bg-sunken); padding: 1px 6px; border-radius: var(--r-sm); border: 1px solid var(--border); }
.faq-body a { color: var(--brand); border-bottom: 1px solid currentColor; }

/* Code panel (dark) */
.code-panel { background: var(--bg-code); color: var(--bg-code-fg); min-width: 0; max-width: 100%;
  border-radius: var(--r-lg); border: 1px solid #1f1f1f;
  box-shadow: var(--shadow-lg); overflow: hidden;
  font-family: var(--font-mono); font-size: 13px; line-height: 1.65; }
.code-tabs { display: flex; align-items: center; padding: 0 var(--s-2);
  border-bottom: 1px solid #1f1f1f; background: #0f0f0f; }
.code-tab { background: transparent; border: none; color: #8a8a8a;
  font-family: var(--font-mono); font-size: 12px; padding: var(--s-3) var(--s-4);
  cursor: pointer; position: relative; transition: color var(--dur) var(--ease); }
.code-tab.active { color: #ededed; }
.code-tab.active::after { content:""; position: absolute; bottom: -1px;
  left: var(--s-3); right: var(--s-3); height: 1px; background: var(--brand); }
.code-tab:hover { color: #ededed; }
.code-body { padding: var(--s-5) var(--s-6); overflow-x: auto; height: 384px; }
.code-body pre { white-space: pre; }
.tk-keyword { color: #c084fc; }
.tk-string  { color: #86efac; }
.tk-fn      { color: #93c5fd; }
.tk-comment { color: #6b7280; font-style: italic; }
.tk-num     { color: #fbbf24; }

/* Tables */
.tbl { width: 100%; border-collapse: separate; border-spacing: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; font-size: 14px; }
.tbl th { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--text-mute);
  text-align: left; padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border); background: var(--bg-sunken); font-weight: 500; }
.tbl td { padding: var(--s-4) var(--s-5); border-bottom: 1px solid var(--border); color: var(--text-soft); }
.tbl tr:last-child td { border-bottom: none; }
.tbl tr.featured td { background: var(--brand-soft); }
.tbl tr.featured td strong { color: var(--brand); }
.tbl tr:hover td { background: var(--bg-sunken); }
.tbl td strong { color: var(--text); font-weight: 600; }

/* Form fields */
.field { display: flex; flex-direction: column; gap: var(--s-2); margin-bottom: var(--s-5); }
.field-label { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-dim); font-weight: 500; }
.field-input, .field-select, .field-textarea { width: 100%;
  font-family: var(--font-sans); font-size: 14px; color: var(--text);
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: var(--r-md); padding: var(--s-3) var(--s-4);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.field-input:focus, .field-select:focus, .field-textarea:focus {
  outline: none; border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(15, 110, 77, 0.12); }
.field-textarea { min-height: 140px; resize: vertical; font-family: var(--font-mono); font-size: 13px; line-height: 1.55; }
.field-input.mono { font-family: var(--font-mono); font-size: 13px; }
.field-hint { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); margin-top: var(--s-1); }

/* Auth card */
.auth-wrap { min-height: calc(100vh - 200px);
  display: flex; align-items: center; justify-content: center; padding: var(--s-12) var(--s-6); }
.auth-card { width: 100%; max-width: 420px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-10);
  box-shadow: var(--shadow-md); }
.auth-head { margin-bottom: var(--s-8); }
.auth-head h1 { font-size: 24px; letter-spacing: -0.02em; line-height: 1.2; margin-bottom: var(--s-2); }
.auth-head p  { font-size: 14px; color: var(--text-dim); }
.auth-oauth { width: 100%; display: inline-flex; align-items: center; justify-content: center;
  gap: var(--s-3); height: 44px; padding: 0 var(--s-5);
  background: var(--bg-card); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: var(--r-md);
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  transition: all var(--dur) var(--ease); cursor: pointer; }
.auth-oauth:hover { border-color: var(--text); background: #fff; box-shadow: var(--shadow-sm); }
.auth-error { background: #fef2f2; border: 1px solid #fecaca; color: #991b1b;
  padding: var(--s-3) var(--s-4); border-radius: var(--r-md);
  font-size: 13.5px; margin-bottom: var(--s-5); }
.auth-dev { margin-top: var(--s-5); padding-top: var(--s-5); border-top: 1px solid var(--border); }
.auth-dev p { font-size: 12px; color: var(--text-mute); margin-bottom: var(--s-3); text-align: center;
  font-family: var(--font-mono); letter-spacing: 0.04em; }
.auth-terms { font-size: 12.5px; color: var(--text-mute); text-align: center; margin-top: var(--s-5); line-height: 1.5; }
.auth-terms a { color: var(--text-dim); border-bottom: 1px solid currentColor; }
.auth-foot { margin-top: var(--s-6); padding-top: var(--s-6);
  border-top: 1px solid var(--border);
  font-size: 13.5px; color: var(--text-dim); text-align: center; }
.auth-foot a { color: var(--brand); border-bottom: 1px solid currentColor; }

/* Playground layout */
.pg-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5);
  padding: var(--s-12) 0; }
@media (max-width: 1000px) { .pg-layout { grid-template-columns: 1fr; } }
.pg-panel { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
  display: flex; flex-direction: column; min-height: 580px; }
.pg-panel-head { padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border); background: var(--bg-sunken);
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); }
.pg-panel-body { padding: var(--s-6); flex: 1; }
.pg-actions { display: flex; gap: var(--s-3); margin-top: var(--s-4); padding-top: var(--s-5); border-top: 1px solid var(--border); }
.pg-result { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.55;
  white-space: pre-wrap; color: var(--text-soft); }
.pg-result.placeholder { display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; height: 100%; color: var(--text-dim); gap: var(--s-3); font-family: var(--font-sans); }
.pg-result.placeholder .ph-icon { font-size: 28px; opacity: 0.6; }
.pg-result.placeholder strong { color: var(--text); font-weight: 600; }

/* Streaming UI for playground */
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.stream-live { display: flex; flex-direction: column; gap: 16px; height: 100%; }
.stream-status { display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-dim);
  padding: var(--s-2) var(--s-3); background: var(--bg-sunken);
  border-radius: var(--r-sm); border: 1px solid var(--border);
  font-family: var(--font-mono); }
.stream-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text-mute); display: inline-block; }
.stream-dot.active { background: var(--brand); animation: pulse 1.5s ease-in-out infinite; }
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
.stream-events { display: flex; flex-direction: column; gap: 4px;
  max-height: 120px; overflow-y: auto;
  font-size: 12px; color: var(--text-dim); padding: var(--s-2) 0;
  font-family: var(--font-mono); }
.stream-event { padding: 2px 0; }
.stream-event-error { color: var(--disputed); }
.stream-event-complete { color: var(--brand); font-weight: 500; }
.stream-claims { display: flex; flex-direction: column; gap: var(--s-3); flex: 1; overflow-y: auto; }
.stream-claim { padding: var(--s-3) var(--s-4); border-radius: var(--r-md);
  border: 1px solid var(--border); background: var(--bg-card); transition: border-color 0.3s; }
.stream-claim.true { border-left: 3px solid var(--confirmed); }
.stream-claim.false { border-left: 3px solid var(--disputed); }
.stream-claim.mixed { border-left: 3px solid var(--unclear); }
.stream-claim.unverifiable { border-left: 3px solid var(--skipped); }
.stream-claim.pending { border-left: 3px solid var(--text-mute); opacity: 0.7; }
.stream-claim-text { font-size: 13px; color: var(--text-soft); line-height: 1.5; margin-bottom: 6px; }
.stream-claim-verdict { display: flex; align-items: center; gap: 8px; }
.verdict-badge { font-size: 10.5px; font-weight: 600; text-transform: uppercase;
  padding: 2px 8px; border-radius: 4px; letter-spacing: 0.06em;
  font-family: var(--font-mono); }
.verdict-badge.true { background: rgba(4,120,87,0.12); color: var(--confirmed); }
.verdict-badge.false { background: rgba(185,28,28,0.12); color: var(--disputed); }
.verdict-badge.mixed { background: rgba(180,83,9,0.12); color: var(--unclear); }
.verdict-badge.unverifiable { background: rgba(107,114,128,0.12); color: var(--skipped); }
.verdict-badge.pending, .verdict-badge.unknown {
  background: rgba(107,114,128,0.08); color: var(--text-mute); }
.verdict-confidence { font-size: 11px; color: var(--text-mute); font-family: var(--font-mono); }
.stream-claim-explanation { font-size: 12px; color: var(--text-dim); margin-top: 6px; line-height: 1.5; }
.stream-claim-sources { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.stream-source { font-size: 11px; color: var(--brand);
  padding: 2px 6px; background: var(--brand-soft); border-radius: var(--r-sm);
  font-family: var(--font-mono); }
.stream-source:hover { text-decoration: underline; }
.api-btn-danger { background: var(--disputed) !important; border-color: var(--disputed) !important; color: #fff !important; }
.api-btn-danger:hover { background: #991b1b !important; }

/* Mode badges */
.badge { display: inline-flex; align-items: center; margin-left: var(--s-2);
  padding: 2px 8px; border-radius: 100px;
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: 0.04em; text-transform: uppercase; font-weight: 500; }
.badge-default { background: var(--brand-soft); color: var(--brand); }
.badge-stream  { background: #fef3c7; color: #92400e; }
.badge-async   { background: #dbeafe; color: #1e40af; }

/* Docs layout */
.docs-layout { display: grid; grid-template-columns: 240px 1fr; gap: var(--s-12); padding: var(--s-12) 0; }
@media (max-width: 1000px) { .docs-layout { grid-template-columns: 1fr; gap: var(--s-6); } }
.docs-sidebar { position: sticky; top: 80px; align-self: start;
  height: calc(100vh - 100px); overflow-y: auto; padding-right: var(--s-4); }
.docs-sidebar h4 { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text-mute); font-weight: 500;
  padding: 0 var(--s-3); margin: var(--s-6) 0 var(--s-2); }
.docs-sidebar h4:first-child { margin-top: 0; }
.docs-sidebar ul { list-style: none; padding: 0; margin: 0; }
.docs-sidebar a { display: block; font-size: 13.5px; color: var(--text-dim);
  padding: var(--s-2) var(--s-3); border-radius: var(--r-sm);
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease); }
.docs-sidebar a:hover { color: var(--text); background: var(--bg-sunken); }
.docs-sidebar a.active { color: var(--brand); background: var(--brand-soft); }
.docs-content { max-width: 760px; }
.docs-content h1 { font-size: 40px; letter-spacing: -0.03em; margin-bottom: var(--s-3); }
.docs-content h2 { font-size: 26px; letter-spacing: -0.02em; line-height: 1.2;
  margin: var(--s-16) 0 var(--s-4); padding-top: var(--s-4);
  border-top: 1px solid var(--border); }
.docs-content h2:first-of-type { border-top: none; padding-top: 0; margin-top: var(--s-8); }
.docs-content h3 { font-size: 17px; margin: var(--s-8) 0 var(--s-3); }
.docs-content p { font-size: 15px; color: var(--text-soft); line-height: 1.7; margin-bottom: var(--s-4); }
.docs-content p a, .docs-content li a { color: var(--brand); border-bottom: 1px solid var(--brand-soft); transition: border-color var(--dur); }
.docs-content p a:hover, .docs-content li a:hover { border-color: var(--brand); }
.docs-content ul, .docs-content ol { padding-left: var(--s-6); margin-bottom: var(--s-4); color: var(--text-soft); }
.docs-content li { margin-bottom: var(--s-2); line-height: 1.65; font-size: 15px; }
.docs-content code { font-family: var(--font-mono); font-size: 12.5px;
  background: var(--bg-sunken); padding: 2px 6px;
  border-radius: var(--r-sm); border: 1px solid var(--border); color: var(--text); }
.docs-content pre { font-family: var(--font-mono); font-size: 13px; line-height: 1.6;
  background: var(--bg-code); color: var(--bg-code-fg);
  border-radius: var(--r-md); padding: var(--s-4) var(--s-5);
  overflow-x: auto; margin: var(--s-4) 0; }
.docs-content pre code, .docs-content pre code * {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  color: inherit !important;
  font-size: 13px !important;
  border-radius: 0 !important; }
.docs-content table { width: 100%; margin: var(--s-4) 0; border-collapse: separate; border-spacing: 0;
  border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; font-size: 14px; }
.docs-content th { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute);
  text-align: left; padding: var(--s-3) var(--s-4); background: var(--bg-sunken);
  border-bottom: 1px solid var(--border); font-weight: 500; }
.docs-content td { padding: var(--s-3) var(--s-4); border-bottom: 1px solid var(--border); color: var(--text-soft); }
.docs-content td:first-child { font-family: var(--font-mono); font-size: 12.5px; color: var(--text); }
.docs-content tr:last-child td { border-bottom: none; }

/* Method badges (reference page) */
.method-badge { display:inline-block; font-family: var(--font-mono); font-size: 11px;
  padding: 2px 8px; border-radius: 4px; letter-spacing: 0.04em; margin-right: var(--s-2); font-weight: 600; }
.method-post { background: var(--brand-soft); color: var(--brand); }
.method-get  { background: #dbeafe; color: #1e40af; }
.docs-content h2 .method-badge { vertical-align: middle; }
.docs-content h2 code, .docs-content h2 .endpoint { font-family: var(--font-mono); font-size: 0.65em; color: var(--text-dim); margin-left: var(--s-2); font-weight: 500; }

/* Showcase */
.showcase { text-align: center; }
.showcase h2 { margin: 0 auto var(--s-4); max-width: 22ch; }
.showcase p { max-width: 50ch; margin: 0 auto var(--s-8); color: var(--text-dim); font-size: 16px; }
.showcase a.show-link { display: inline-block;
  border: 1px solid var(--border); border-radius: var(--r-lg);
  overflow: hidden; transition: all var(--dur) var(--ease); box-shadow: var(--shadow-md); }
.showcase a.show-link:hover { border-color: var(--border-hover); transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.showcase img { display: block; max-width: 100%; width: 920px; height: auto; }

/* Chips (sources section on home) */
.chips { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.chip { display: inline-flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-4); background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 100px;
  font-size: 13.5px; color: var(--text); transition: all var(--dur) var(--ease); }
.chip:hover { border-color: var(--border-hover); transform: translateY(-1px); }
.chip svg { width: 16px; height: 16px; color: var(--chip-accent, var(--brand)); }

/* Source grid (home inputs) */
.src-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0;
  border: 1px solid var(--border); border-radius: var(--r-lg);
  overflow: hidden; background: var(--bg-card); }
@media (max-width: 880px) { .src-grid { grid-template-columns: repeat(3, 1fr); } }
.src-item { position: relative; padding: var(--s-6) var(--s-4);
  display: flex; flex-direction: column; align-items: center; gap: var(--s-3);
  border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
  transition: background var(--dur) var(--ease); cursor: default; }
.src-item:hover { background: var(--bg-sunken); }
.src-item:nth-child(6n) { border-right: none; }
.src-item:nth-last-child(-n+6) { border-bottom: none; }
@media (max-width: 880px) {
  .src-item:nth-child(6n) { border-right: 1px solid var(--border); }
  .src-item:nth-child(3n) { border-right: none; }
}
.src-item svg, .src-item img { width: 28px; height: 28px; opacity: 0.85; }
.src-item span { font-size: 12.5px; font-family: var(--font-mono); color: var(--text-dim); }

/* Steps (quickstart) */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
@media (max-width: 880px) { .steps { grid-template-columns: 1fr; } }
.step { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-6); position: relative;
  transition: border-color var(--dur) var(--ease); }
.step:hover { border-color: var(--border-hover); }
.step-num { display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  font-family: var(--font-mono); font-size: 13px; font-weight: 500;
  color: var(--brand); background: var(--brand-soft);
  border-radius: var(--r-sm); margin-bottom: var(--s-4); }
.step h3 { margin-bottom: var(--s-2); }
.step p { font-size: 14px; color: var(--text-dim); }
.step-cta { margin-top: var(--s-5); }

/* Pipeline flow */
.pipe-flow { position: relative; display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; padding: var(--s-12) 0; }
@media (max-width: 880px) {
  .pipe-flow { grid-template-columns: 1fr; padding: var(--s-6) 0; }
  .pipe-flow .pipe-line, .pipe-flow .travel-dot { display: none; }
}
.pipe-line { position: absolute; top: 50%; left: 10%; right: 10%; height: 1px;
  background: linear-gradient(to right, transparent, var(--border-strong) 8%, var(--border-strong) 92%, transparent); z-index: 0; }
.travel-dot { position: absolute; top: 50%; left: 10%; width: 6px; height: 6px;
  margin-top: -3px; border-radius: 50%; background: var(--brand);
  box-shadow: 0 0 8px rgba(15, 110, 77, 0.5); z-index: 1;
  animation: travel 5s linear infinite; }
.travel-dot:nth-child(2) { animation-delay: 1.25s; opacity: 0.7; }
.travel-dot:nth-child(3) { animation-delay: 2.5s; opacity: 0.5; }
.travel-dot:nth-child(4) { animation-delay: 3.75s; opacity: 0.3; }
@keyframes travel { from { left: 10%; opacity: 0; } 10% { opacity: 1; } 90% { opacity: 1; } to { left: 90%; opacity: 0; } }
.pipe-node { position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center; text-align: center; }
.pipe-circle { width: 64px; height: 64px; border-radius: 50%;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--s-4); transition: all var(--dur) var(--ease); }
.pipe-circle svg { width: 22px; height: 22px; stroke: var(--text-soft); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; transition: stroke var(--dur) var(--ease); }
.pipe-node:hover .pipe-circle { border-color: var(--brand); transform: translateY(-2px); }
.pipe-node:hover .pipe-circle svg { stroke: var(--brand); }
.pipe-label { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text); margin-bottom: var(--s-1); }
.pipe-desc  { font-size: 12.5px; color: var(--text-dim); max-width: 14ch; line-height: 1.4; }

/* Benchmark cards */
.bench-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
@media (max-width: 880px) { .bench-grid { grid-template-columns: 1fr; } }
.bench-card { position: relative; perspective: 1200px; height: 420px; }
.bench-inner { position: absolute; inset: 0;
  transform-style: preserve-3d; transition: transform 0.55s var(--ease); }
.bench-card.flipped .bench-inner { transform: rotateY(180deg); }
.bench-face { position: absolute; inset: 0; backface-visibility: hidden;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-6);
  display: flex; flex-direction: column;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.bench-card:not(.flipped) .bench-face:first-child:hover {
  border-color: var(--border-hover); transform: translateY(-2px); }
.bench-back { transform: rotateY(180deg); }
.bench-tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--text-mute); }
.bench-name { margin-top: var(--s-2); font-size: 15px; font-weight: 500; color: var(--text); letter-spacing: -0.01em; }
.bench-score { margin: var(--s-6) 0 var(--s-2);
  display: flex; align-items: baseline; gap: var(--s-2); }
.bench-score-val { font-family: var(--font-mono); font-size: 56px;
  font-weight: 500; letter-spacing: -0.04em; color: var(--text); line-height: 1; }
.bench-score-sub { font-family: var(--font-mono); font-size: 12px; color: var(--text-mute);
  text-transform: uppercase; letter-spacing: 0.06em; }
.bench-bar { height: 4px; background: var(--bg-sunken); border-radius: 2px;
  margin: var(--s-3) 0 var(--s-5); position: relative; overflow: hidden; }
.bench-bar-fill { position: absolute; inset: 0; background: var(--brand);
  border-radius: 2px; transform-origin: left;
  animation: barFill 1.2s var(--ease-out-back) both; }
@keyframes barFill { from { transform: scaleX(0); } to { transform: scaleX(var(--fill, 1)); } }
.bench-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-3);
  padding: var(--s-3) 0; border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border); margin-bottom: var(--s-4); }
.bench-stat { display: flex; flex-direction: column; gap: 2px; }
.bench-stat-val { font-family: var(--font-mono); font-size: 14px; font-weight: 500; color: var(--text); }
.bench-stat-lbl { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute); }
.bench-so-what { font-size: 13.5px; color: var(--text-soft); line-height: 1.5; flex: 1; }
.bench-flip { margin-top: var(--s-4); padding-top: var(--s-4); border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  color: var(--text-dim); font-size: 12.5px; font-family: var(--font-mono); cursor: pointer; }
.bench-flip svg { width: 14px; height: 14px; transition: transform var(--dur) var(--ease); }
.bench-card:not(.flipped) .bench-face:hover .bench-flip { color: var(--text); }
.bench-card:not(.flipped) .bench-face:hover .bench-flip svg { transform: rotate(180deg); }
.bench-back-name { font-family: var(--font-mono); font-size: 13px; color: var(--brand); letter-spacing: 0.04em; text-transform: uppercase; }
.bench-back-table { margin: var(--s-4) 0; }
.bench-back-row { display: flex; justify-content: space-between; align-items: center;
  padding: var(--s-2) 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.bench-back-row:last-child { border-bottom: none; }
.bench-back-row span:first-child { color: var(--text-dim); }
.bench-back-row span:last-child { font-family: var(--font-mono); color: var(--text); }
.bench-back-desc { font-size: 13px; line-height: 1.6; color: var(--text-soft); flex: 1; overflow-y: auto; }
.bench-back-close { margin-top: var(--s-3); font-family: var(--font-mono); font-size: 11.5px; color: var(--text-mute); text-align: right; cursor: pointer; }

/* Hero (homepage) */
.hero { border-top: none; padding: var(--s-24) 0 var(--s-16); position: relative; overflow: hidden; }
.hero::before { content:""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 20% 10%, rgba(15, 110, 77, 0.04), transparent 40%),
                    radial-gradient(circle at 80% 0%, rgba(15, 110, 77, 0.025), transparent 35%);
  pointer-events: none; }
.hero-grid { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: var(--s-16); align-items: center; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: var(--s-10); } }
.hero-label { display: inline-flex; align-items: center; gap: var(--s-2);
  height: 28px; padding: 0 var(--s-3);
  border: 1px solid var(--border-strong); background: var(--bg-card);
  border-radius: 100px; font-family: var(--font-mono); font-size: 12px;
  color: var(--text-dim); margin-bottom: var(--s-6);
  transition: border-color var(--dur) var(--ease); }
.hero-label:hover { border-color: var(--text); color: var(--text); }
.hero-label .dot { width: 6px; height: 6px; border-radius: 50%;
  background: var(--brand); box-shadow: 0 0 0 3px rgba(15, 110, 77, 0.18);
  animation: heroPulse 2.4s var(--ease) infinite; }
@keyframes heroPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.hero h1 { margin-bottom: var(--s-5); }
.hero h1 em { font-style: normal; color: var(--brand); }
.hero-sub { font-size: 18px; color: var(--text-dim); max-width: 50ch; line-height: 1.5; margin-bottom: var(--s-8); }
.hero-ctas { display: flex; gap: var(--s-3); flex-wrap: wrap; align-items: flex-start; }
.hero-cta-stack { display: flex; flex-direction: column; align-items: center; gap: var(--s-2); }
.hero-tier { font-family: var(--font-mono); font-size: 12px; color: var(--brand); letter-spacing: 0.01em; }

/* Utility */
.center-narrow { max-width: 720px; margin: 0 auto; text-align: center; }


/* ═══════════════════════════════════════════════════════════════════════════
   LEGACY OVERRIDES — for dashboard.html and admin.html which keep their
   markup intact. We rewrite only their colors, typography, and borders so
   the layout stays the same (JS-driven tabs and tables still function).
   ═══════════════════════════════════════════════════════════════════════════ */

/* Dashboard layout */
.api-dash { background: var(--bg); padding: var(--s-12) 0; min-height: calc(100vh - 200px); }
.api-dash-inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6);
  display: grid; grid-template-columns: 240px 1fr; gap: var(--s-10); }
@media (max-width: 1000px) { .api-dash-inner { grid-template-columns: 1fr; } }

/* Sidebar */
.api-dash-sidebar { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); height: fit-content;
  position: sticky; top: 80px; }
.api-dash-sidebar-header { padding-bottom: var(--s-4); border-bottom: 1px solid var(--border);
  margin-bottom: var(--s-4); }
.api-dash-user-email { font-family: var(--font-mono); font-size: 12px; color: var(--text-dim); word-break: break-all; }
.api-dash-user-tier { font-family: var(--font-mono); font-size: 11px; color: var(--brand); margin-top: var(--s-1);
  text-transform: uppercase; letter-spacing: 0.04em; }
.api-dash-nav { display: flex; flex-direction: column; gap: var(--s-1); }
.api-dash-nav-item { display: flex; align-items: center; gap: var(--s-3);
  background: transparent; border: none; padding: var(--s-2) var(--s-3);
  border-radius: var(--r-sm); font-family: var(--font-sans); font-size: 14px;
  color: var(--text-dim); cursor: pointer; transition: all var(--dur) var(--ease);
  text-align: left; }
.api-dash-nav-item:hover { color: var(--text); background: var(--bg-sunken); }
.api-dash-nav-item.active { color: var(--brand); background: var(--brand-soft); }
.api-dash-nav-item svg { width: 14px; height: 14px; flex-shrink: 0; }
.api-dash-sidebar-footer { margin-top: var(--s-5); padding-top: var(--s-5); border-top: 1px solid var(--border); }
.api-dash-app-link { display: inline-flex; align-items: center; gap: var(--s-2);
  font-size: 13px; color: var(--text-dim); transition: color var(--dur) var(--ease); }
.api-dash-app-link:hover { color: var(--brand); }

/* Content */
.api-dash-content { background: transparent; }
.api-dash-banner { padding: var(--s-3) var(--s-4) !important;
  border-radius: var(--r-md) !important; font-size: 13.5px !important; font-family: var(--font-sans) !important; }
.api-dash-tab { display: none; }
.api-dash-tab.active { display: block; }
.api-dash-tab-header { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--s-3); }
.api-dash-tab-header h2 { font-family: var(--font-sans); font-size: 24px;
  letter-spacing: -0.02em; color: var(--text); font-weight: 600; }
.api-dash-tab-desc { font-size: 14px; color: var(--text-dim); margin-bottom: var(--s-6); line-height: 1.6; }
.api-dash-tab-desc code { font-family: var(--font-mono); font-size: 12.5px;
  background: var(--bg-sunken); padding: 1px 6px; border-radius: var(--r-sm); border: 1px solid var(--border); }

/* Tables */
.api-dash-table-wrap { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; }
.api-dash-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 14px; }
.api-dash-table th { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--text-mute); text-align: left;
  padding: var(--s-3) var(--s-4); background: var(--bg-sunken);
  border-bottom: 1px solid var(--border); font-weight: 500; }
.api-dash-table td { padding: var(--s-3) var(--s-4); border-bottom: 1px solid var(--border); color: var(--text-soft); }
.api-dash-table tr:last-child td { border-bottom: none; }
.api-dash-table tr:hover td { background: var(--bg-sunken); }
.api-dash-table td code { font-family: var(--font-mono); font-size: 12.5px;
  background: var(--bg-sunken); padding: 2px 6px; border-radius: var(--r-sm); border: 1px solid var(--border); color: var(--text); }

/* Upload zone */
.api-dash-corpus-upload { background: var(--bg-card); border: 1.5px dashed var(--border-strong);
  border-radius: var(--r-lg); padding: var(--s-8) var(--s-6); margin: var(--s-5) 0;
  transition: border-color var(--dur) var(--ease); }
.api-dash-corpus-upload:hover { border-color: var(--brand); }
.api-dash-corpus-upload.dragging { border-color: var(--brand); background: var(--brand-soft); }
.api-dash-corpus-upload-inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--s-3); }
.api-dash-corpus-upload-inner svg { stroke: var(--text-dim); }
.api-dash-corpus-upload-title { font-size: 14px; color: var(--text); margin: 0; }
.api-dash-corpus-upload-hint { font-family: var(--font-mono); font-size: 11.5px; color: var(--text-mute); margin: 0; }
.api-dash-link { background: none; border: none; color: var(--brand); cursor: pointer;
  font-size: inherit; padding: 0; text-decoration: underline; font-family: inherit; }
.api-dash-link:hover { color: var(--brand-strong); }
.api-dash-link-sm { font-size: 13px; color: var(--brand); }

/* Coverage description card */
.api-dash-coverage { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); margin-bottom: var(--s-5); }
.api-dash-coverage-header { display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: var(--s-3); margin-bottom: var(--s-3); }
.api-dash-coverage-title { display: flex; align-items: center; gap: var(--s-2);
  font-size: 14px; font-weight: 500; color: var(--text); }
.api-dash-coverage-title svg { stroke: var(--text-dim); }
.api-dash-coverage-pill { font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 2px 8px; border-radius: 100px;
  background: var(--brand-soft); color: var(--brand); }
.api-dash-coverage-spinner { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); }
.api-dash-coverage-actions { display: flex; gap: var(--s-2); }
.api-dash-coverage-body p { font-size: 13.5px; color: var(--text-dim); line-height: 1.6; }
.api-dash-coverage-text { font-size: 13.5px; color: var(--text-soft); line-height: 1.6; }
.api-dash-coverage-edit-area textarea { width: 100%; font-family: var(--font-sans); font-size: 13.5px;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: var(--r-md); padding: var(--s-3); color: var(--text); line-height: 1.6; min-height: 100px; }
.api-dash-coverage-edit-actions { display: flex; align-items: center; gap: var(--s-3); margin-top: var(--s-2); }
.api-dash-coverage-edit-hint { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); }
.api-dash-coverage-meta { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); margin-top: var(--s-2); }

/* Storage meter */
.api-dash-corpus-meter { display: flex; align-items: center; gap: var(--s-3); margin: var(--s-5) 0; font-size: 13px; color: var(--text-dim); }
.api-dash-corpus-meter-bar { flex: 1; height: 4px; background: var(--bg-sunken); border-radius: 2px; overflow: hidden; }
.api-dash-corpus-meter-fill { height: 100%; background: var(--brand); border-radius: 2px; transition: width var(--dur) var(--ease); }
.api-dash-corpus-progress { margin-top: var(--s-3); }
.api-dash-corpus-progress > div { display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-2) var(--s-3); background: var(--bg-sunken); border-radius: var(--r-sm); margin-bottom: var(--s-2); font-size: 12.5px; color: var(--text-soft); }

/* Billing summary cards */
.api-dash-billing-top { display: grid; grid-template-columns: repeat(2, 1fr) 1.4fr; gap: var(--s-4); margin-bottom: var(--s-8); }
@media (max-width: 880px) { .api-dash-billing-top { grid-template-columns: 1fr; } }
.api-dash-balance-card { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-1); }
.api-dash-balance-label { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute); }
.api-dash-balance-amount { font-family: var(--font-mono); font-size: 28px;
  font-weight: 500; letter-spacing: -0.03em; color: var(--text); }
.api-dash-balance-sub { font-family: var(--font-mono); font-size: 11.5px; color: var(--text-mute); }
.api-dash-billing-settings { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3); }
.api-dash-setting-row { display: flex; justify-content: space-between; align-items: center; gap: var(--s-3);
  padding-bottom: var(--s-3); border-bottom: 1px solid var(--border); }
.api-dash-setting-row:last-child { border-bottom: none; padding-bottom: 0; }
.api-dash-setting-label { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute); }
.api-dash-setting-value { font-size: 14px; color: var(--text); margin-top: 2px; }
.api-dash-usage-header { display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--s-4); flex-wrap: wrap; gap: var(--s-3); }
.api-dash-usage-header h3 { font-family: var(--font-sans); font-size: 18px;
  letter-spacing: -0.02em; color: var(--text); font-weight: 600; }
.api-dash-usage-filters { display: flex; gap: var(--s-2); }
.api-dash-select { font-family: var(--font-sans); font-size: 13px;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: var(--r-md); padding: var(--s-2) var(--s-3); color: var(--text); cursor: pointer; }

/* Legacy api-btn aliases (used by admin and dashboard buttons) */
.api-btn { display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  height: 36px; padding: 0 var(--s-4);
  font-family: var(--font-sans); font-size: 13.5px; font-weight: 500;
  border-radius: var(--r-md); border: 1px solid transparent;
  cursor: pointer; transition: all var(--dur) var(--ease); white-space: nowrap; }
.api-btn-primary { background: var(--text); color: #fff; border-color: var(--text); }
.api-btn-primary:hover { background: #1a1a1a; }
.api-btn-secondary { background: var(--bg-card); color: var(--text); border-color: var(--border-strong); }
.api-btn-secondary:hover { border-color: var(--text); }
.api-btn-ghost { background: transparent; color: var(--text-dim); border-color: transparent; }
.api-btn-ghost:hover { color: var(--text); background: var(--bg-sunken); }
.api-btn-oauth { background: var(--bg-card); color: var(--text); border-color: var(--border-strong); height: 44px; }
.api-btn-oauth:hover { border-color: var(--text); }
.api-btn-sm { height: 32px; padding: 0 var(--s-3); font-size: 13px; }
.api-btn-xs { height: 26px; padding: 0 var(--s-2); font-size: 12px; }
.api-btn-lg { height: 44px; padding: 0 var(--s-6); font-size: 14px; }

/* Admin specifics */
.admin-header { padding: var(--s-12) 0 var(--s-6); }
.admin-header h1 { font-size: 32px; letter-spacing: -0.02em; }
.admin-tabs { display: flex; gap: var(--s-1); border-bottom: 1px solid var(--border); margin-bottom: var(--s-8); }
.admin-tab-btn { background: transparent; border: none; padding: var(--s-3) var(--s-4);
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--text-dim); cursor: pointer; border-bottom: 2px solid transparent;
  margin-bottom: -1px; transition: all var(--dur) var(--ease); }
.admin-tab-btn:hover { color: var(--text); }
.admin-tab-btn.active { color: var(--brand); border-bottom-color: var(--brand); }
.admin-tab-panel { display: none; }
.admin-tab-panel.active { display: block; }
.admin-table { width: 100%; border-collapse: separate; border-spacing: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden; font-size: 14px; }
.admin-table th { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute);
  text-align: left; padding: var(--s-3) var(--s-4); background: var(--bg-sunken);
  border-bottom: 1px solid var(--border); font-weight: 500; }
.admin-table td { padding: var(--s-3) var(--s-4); border-bottom: 1px solid var(--border); color: var(--text-soft); }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--bg-sunken); }
.admin-cost-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--s-4); margin-bottom: var(--s-6); }
.admin-cost-card { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-1); }
.admin-cost-card-label { font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-mute); }
.admin-cost-card-value { font-family: var(--font-mono); font-size: 24px;
  font-weight: 500; letter-spacing: -0.02em; color: var(--text); }
.admin-cost-controls { display: flex; gap: var(--s-3); margin-bottom: var(--s-4); align-items: center; flex-wrap: wrap; }
.admin-summary { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5); margin-bottom: var(--s-5); font-size: 14px; color: var(--text-soft); }
.admin-empty { padding: var(--s-12) var(--s-6); text-align: center; color: var(--text-dim);
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r-lg); }
.admin-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 100;
  display: flex; align-items: center; justify-content: center; padding: var(--s-6); }
.admin-modal { background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-6); max-width: 480px; width: 100%;
  box-shadow: var(--shadow-lg); position: relative; }
.admin-modal-close { position: absolute; top: var(--s-3); right: var(--s-3);
  background: transparent; border: none; cursor: pointer; padding: var(--s-2);
  color: var(--text-dim); font-size: 18px; line-height: 1; }
.admin-modal-close:hover { color: var(--text); }
.admin-plan-select { font-family: var(--font-sans); font-size: 13px;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: var(--r-md); padding: var(--s-2) var(--s-3); color: var(--text); cursor: pointer; }

/* Legacy api-* containers and sections (used by admin/dashboard/pricing) */
.api-page { background: var(--bg); }
.api-container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--s-6); }
.api-section { padding: var(--s-16) 0; }
.api-section-header { margin-bottom: var(--s-8); max-width: 820px; }
.api-section-header h2 { font-family: var(--font-sans); font-size: 28px;
  letter-spacing: -0.02em; color: var(--text); font-weight: 600; }
.api-section-header p { font-size: 15px; color: var(--text-dim); margin-top: var(--s-2); }
.api-footer { display: none; }


/* ═══════════════════════════════════════════════════════════════════════════
   Beta gate modal — used by /static/js/api-beta-gate.js when a user clicks
   any /api/login, /api/register, or /api/dashboard link. The script injects
   the modal markup; we just need to style it. Restyled with v2 tokens.
   ═══════════════════════════════════════════════════════════════════════════ */
.beta-gate-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 10, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  animation: betaGateFadeIn 0.2s ease;
  padding: var(--s-5);
}
@keyframes betaGateFadeIn { from { opacity: 0; } to { opacity: 1; } }

.beta-gate-modal {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--s-10) var(--s-10) var(--s-8);
  max-width: 480px;
  width: 100%;
  box-shadow: var(--shadow-lg);
  font-family: var(--font-sans);
  animation: betaGateSlideUp 0.25s ease;
  max-height: 90vh;
  overflow-y: auto;
}
@keyframes betaGateSlideUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.beta-gate-title {
  font-family: var(--font-sans);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text);
  margin: 0 0 var(--s-2);
}

.beta-gate-desc {
  color: var(--text-dim);
  font-size: 14px;
  line-height: 1.6;
  margin: 0 0 var(--s-6);
}

.beta-gate-form {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}

.beta-gate-label {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--text-dim);
}

.beta-gate-input {
  width: 100%;
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  font-size: 14px;
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg-card);
  outline: none;
  letter-spacing: -0.005em;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.beta-gate-input::placeholder { text-transform: none; letter-spacing: -0.005em; font-family: var(--font-sans); font-size: 14px; color: var(--text-mute); }
.beta-gate-input:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(15, 110, 77, 0.12);
}

.beta-gate-textarea {
  resize: vertical;
  min-height: 80px;
  line-height: 1.55;
  font-family: var(--font-sans);
}

.beta-gate-submit {
  margin-top: var(--s-1);
  width: 100%;
  background: var(--text) !important;
  color: #fff !important;
  border-color: var(--text) !important;
  height: 44px;
  font-size: 14px;
  font-family: var(--font-sans);
  font-weight: 500;
}
.beta-gate-submit:hover { background: #1a1a1a !important; }

.beta-gate-divider {
  height: 1px;
  background: var(--border);
  margin: var(--s-6) 0 var(--s-5);
}

.beta-gate-access {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}

.beta-gate-access-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--text-dim);
}

.beta-gate-access-row {
  display: flex;
  align-items: center;
  gap: var(--s-2);
}

.beta-gate-access-text {
  font-size: 13px;
  color: var(--text-dim);
  white-space: nowrap;
}

.beta-gate-code-input {
  flex: 1;
  padding: var(--s-2) var(--s-3);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-md);
  font-size: 13px;
  font-family: var(--font-mono);
  color: var(--text);
  background: var(--bg-card);
  outline: none;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.beta-gate-code-input:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(15, 110, 77, 0.12);
}

.beta-gate-code-btn {
  white-space: nowrap;
  background: var(--text) !important;
  color: #fff !important;
  border-color: var(--text) !important;
}
.beta-gate-code-btn:hover { background: #1a1a1a !important; }

.beta-gate-error {
  font-size: 12.5px;
  color: var(--disputed);
  margin: var(--s-1) 0 0;
}

#beta-gate-thankyou { align-items: center; justify-content: center; min-height: 200px; }
.beta-gate-thankyou-inner {
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  gap: var(--s-3);
}
.beta-gate-check-icon { margin-bottom: var(--s-1); }
.beta-gate-check-icon { stroke: var(--brand); }
.beta-gate-thankyou-inner .beta-gate-title { margin-bottom: 0; }
.beta-gate-thankyou-inner .beta-gate-desc { margin-bottom: var(--s-2); }
.beta-gate-close-btn { margin-top: var(--s-2); }

@media (max-width: 520px) {
  .beta-gate-modal { padding: var(--s-6) var(--s-5); }
  .beta-gate-access-row { flex-direction: column; align-items: stretch; }
  .beta-gate-access-text { margin-bottom: var(--s-1); }
}
