/* ─── Legal page layout ──────────────────────────────────────────────────────── */
.legal-wrap { padding: 4rem 0 6rem; }
.legal-layout { display: grid; grid-template-columns: 220px 1fr; gap: 4rem; align-items: start; }
.legal-body { min-width: 0; }

/* ─── Header ──────────────────────────────────────────────────────────────────── */
.legal-header { margin-bottom: 2.5rem; padding-bottom: 2rem; border-bottom: 1px solid var(--border); }
.legal-header h1 { font-size: 1.9rem; margin-bottom: 0.4rem; }
.legal-meta { font-size: 0.85rem; color: var(--text-faint); }

/* ─── Sidebar TOC ─────────────────────────────────────────────────────────────── */
.legal-toc {
  position: sticky; top: 90px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.25rem;
}
.legal-toc-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-faint); margin-bottom: 0.75rem; }
.legal-toc ol { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0.1rem; }
.legal-toc a { font-size: 0.83rem; color: var(--text-muted); display: block; padding: 0.3rem 0.5rem; border-radius: 6px; transition: all 0.12s; line-height: 1.4; }
.legal-toc a:hover { color: var(--accent); background: rgba(99,102,241,0.06); }

/* ─── Prose ───────────────────────────────────────────────────────────────────── */
.legal-body h2 {
  font-size: 1.1rem; font-weight: 700;
  margin: 2.5rem 0 0.75rem; padding-top: 2.5rem;
  border-top: 1px solid var(--border);
  color: var(--text); scroll-margin-top: 90px;
}
.legal-body h2:first-of-type { margin-top: 0; padding-top: 0; border-top: none; }
.legal-body h3 { font-size: 0.95rem; font-weight: 700; margin: 1.5rem 0 0.5rem; color: var(--text); }
.legal-body p { font-size: 0.9rem; line-height: 1.8; margin-bottom: 0.9rem; color: var(--text-muted); }
.legal-body ul, .legal-body ol { padding-left: 1.4rem; margin-bottom: 1rem; }
.legal-body li { font-size: 0.9rem; line-height: 1.75; color: var(--text-muted); margin-bottom: 0.3rem; }
.legal-body a { color: var(--accent); }
.legal-body a:hover { color: var(--accent-hover); }
.legal-body strong { color: var(--text); font-weight: 600; }
.legal-body code { font-family: var(--mono); font-size: 0.85em; background: var(--surface-2); padding: 0.1em 0.4em; border-radius: 4px; color: var(--text); }

/* ─── Contact box ─────────────────────────────────────────────────────────────── */
.legal-contact {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.25rem 1.5rem; margin-top: 2rem;
}
.legal-contact p { margin: 0; font-size: 0.875rem; }

/* ─── Responsive ──────────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
  .legal-layout { grid-template-columns: 1fr; gap: 2rem; }
  .legal-toc { position: static; }
}
@media (max-width: 540px) {
  .legal-wrap { padding: 2.5rem 0 4rem; }
  .legal-header h1 { font-size: 1.5rem; }
}
