/* Legal pages (privacy policy, terms). Tokens + primitives live in site.css. */

/* -----------------------------------------------------------------------------
   Hero
-------------------------------------------------------------------------------*/

.legal-hero {
  padding: 64px 0 40px;
  text-align: center;
}

.legal-hero__inner {
  max-width: 720px;
  margin: 0 auto;
  display: grid;
  gap: var(--space-xl);
}

.legal-hero h1 {
  margin: 0;
  font: var(--font-display);
  letter-spacing: -0.025em;
  color: var(--text-primary);
}

.legal-hero__meta {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm) var(--space-md);
  margin: 0 auto;
  font-family: var(--font-mono);
  font-feature-settings: 'tnum','lnum','zero';
  font-size: 13px;
  line-height: 18px;
  color: var(--text-tertiary);
}
.legal-hero__meta .sep { color: var(--text-quaternary); }

.legal-hero__lede {
  margin: 0 auto;
  max-width: 600px;
  color: var(--text-secondary);
  font: var(--font-body);
}

@media (min-width: 768px) {
  .legal-hero h1 { font-size: 48px; line-height: 52px; }
}
@media (min-width: 1024px) {
  .legal-hero h1 { font-size: 56px; line-height: 60px; }
}

/* -----------------------------------------------------------------------------
   Layout — TOC sidebar + content
-------------------------------------------------------------------------------*/

.legal {
  padding-top: var(--space-2xl);
  padding-bottom: 80px;
}

.legal__layout {
  display: grid;
  gap: 40px;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 1024px) {
  .legal__layout {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 48px;
  }
}

/* -----------------------------------------------------------------------------
   Table of contents
-------------------------------------------------------------------------------*/

.legal-toc {
  padding: var(--space-xl);
  font: var(--font-body-sm);
}

.legal-toc__title {
  margin: 0 0 var(--space-md);
  font: var(--font-overline);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.legal-toc ol {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: toc;
  display: grid;
  gap: 2px;
}
.legal-toc li { counter-increment: toc; }

.legal-toc a {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--space-sm);
  align-items: baseline;
  padding: var(--space-sm) var(--space-sm);
  border-radius: 10px;
  color: var(--text-secondary);
  font: 400 14px/20px 'DM Sans', system-ui, sans-serif;
  transition: background 120ms ease, color 120ms ease;
}
.legal-toc a::before {
  content: counter(toc);
  font-family: var(--font-mono);
  font-feature-settings: 'tnum','lnum','zero';
  font-size: 12px;
  color: var(--text-quaternary);
  text-align: right;
}
.legal-toc a:hover {
  color: var(--text-primary);
  background: color-mix(in srgb, var(--raised) 60%, transparent);
}

@media (min-width: 1024px) {
  .legal-toc {
    position: sticky;
    top: 96px;
    max-height: calc(100vh - 120px);
    overflow-y: auto;
  }
}

/* The inline Contents panel duplicates what's in the mobile nav menu on narrow
   screens, so hide it there and let the hamburger panel carry navigation. */
@media (max-width: 767px) {
  .legal-toc { display: none; }
}

/* -----------------------------------------------------------------------------
   Document body
-------------------------------------------------------------------------------*/

.legal-doc {
  max-width: 760px;
  min-width: 0;
  color: var(--text-secondary);
  font: var(--font-body);
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;
}

.legal-doc > section + section {
  margin-top: 48px;
}

.legal-doc h2 {
  margin: 0 0 var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--hairline);
  font: var(--font-h1);
  letter-spacing: -0.02em;
  color: var(--text-primary);
  scroll-margin-top: 96px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-md);
  align-items: baseline;
}
.legal-doc h2 .legal-doc__num {
  font-family: var(--font-mono);
  font-feature-settings: 'tnum','lnum','zero';
  font-size: 18px;
  line-height: 1;
  font-weight: 500;
  color: var(--brand-orange);
  letter-spacing: 0;
}
@media (min-width: 768px) {
  .legal-doc h2 { font-size: 32px; line-height: 38px; }
  .legal-doc h2 .legal-doc__num { font-size: 20px; }
}

.legal-doc h3 {
  margin: 32px 0 var(--space-md);
  font: var(--font-h3);
  letter-spacing: -0.01em;
  color: var(--text-primary);
  scroll-margin-top: 96px;
}

.legal-doc p {
  margin: 0 0 var(--space-lg);
}
.legal-doc p:last-child { margin-bottom: 0; }

.legal-doc strong { color: var(--text-primary); font-weight: 600; }
.legal-doc em { color: var(--text-primary); font-style: italic; }

.legal-doc a {
  color: var(--text-primary);
  text-decoration: underline;
  text-decoration-color: var(--hairline-strong);
  text-underline-offset: 3px;
  transition: color 120ms ease, text-decoration-color 120ms ease;
}
.legal-doc a:hover {
  color: var(--brand-orange);
  text-decoration-color: var(--brand-orange);
}

.legal-doc ul {
  margin: 0 0 var(--space-lg);
  padding-left: var(--space-xl);
  display: grid;
  gap: var(--space-sm);
}
.legal-doc ul li::marker { color: var(--brand-orange); }

.legal-doc code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  padding: 0 6px;
  border-radius: 6px;
  background: color-mix(in srgb, var(--raised) 70%, transparent);
  color: var(--text-primary);
  border: 1px solid var(--hairline);
}

/* Callout — used for addresses and representative blocks */
.legal-doc blockquote {
  margin: var(--space-lg) 0;
  padding: var(--space-lg) var(--space-xl);
  border-left: 2px solid var(--brand-orange);
  background: color-mix(in srgb, var(--raised) 40%, transparent);
  border-radius: 0 var(--radius-card) var(--radius-card) 0;
  color: var(--text-primary);
  font: var(--font-body-sm);
}
.legal-doc blockquote p { margin: 0 0 var(--space-xs); }
.legal-doc blockquote p:last-child { margin-bottom: 0; }
.legal-doc blockquote strong { color: var(--text-primary); }

/* Section dividers between numbered sections are handled via section spacing;
   no <hr> needed. */

/* -----------------------------------------------------------------------------
   Tables — responsive, accessible
-------------------------------------------------------------------------------*/

.legal-doc__table-wrap {
  margin: var(--space-xl) 0;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-card);
  background: color-mix(in srgb, var(--surface) 60%, transparent);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.legal-doc table {
  width: 100%;
  min-width: 560px;
  border-collapse: collapse;
  font: var(--font-body-sm);
  color: var(--text-secondary);
}

.legal-doc thead th {
  text-align: left;
  padding: var(--space-md) var(--space-lg);
  background: color-mix(in srgb, var(--raised) 50%, transparent);
  border-bottom: 1px solid var(--hairline);
  font: var(--font-overline);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  white-space: nowrap;
}

.legal-doc tbody td {
  padding: var(--space-lg);
  border-bottom: 1px solid var(--hairline);
  vertical-align: top;
}
.legal-doc tbody tr:last-child td { border-bottom: 0; }
.legal-doc tbody td strong { color: var(--text-primary); }

/* -----------------------------------------------------------------------------
   Back-to-top affordance
-------------------------------------------------------------------------------*/

.legal-doc__back-top {
  margin-top: 48px;
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--hairline);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
  font: var(--font-caption);
  color: var(--text-tertiary);
}
.legal-doc__back-top a {
  color: var(--text-secondary);
  text-decoration: none;
}
.legal-doc__back-top a:hover { color: var(--brand-orange); }
