/* Legal pages — layered on top of site.css */
.legal-body { background: var(--bg); min-height: 100vh; display: flex; flex-direction: column; }
.legal-body > footer { margin-top: auto; }

.legal {
  padding: 120px 28px 80px;
  min-height: 60vh;
}
.legal-wrap {
  max-width: 720px;
  margin: 0 auto;
}
.legal-eyebrow {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 18px;
}
.legal h1 {
  font-family: var(--f-display);
  font-weight: 400;
  font-size: clamp(44px, 6vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 0 0 20px;
  color: var(--ink);
}
.legal-lede {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 60ch;
  margin: 0 0 44px;
  text-wrap: pretty;
}
.legal section {
  padding: 28px 0;
  border-top: 1px solid var(--line);
}
.legal section:first-of-type { border-top: 1px solid var(--line-strong); }
.legal h2 {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 14px;
  font-weight: 500;
}
.legal p {
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--ink-2);
  margin: 0 0 12px;
  max-width: 64ch;
  text-wrap: pretty;
}
.legal p:last-child { margin-bottom: 0; }
.legal a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid var(--accent-line);
}
.legal a:hover { border-bottom-color: var(--accent); }
.legal code {
  font-family: var(--f-mono);
  font-size: 13px;
  background: var(--bg-2);
  padding: 1px 6px;
  border-radius: 3px;
  border: 1px solid var(--line);
}
.legal-meta {
  margin-top: 52px;
  padding-top: 22px;
  border-top: 1px dashed var(--line);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--ink-4);
}

@media (max-width: 640px) {
  .legal { padding: 100px 20px 60px; }
}
