.legal {
  padding: 140px 48px 100px;
  position: relative;
  z-index: 2;
  min-height: calc(100vh - 200px);
}

.legal__inner {
  max-width: 760px;
  margin: 0 auto;
}

.legal h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 0.96;
  letter-spacing: -0.03em;
  margin: 24px 0 32px;
}

.legal h2 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: -0.02em;
  margin: 56px 0 16px;
  color: var(--ink);
}

.legal h3 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 17px;
  margin: 32px 0 8px;
  color: var(--ink);
}

.legal p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink-muted);
  margin-bottom: 16px;
}

.legal__lede {
  font-size: 21px !important;
  line-height: 1.55 !important;
  color: var(--ink) !important;
  margin-bottom: 48px !important;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--stroke);
}

.legal ul {
  list-style: none;
  padding: 0;
  margin: 16px 0 24px;
}

.legal ul li {
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink-muted);
  padding-left: 28px;
  position: relative;
  margin-bottom: 8px;
}

.legal ul li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--amber);
}

.legal a {
  color: var(--amber);
  text-decoration: none;
  border-bottom: 1px solid rgba(212, 165, 116, 0.3);
  transition: border-color 0.2s;
}

.legal a:hover {
  border-color: var(--amber);
}

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

.legal__sig {
  margin-top: 80px;
  padding-top: 32px;
  border-top: 1px solid var(--stroke);
  font-style: italic;
  color: var(--ink-faint);
  font-family: var(--serif);
}

@media (max-width: 768px) {
  .legal { padding: 100px 24px 60px; }
  .legal h2 { margin: 40px 0 12px; }
}
