/* Long-form legal layout (privacy + terms) */

.legal-page main {
  max-width: 980px;
  margin: 0 auto;
  padding: 28px 22px 72px;
  line-height: 1.6;
}

.legal-page h1 {
  font-size: clamp(1.65rem, 3vw, 2.1rem);
  margin: 0 0 10px;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.legal-page h2 {
  font-size: 1.2rem;
  margin: 0 0 10px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.legal-page p {
  margin: 0 0 12px;
}

.legal-page ul {
  margin: 8px 0 16px 22px;
}

.legal-page .muted {
  color: var(--ink-muted);
  font-size: 0.9rem;
}

.doc-hero {
  background: linear-gradient(165deg, color-mix(in srgb, var(--accent) 12%, var(--surface)) 0%, var(--surface) 55%, var(--surface-2) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 24px 22px;
  margin-bottom: 22px;
  box-shadow: var(--shadow-sm);
}

.doc-hero p {
  max-width: 760px;
}

.legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 250px) 1fr;
  gap: 18px;
  align-items: start;
}

.legal-layout .card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.toc {
  position: sticky;
  top: calc(var(--header-h) + 8px);
  padding: 16px 14px;
}

.toc h3 {
  margin: 2px 0 10px;
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-muted);
}

.toc a {
  display: block;
  padding: 6px 0;
  color: var(--accent);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
}

.toc a:hover {
  text-decoration: underline;
}

.content {
  padding: 22px 24px 28px;
}

.content .section {
  border-top: 1px solid var(--line);
  padding-top: 18px;
  margin-top: 18px;
}

.content .section:first-child {
  border-top: 0;
  padding-top: 0;
  margin-top: 0;
}

.pill {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 12px;
  background: var(--violet-soft);
  color: var(--violet);
}

@media (prefers-color-scheme: dark) {
  .pill {
    color: #c4b5fd;
  }
}

.highlight {
  background: color-mix(in srgb, var(--surface-2) 85%, var(--accent));
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}

.footer-note {
  margin-top: 22px;
  padding: 16px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
}

@media (max-width: 900px) {
  .legal-layout {
    grid-template-columns: 1fr;
  }

  .toc {
    position: static;
  }
}
