/* ============================================================
   Thought Pattern AI - Legal pages (Terms / Privacy / Security)
   Shared long-form legal layout. Chrome is in site.css.
   ============================================================ */

.legal {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(48px, 8vw, 96px) var(--tp-space-8) clamp(56px, 9vw, 120px);
}

/* -------- Header ----------------------------------------- */
.legal-head {
  border-bottom: 1px solid var(--tp-border);
  padding-bottom: var(--tp-space-8);
  margin-bottom: var(--tp-space-8);
}
.legal-title {
  font-family: var(--tp-font-display);
  font-weight: var(--tp-fw-regular);
  letter-spacing: var(--tp-ls-display);
  font-size: clamp(2.5rem, 6vw, 4rem);
  line-height: 1;
  text-transform: uppercase;
  color: var(--tp-fg);
  margin: 0 0 var(--tp-space-4);
}
.legal-meta {
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: 0.05em;
  color: var(--tp-fg-muted);
  margin: 0;
  line-height: 1.9;
}
.legal-meta .entity { color: var(--tp-fg); }
.legal-intro {
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-md);
  line-height: var(--tp-lh-body);
  color: var(--tp-fg-body);
  margin: var(--tp-space-6) 0 0;
}

/* -------- Table of contents ------------------------------ */
.legal-toc {
  background: var(--tp-bg-surface);
  border: 1px solid var(--tp-border);
  border-radius: var(--tp-radius-md);
  padding: var(--tp-space-6) var(--tp-space-8);
  margin-bottom: var(--tp-space-10);
}
.legal-toc h2 {
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: var(--tp-ls-caps);
  text-transform: uppercase;
  color: var(--tp-fg-muted);
  margin: 0 0 var(--tp-space-4);
}
.legal-toc ol {
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: toc;
  columns: 2;
  column-gap: var(--tp-space-8);
}
.legal-toc li { counter-increment: toc; margin-bottom: var(--tp-space-2); break-inside: avoid; }
.legal-toc a {
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-base);
  color: var(--tp-fg-body);
  text-decoration: none;
}
.legal-toc a::before {
  content: counter(toc, decimal-leading-zero) "  ";
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  color: var(--tp-yellow-deep);
}
.legal-toc a:hover { color: var(--tp-yellow); }

/* -------- Body ------------------------------------------- */
.legal-body > section {
  padding-top: var(--tp-space-9);
  scroll-margin-top: 88px;
}
.legal-body > section:first-child { padding-top: 0; }

.legal-num {
  display: block;
  font-family: var(--tp-font-mono);
  font-size: var(--tp-fs-xs);
  letter-spacing: var(--tp-ls-caps);
  text-transform: uppercase;
  color: var(--tp-yellow-deep);
  margin: 0 0 var(--tp-space-3);
}
.legal-body h2 {
  font-family: var(--tp-font-serif);
  font-weight: var(--tp-fw-semi);
  font-size: clamp(1.4rem, 3vw, 1.7rem);
  line-height: var(--tp-lh-snug);
  color: var(--tp-fg);
  margin: 0 0 var(--tp-space-4);
}
.legal-body h3 {
  font-family: var(--tp-font-serif);
  font-weight: var(--tp-fw-semi);
  font-size: var(--tp-fs-lg);
  color: var(--tp-fg);
  margin: var(--tp-space-6) 0 var(--tp-space-3);
}
.legal-body p {
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-md);
  line-height: var(--tp-lh-body);
  color: var(--tp-fg-muted);
  margin: 0 0 var(--tp-space-4);
}
.legal-body p strong { color: var(--tp-fg); font-weight: var(--tp-fw-semi); }
.legal-body a { color: var(--tp-yellow); text-decoration: none; }
.legal-body a:hover { color: var(--tp-yellow-hi); }

.legal-body ul {
  list-style: none;
  margin: 0 0 var(--tp-space-4);
  padding: 0;
}
.legal-body li {
  position: relative;
  font-family: var(--tp-font-serif);
  font-size: var(--tp-fs-md);
  line-height: var(--tp-lh-body);
  color: var(--tp-fg-muted);
  padding-left: var(--tp-space-6);
  margin-bottom: var(--tp-space-3);
}
.legal-body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 12px;
  height: 1px;
  background: var(--tp-rule);
}
.legal-body li strong { color: var(--tp-fg); font-weight: var(--tp-fw-semi); }

/* -------- Responsive ------------------------------------- */
@media (max-width: 640px) {
  .legal-toc ol { columns: 1; }
}
@media (max-width: 560px) {
  .legal { padding-left: var(--tp-space-5); padding-right: var(--tp-space-5); }
  .legal-toc { padding-left: var(--tp-space-5); padding-right: var(--tp-space-5); }
}
