/* =========================================================================
   Orbit legal pages (privacy.html, terms.html)
   Loaded AFTER styles.css. Reuses the landing tokens, header and footer;
   only adds the long-form reading layout: a narrow prose column, a sticky
   table of contents, and document typography in the warm-cream-on-black palette.
   ========================================================================= */

/* ---- page frame --------------------------------------------------------- */
.legal-main { padding-block: 56px 96px; position: relative; z-index: 1; }

.legal-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.02em;
  color: var(--fg-muted); padding: 6px 0; margin-bottom: 28px;
  transition: color .2s var(--ease);
}
.legal-back:hover { color: var(--fg); }
.legal-back svg { transition: transform .2s var(--ease); }
.legal-back:hover svg { transform: translateX(-2px); }

/* ---- header block ------------------------------------------------------- */
.legal-head { max-width: 760px; margin-bottom: 8px; }
.legal-head h1 {
  font-family: var(--font-display);
  font-size: clamp(34px, 6vw, 52px);
  line-height: 1.04; letter-spacing: -0.02em; font-weight: 600;
  margin: 14px 0 16px;
}
.legal-updated {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; color: var(--fg-faint);
  border: 1px solid var(--hairline); border-radius: var(--radius-pill);
  padding: 4px 11px;
}
.legal-updated::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 8px var(--accent);
}
.legal-lead { font-size: 17px; line-height: 27px; color: var(--fg-muted); max-width: 68ch; margin-top: 20px; }

/* ---- TL;DR callout ------------------------------------------------------ */
.legal-tldr {
  margin: 32px 0 8px; max-width: 760px;
  border: 1px solid var(--hairline-2); border-radius: var(--radius-card);
  background: var(--accent-tint);
  padding: 22px 24px;
}
.legal-tldr h2 {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--accent); margin: 0 0 12px;
  border: 0; padding: 0;
}
.legal-tldr ul { list-style: none; display: grid; gap: 10px; }
.legal-tldr li { position: relative; padding-left: 24px; font-size: 14.5px; line-height: 22px; color: var(--fg); }
.legal-tldr li::before {
  content: ""; position: absolute; left: 4px; top: 8px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold); box-shadow: 0 0 8px rgba(216,185,117,0.6);
}

/* ---- two-column body: sticky TOC + prose -------------------------------- */
.legal-grid {
  display: grid; grid-template-columns: 220px minmax(0, 760px);
  gap: 56px; align-items: start; margin-top: 48px;
}
.legal-toc { position: sticky; top: 92px; }
.legal-toc h2 {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--fg-faint); margin: 0 0 14px;
  border: 0; padding: 0;
}
.legal-toc ol { list-style: none; counter-reset: toc; display: grid; gap: 2px; }
.legal-toc a {
  display: block; counter-increment: toc;
  font-size: 13px; line-height: 18px; color: var(--fg-muted);
  padding: 7px 10px; border-radius: var(--radius-btn);
  border-left: 2px solid transparent;
  transition: color .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
.legal-toc a::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--font-mono); font-size: 10px; color: var(--fg-faint);
  margin-right: 9px;
}
.legal-toc a:hover { color: var(--fg); background: var(--surface-5); }
.legal-toc a.is-active { color: var(--fg); border-left-color: var(--accent); background: var(--surface-5); }

/* ---- prose -------------------------------------------------------------- */
.legal-prose { max-width: 760px; }
.legal-prose section { padding: 0; margin-bottom: 40px; scroll-margin-top: 92px; }
.legal-prose h2 {
  font-family: var(--font-heading); font-size: 22px; line-height: 1.2;
  font-weight: 600; letter-spacing: -0.01em; color: var(--fg);
  padding-top: 32px; margin-bottom: 14px;
  border-top: 1px solid var(--hairline);
}
.legal-prose section:first-child h2 { border-top: 0; padding-top: 0; }
.legal-prose h3 {
  font-family: var(--font-heading); font-size: 16px; font-weight: 600;
  color: var(--fg); margin: 22px 0 8px;
}
.legal-prose p { font-size: 15.5px; line-height: 26px; color: var(--fg-muted); margin-bottom: 14px; }
.legal-prose ul { list-style: none; display: grid; gap: 9px; margin: 6px 0 16px; }
.legal-prose li { position: relative; padding-left: 22px; font-size: 15px; line-height: 24px; color: var(--fg-muted); }
.legal-prose li::before {
  content: ""; position: absolute; left: 3px; top: 9px;
  width: 6px; height: 6px; border-radius: 50%;
  border: 1.5px solid var(--accent);
}
.legal-prose strong { color: var(--fg); font-weight: 600; }
.legal-prose a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.legal-prose a:hover { color: var(--fg); }
.legal-prose code {
  font-family: var(--font-mono); font-size: 0.86em;
  background: var(--surface-5); border: 1px solid var(--hairline);
  border-radius: 4px; padding: 1px 6px; color: var(--fg);
}

.legal-contact {
  margin-top: 40px; padding: 22px 24px; max-width: 760px;
  border: 1px solid var(--hairline); border-radius: var(--radius-card);
  background: var(--bg-elevated);
}
.legal-contact h2 { border: 0; padding: 0; margin: 0 0 6px; font-size: 17px; }
.legal-contact p { margin: 0; font-size: 14.5px; color: var(--fg-muted); }
.legal-contact a { color: var(--accent); }

/* ---- responsive --------------------------------------------------------- */
@media (max-width: 900px) {
  .legal-grid { grid-template-columns: 1fr; gap: 0; }
  .legal-toc { display: none; }
}
