/* ==========================================================================
   Hush — Nocturne · legal pages (privacy + terms)
   ========================================================================== */

.legal { padding-block: clamp(2.5rem, 6vw, 4.5rem) clamp(3rem, 7vw, 5rem); }

.legal__header { max-width: 60ch; margin-bottom: clamp(2rem, 5vw, 3rem); }
.legal__header h1 { font-size: var(--step-3); font-weight: 500; margin-top: 0.8rem; }
.legal__header h1 em { font-family: var(--display); font-style: italic; font-weight: 300; }
.legal__updated { color: var(--haze-dim); font-size: var(--step--1); margin-top: 1rem; }

.legal__layout { display: grid; grid-template-columns: 220px 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start; }

/* Sticky table of contents */
.legal__toc { position: sticky; top: 100px; }
.legal__toc ol { list-style: none; margin: 0; padding: 0; counter-reset: toc; }
.legal__toc li { counter-increment: toc; margin-bottom: 0.7rem; }
.legal__toc a {
  display: flex; gap: 0.6rem;
  color: var(--haze); font-size: var(--step--1); font-weight: 600;
  transition: color 0.25s;
}
.legal__toc a::before { content: counter(toc, decimal-leading-zero); color: var(--haze-dim); font-family: var(--display); font-style: italic; }
.legal__toc a:hover { color: var(--moon); }

.legal__body { max-width: 68ch; }
.legal__body section { margin-bottom: 2.6rem; scroll-margin-top: 100px; }
.legal__body h2 { font-size: var(--step-2); font-weight: 500; margin-bottom: 0.9rem; }
.legal__body h3 { font-size: var(--step-1); font-weight: 600; margin: 1.6rem 0 0.6rem; }
.legal__body p { color: var(--haze); margin-bottom: 1rem; }
.legal__body ul { color: var(--haze); padding-left: 1.2rem; margin: 0 0 1rem; }
.legal__body li { margin-bottom: 0.5rem; }
.legal__body a { color: var(--glow); text-decoration: underline; text-underline-offset: 3px; }
.legal__body strong { color: var(--moon); font-weight: 600; }

.legal__note {
  border: 1px solid var(--ink-3);
  border-left: 3px solid var(--warm);
  background: var(--ink-2);
  border-radius: 12px;
  padding: 1.2rem 1.4rem;
  color: var(--haze);
  font-size: var(--step--1);
  margin-bottom: 2.6rem;
}

@media (max-width: 820px) {
  .legal__layout { grid-template-columns: 1fr; }
  .legal__toc { position: static; margin-bottom: 1rem; }
  .legal__toc ol { display: flex; flex-wrap: wrap; gap: 0.8rem 1.4rem; }
  .legal__toc li { margin: 0; }
}
