/* Legal pages — prose overrides only. Nav, footer, body, tokens, fonts all come from /style.css */

.legal-container {
  position: relative; z-index: 1;
  max-width: 780px;
  margin: calc(var(--nav-h) + 3rem) auto 6rem;
  padding: 0 1.5rem;
  font-size: .975rem;
  line-height: 1.75;
  color: var(--fg-2);
}

/* Headings — use the site display font */
.legal-container h1 {
  font-family: var(--ff-display);
  font-size: clamp(1.9rem, 4.5vw, 2.8rem);
  font-weight: 700;
  color: var(--fg-1);
  line-height: 1.1;
  letter-spacing: -.02em;
  margin-bottom: .6em;
}
.legal-container h2 {
  font-family: var(--ff-display);
  font-size: clamp(1.25rem, 2.5vw, 1.55rem);
  font-weight: 600;
  color: var(--fg-1);
  line-height: 1.25;
  letter-spacing: -.01em;
  margin-top: 3em; margin-bottom: .6em;
  padding-bottom: .5em;
  border-bottom: 1px solid var(--border);
}
.legal-container h3 {
  font-family: var(--ff-display);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--fg-1);
  margin-top: 2em; margin-bottom: .4em;
}
.legal-container h4 {
  font-family: var(--ff-body);
  font-size: .95rem;
  font-weight: 500;
  color: var(--fg-2);
  margin-top: 1.5em; margin-bottom: .3em;
}

/* Body prose */
.legal-container p { margin-bottom: 1em; }
.legal-container strong { color: var(--fg-1); font-weight: 500; }
.legal-container em { color: var(--fg-3); font-style: italic; }

.legal-container ul,
.legal-container ol {
  padding-left: 1.5rem;
  margin-bottom: 1em;
}
.legal-container li { margin-bottom: .5em; }
.legal-container li > p { margin-bottom: .4em; }

.legal-container a {
  color: var(--brand-hi);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: opacity var(--dur-base);
}
.legal-container a:hover { opacity: .75; }

.legal-container hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: 2.5em 0;
}

.legal-container blockquote {
  border-left: 2px solid var(--brand);
  margin: 1.5em 0;
  padding: .75em 1.25em;
  background: var(--brand-dim);
  border-radius: 0 8px 8px 0;
  color: var(--fg-2);
}
.legal-container blockquote p { margin-bottom: 0; }

.legal-container code {
  font-family: var(--ff-mono);
  font-size: .875em;
  background: rgba(255, 255, 255, 0.05);
  padding: .15em .4em;
  border-radius: 4px;
  color: var(--fg-1);
}
.legal-container pre {
  font-family: var(--ff-mono);
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1.1rem 1.25rem;
  overflow-x: auto;
  margin: 1.5em 0;
  font-size: .875rem;
  line-height: 1.6;
}
.legal-container pre code { background: none; padding: 0; color: var(--fg-2); }

.legal-container img {
  max-width: 100%;
  border-radius: 10px;
  border: 1px solid var(--border);
  margin: 1.75em 0;
  display: block;
}

.legal-container table {
  width: 100%; border-collapse: collapse;
  margin: 1.75em 0; font-size: .9rem;
  border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
}
.legal-container th {
  text-align: left; padding: .7em 1em;
  background: var(--surface);
  color: var(--fg-1); font-weight: 500;
  border-bottom: 1px solid var(--border);
}
.legal-container td {
  padding: .7em 1em;
  border-bottom: 1px solid var(--border);
  color: var(--fg-2);
}
.legal-container tr:last-child td { border-bottom: none; }
.legal-container tr:hover td { background: rgba(255, 255, 255, 0.015); }

@media (max-width: 768px) {
  .legal-container {
    margin-top: calc(var(--nav-h) + 2rem);
    padding: 0 1.25rem;
  }
}
