/* ============================================================================
   legal-page.css
   ----------------------------------------------------------------------------
   Shared chrome for trust / legal pages:
     - affiliate-disclosure.html
     - privacy.html
     - terms.html
     - sitemap.html  (reuses .legal-hero + adds its own .legal-sitemap blocks)

   Editorial single-column reading width, mint page background (matches site),
   accent rule on the TL;DR band, inverted "trust move" card, and a quiet
   directory layout for the sitemap. Tokens only — no raw values.
   ========================================================================= */

/* ── PAGE SHELL ────────────────────────────────────────────────────────── */

.legal-page {
  background: var(--color-bg);
  color: var(--color-ink);
}

/* ── HERO ──────────────────────────────────────────────────────────────── */

.legal-hero {
  padding-block: clamp(var(--space-12), 8vw, var(--space-20))
                 clamp(var(--space-8),  4vw, var(--space-12));
  border-bottom: 1px solid var(--color-line);
}

.legal-hero__inner {
  max-width: 56rem;
  margin-inline: auto;
}

.legal-hero__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 0 0 var(--space-4);
}

.legal-hero__title {
  font-family: var(--font-sans);
  font-size: clamp(var(--fs-2xl), 4.5vw, 3rem);
  font-weight: var(--fw-black);
  line-height: 1.15;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
  margin: 0 0 var(--space-6);
}

.legal-hero__title em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
}

.legal-hero__meta {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  color: var(--color-ink-muted);
  margin: 0;
}

/* ── TL;DR BAND ────────────────────────────────────────────────────────── */
/* Cyan-tinted band that holds the plain-English summary — the part most
   readers will actually read. Subtle so it doesn't read as marketing. */

.legal-tldr {
  padding-block: clamp(var(--space-10), 5vw, var(--space-16));
  background: var(--color-accent-soft);
  border-bottom: 1px solid var(--color-line);
}

.legal-tldr__inner {
  max-width: 52rem;
  margin-inline: auto;
}

.legal-tldr__label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 0 0 var(--space-4);
}

.legal-tldr__copy {
  font-family: var(--font-serif);
  font-size: clamp(var(--fs-lg), 1.8vw, var(--fs-xl));
  line-height: 1.55;
  color: var(--color-ink);
  margin: 0;
}

.legal-tldr__copy + .legal-tldr__copy {
  margin-top: var(--space-4);
}

.legal-tldr__copy em {
  font-style: italic;
  font-weight: var(--fw-bold);
}

/* ── BODY (single-column reading) ──────────────────────────────────────── */

.legal-body {
  padding-block: clamp(var(--space-12), 7vw, var(--space-20));
}

.legal-body__inner {
  max-width: 44rem;
  margin-inline: auto;
}

.legal-body section + section {
  margin-top: clamp(var(--space-10), 5vw, var(--space-14));
}

.legal-body h2 {
  font-family: var(--font-sans);
  font-size: clamp(var(--fs-xl), 2.5vw, var(--fs-2xl));
  font-weight: var(--fw-bold);
  line-height: 1.2;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
  margin: 0 0 var(--space-5);
}

.legal-body h2 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-bold);
}

.legal-body h3 {
  font-family: var(--font-sans);
  font-size: var(--fs-lg);
  font-weight: var(--fw-semibold);
  line-height: 1.3;
  color: var(--color-ink);
  margin: var(--space-6) 0 var(--space-3);
}

.legal-body p {
  font-family: var(--font-serif);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--color-ink);
  margin: 0 0 var(--space-4);
}

.legal-body p strong,
.legal-body li strong {
  font-weight: var(--fw-bold);
}

.legal-body p em,
.legal-body li em {
  font-style: italic;
}

.legal-body ul,
.legal-body ol {
  font-family: var(--font-serif);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--color-ink);
  margin: 0 0 var(--space-4);
  padding-left: var(--space-6);
}

.legal-body li {
  margin-bottom: var(--space-3);
}

.legal-body li::marker {
  color: var(--color-accent);
  font-weight: var(--fw-bold);
}

.legal-body a {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: text-decoration-thickness 120ms ease;
}

.legal-body a:hover {
  text-decoration-thickness: 2px;
}

.legal-body code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--color-surface-2);
  padding: 0.12em 0.4em;
  border-radius: var(--radius-xs, 3px);
}

.legal-body__aside {
  font-style: italic;
  color: var(--color-ink-muted);
  border-left: 2px solid var(--color-accent);
  padding-left: var(--space-4);
  margin-top: var(--space-4);
}

/* Definition-list pattern used by privacy & terms for short
   "term — meaning" pairs. */
.legal-body dl {
  font-family: var(--font-serif);
  margin: 0 0 var(--space-4);
}

.legal-body dt {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-ink);
  margin-top: var(--space-4);
}

.legal-body dt:first-child {
  margin-top: 0;
}

.legal-body dd {
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--color-ink);
  margin: var(--space-1) 0 0;
}

/* Inverted "trust move" card — used for sections we want to read as a
   commitment, not a clause. */
.legal-section--invert {
  background: var(--color-ink);
  color: var(--color-surface);
  padding: clamp(var(--space-8), 4vw, var(--space-12));
  border-radius: 8px;
}

.legal-section--invert h2,
.legal-section--invert p,
.legal-section--invert li,
.legal-section--invert li strong {
  color: var(--color-surface);
}

.legal-section--invert h2 em {
  color: var(--color-accent);
}

.legal-section--invert a {
  color: var(--color-accent);
}

@media (max-width: 600px) {
  .legal-section--invert {
    padding: var(--space-6);
  }
}

/* ── SITEMAP DIRECTORY ────────────────────────────────────────────────── */
/* Reuses .legal-hero on top, then a dense multi-column directory below.
   No hero/tldr coupling — sitemap pages do not need a TL;DR band. */

.legal-sitemap {
  padding-block: clamp(var(--space-12), 7vw, var(--space-20));
}

.legal-sitemap__inner {
  max-width: var(--container-default);
  margin-inline: auto;
}

.legal-sitemap__intro {
  font-family: var(--font-serif);
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--color-ink-muted);
  max-width: 44rem;
  margin: 0 0 clamp(var(--space-10), 5vw, var(--space-14));
}

.legal-sitemap__intro a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-sitemap__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(var(--space-8), 4vw, var(--space-12));
}

.legal-sitemap__group {
  border-top: 2px solid var(--color-ink);
  padding-top: var(--space-5);
}

.legal-sitemap__kicker {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 0 0 var(--space-2);
}

.legal-sitemap__title {
  font-family: var(--font-sans);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-snug);
  color: var(--color-ink);
  margin: 0 0 var(--space-5);
}

.legal-sitemap__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.legal-sitemap__list li {
  border-bottom: 1px solid var(--color-line);
}

.legal-sitemap__list li:last-child {
  border-bottom: none;
}

.legal-sitemap__list a {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  font-family: var(--font-serif);
  font-size: var(--fs-base);
  line-height: 1.4;
  color: var(--color-ink);
  text-decoration: none;
  transition: color 120ms ease;
}

.legal-sitemap__list a:hover,
.legal-sitemap__list a:focus-visible {
  color: var(--color-accent);
}

.legal-sitemap__list a span {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  color: var(--color-ink-subtle);
  flex-shrink: 0;
}

.legal-sitemap__list a:hover span,
.legal-sitemap__list a:focus-visible span {
  color: var(--color-accent);
}

.legal-sitemap__note {
  margin-top: clamp(var(--space-10), 5vw, var(--space-14));
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-line);
  font-family: var(--font-serif);
  font-size: var(--fs-sm);
  line-height: var(--lh-relaxed);
  color: var(--color-ink-muted);
  max-width: 44rem;
}

.legal-sitemap__note code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--color-surface-2);
  padding: 0.12em 0.4em;
  border-radius: var(--radius-xs, 3px);
}
