/* Compliance-page styles. Layered on top of styles.css. */

.legal-page {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(44px, 7vw, 90px) clamp(18px, 6vw, 72px) clamp(70px, 9vw, 120px);
}

.legal-page .eyebrow {
  margin-bottom: 18px;
  color: var(--muted);
  font: 760 .76rem/1.2 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.legal-page h1 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: 1.05;
  letter-spacing: -.03em;
  text-wrap: balance;
}

.legal-meta {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: .98rem;
  line-height: 1.5;
}

.legal-banner {
  display: grid;
  gap: 8px;
  margin: 28px 0 0;
  padding: 18px 22px;
  border: 1px solid rgba(5, 5, 5, .18);
  background: var(--soft);
  font-size: .96rem;
  line-height: 1.55;
}

.legal-banner strong { font-weight: 700; }

.legal-body {
  display: grid;
  gap: 20px;
  margin-top: clamp(38px, 6vw, 70px);
}

.legal-body p,
.legal-body li {
  margin: 0;
  color: #2b2a27;
  font-size: clamp(1rem, 1.15vw, 1.12rem);
  line-height: 1.7;
}

.legal-body h2 {
  margin: 26px 0 -2px;
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  line-height: 1.1;
  letter-spacing: -.02em;
}

.legal-body h3 {
  margin: 18px 0 -4px;
  font-size: clamp(1.1rem, 1.5vw, 1.35rem);
  line-height: 1.15;
  letter-spacing: -.015em;
}

.legal-body ul,
.legal-body ol {
  display: grid;
  gap: 8px;
  margin: 4px 0 0;
  padding-left: 22px;
}

.legal-body li::marker { color: var(--muted); }

.legal-body a {
  color: var(--black);
  border-bottom: 1px solid rgba(5, 5, 5, .35);
}

.legal-body a:hover { border-bottom-color: var(--black); }

.legal-body code {
  padding: 2px 6px;
  border: 1px solid rgba(5, 5, 5, .14);
  background: var(--white);
  font: 600 .92em/1.4 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.legal-body pre {
  overflow-x: auto;
  margin: 8px 0;
  padding: 18px 20px;
  border: 1px solid rgba(5, 5, 5, .14);
  background: var(--white);
  font: 500 .92rem/1.55 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.legal-body pre code {
  padding: 0;
  border: 0;
  background: transparent;
}

.legal-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 6px 0;
  font-size: .98rem;
}

.legal-body th,
.legal-body td {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(5, 5, 5, .14);
  text-align: left;
  vertical-align: top;
  line-height: 1.55;
}

.legal-body th {
  background: var(--soft);
  font-weight: 700;
}

.legal-body hr {
  margin: 24px 0;
  border: 0;
  border-top: 1px solid rgba(5, 5, 5, .18);
}

.legal-toc {
  display: grid;
  gap: 8px;
  margin: 12px 0 0;
  padding: 18px 22px;
  border: 1px solid rgba(5, 5, 5, .14);
  background: var(--white);
}

.legal-toc strong {
  display: block;
  margin-bottom: 6px;
  font: 700 .85rem/1.3 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}

.legal-toc a {
  font-size: .98rem;
  border-bottom: 0;
}

.legal-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  margin: 0;
  padding: 22px clamp(18px, 6vw, 72px);
  border-top: 1px solid rgba(5, 5, 5, .14);
  font-size: .92rem;
  color: var(--muted);
}

.legal-footer-links a {
  color: var(--muted);
  border-bottom: 1px solid transparent;
}

.legal-footer-links a:hover {
  color: var(--black);
  border-bottom-color: rgba(5, 5, 5, .35);
}
