/* Legal / policy pages */
.legal-page {
  padding-top: 100px;
}

.legal-hero {
  padding: 48px 0 32px;
  border-bottom: 1px solid var(--line);
}

.legal-hero h1 {
  font-size: clamp(36px, 5vw, 56px);
  margin-bottom: 12px;
  color: var(--ink);
}

.legal-meta {
  font-size: 14px;
  color: var(--ink-dim);
}

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

.legal-meta a:hover {
  text-decoration: underline;
}

.legal-body {
  padding: 48px 0 80px;
}

.legal-content {
  max-width: 760px;
}

.legal-content h2 {
  font-family: var(--sans);
  font-size: 20px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  color: var(--ink);
  margin: 40px 0 16px;
}

.legal-content h2:first-of-type {
  margin-top: 0;
}

.legal-content h3 {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  margin: 24px 0 10px;
}

.legal-content p,
.legal-content li {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-dim);
  margin-bottom: 12px;
}

.legal-content ul,
.legal-content ol {
  margin: 0 0 16px 1.25rem;
  padding: 0;
}

.legal-content li {
  margin-bottom: 8px;
}

.legal-content strong {
  color: var(--ink);
  font-weight: 600;
}

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

.legal-content a:hover {
  text-decoration: underline;
}

.legal-box {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  margin: 24px 0;
}

.legal-box p:last-child {
  margin-bottom: 0;
}

.legal-toc {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px 28px;
  margin-bottom: 40px;
}

.legal-toc h2 {
  font-size: 14px;
  margin: 0 0 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legal-toc ol {
  margin: 0;
  padding-left: 1.25rem;
}

.legal-toc a {
  font-size: 14px;
  color: var(--ink-dim);
}

.legal-toc a:hover {
  color: var(--accent);
}

.legal-nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
}

.legal-nav-links a {
  font-size: 13px;
  font-weight: 600;
  padding: 10px 18px;
  border: 1px solid var(--line-2);
  border-radius: var(--radius-pill);
  color: var(--ink-dim);
  transition: border-color 200ms var(--ease), color 200ms var(--ease);
}

.legal-nav-links a:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.legal-nav-links a.active {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--on-accent);
}

@media (max-width: 680px) {
  .legal-page {
    padding-top: 88px;
  }

  .floating-cta {
    display: none;
  }
}
