/* ===== Legal page additions (kept separate from styles.css) ========== */

/* Layout helpers */
.legal-toc{
  max-width: 1100px;
  margin: 0 auto 2rem;
  display:flex; flex-wrap:wrap; gap:.6rem;
  padding: .8rem;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.legal-toc a{
  text-decoration:none;
  padding:.45rem .7rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  color: var(--text);
  background: rgba(255,255,255,.04);
}
.legal-toc a:hover{ border-color: var(--accent); box-shadow:0 0 0 2px rgba(0,255,224,.12) inset }

/* Prose block (legal content) -> capsule visuelle */
.legal.prose{
  max-width: 1100px;
  margin: 0 auto;
  padding: 1rem 1.2rem 0;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
}
.legal.prose p{ color: var(--muted); line-height: 1.6; margin: .7rem 0; }
.legal.prose a{ color: var(--text); text-decoration: underline; text-underline-offset: 3px; }
.legal.prose a:hover{ color: var(--accent); }

/* Section heads spacing */
.section .section-head{ margin-bottom: 1rem; }
.section .section-title{ margin: 0 0 .4rem; }

/* Reveal coherence */
.reveal{ opacity:0; transform:translateY(12px) scale(.98); transition:.5s ease }
.reveal.in{ opacity:1; transform:none }

/* Small screens */
@media (max-width: 700px){
  .legal-toc{ gap:.5rem; padding:.6rem; }
  .legal.prose{ padding: .8rem .9rem 0; }
}
