/* ═══════════════════════════════════════════════════════════════════════════
   SPOTVIB — Pages légales (CGU · Politique de confidentialité)
   Réutilise les tokens de styles.css. Mise en page lecture longue + sommaire.
   ═══════════════════════════════════════════════════════════════════════════ */

.legal-main {
  position: relative;
  padding: 76px 0 0;
  background: var(--bg);
  overflow: hidden;
}

/* ─── En-tête de page ─── */
.legal-hero {
  position: relative;
  background: var(--bg-alt);
  border-bottom: 1px solid var(--border);
  padding: clamp(48px, 7vw, 84px) 0 clamp(40px, 5vw, 58px);
  overflow: hidden;
}
.legal-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(58% 60% at 14% 6%, rgba(231,111,81,.10), transparent 70%),
    radial-gradient(52% 54% at 94% 100%, rgba(42,157,143,.10), transparent 72%);
}
.legal-hero .wrap { position: relative; z-index: 1; }
.legal-hero h1 {
  font-size: clamp(30px, 4.4vw, 50px); font-weight: 800; line-height: 1.06;
  letter-spacing: -.02em; color: var(--fg); margin: 12px 0 0; text-wrap: balance;
}
.legal-hero .legal-lead {
  color: var(--muted); font-size: clamp(16px, 1.4vw, 18px); line-height: 1.55;
  margin: 16px 0 0; max-width: 62ch;
}
.legal-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 16px; margin-top: 24px;
}
.legal-meta .chip {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; border: 1px solid var(--border); box-shadow: var(--shadow-sm);
  padding: 8px 14px; border-radius: var(--r-full);
  font-size: 13px; font-weight: 700; color: var(--navy);
}
.legal-meta .chip svg { width: 15px; height: 15px; stroke: var(--teal); flex: none; }
.legal-meta .chip strong { font-weight: 800; }

/* ─── Disposition : sommaire + corps ─── */
.legal-layout {
  display: grid;
  grid-template-columns: 244px minmax(0, 1fr);
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
  padding: clamp(44px, 5vw, 72px) 0 clamp(72px, 8vw, 110px);
}

/* ─── Sommaire collant ─── */
.legal-toc {
  position: sticky; top: 100px;
  align-self: start;
}
.legal-toc__label {
  font-size: 12px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase;
  color: var(--coral); margin: 0 0 14px; padding-left: 14px;
}
.legal-toc nav { display: flex; flex-direction: column; }
.legal-toc a {
  display: block; padding: 7px 14px; border-left: 2px solid var(--border);
  font-size: 13.5px; font-weight: 700; line-height: 1.3; color: var(--muted);
  transition: color .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.legal-toc a:hover { color: var(--coral); border-left-color: var(--coral-light); }
.legal-toc a.active { color: var(--coral-dark); border-left-color: var(--coral); background: rgba(231,111,81,.06); }

/* ─── Corps du document ─── */
.legal-doc { max-width: 760px; min-width: 0; }
.legal-doc > section { scroll-margin-top: 96px; }
.legal-doc > section + section {
  margin-top: 42px; padding-top: 40px; border-top: 1px solid var(--border);
}
.legal-doc h2 {
  display: flex; align-items: baseline; gap: 12px;
  font-size: clamp(21px, 2.4vw, 27px); font-weight: 800; line-height: 1.2;
  letter-spacing: -.015em; color: var(--fg); margin: 0 0 18px; text-wrap: balance;
}
.legal-doc h2 .legal-num {
  flex: none; font-size: 15px; font-weight: 800; color: var(--coral);
  background: rgba(231,111,81,.10); border-radius: var(--r-sm);
  padding: 4px 9px; line-height: 1; align-self: center; min-width: 30px; text-align: center;
}
.legal-doc h3 {
  font-size: 17px; font-weight: 800; color: var(--navy); margin: 28px 0 10px;
  letter-spacing: -.01em;
}
.legal-doc p { color: var(--fg-2); font-size: 16px; line-height: 1.72; margin: 0 0 16px; }
.legal-doc p:last-child { margin-bottom: 0; }
.legal-doc strong { font-weight: 800; color: var(--fg); }
.legal-doc em { font-style: italic; color: var(--muted); }
.legal-doc a.inline-link { color: var(--teal-dark); font-weight: 700; text-decoration: underline; text-decoration-color: rgba(42,157,143,.4); text-underline-offset: 2px; }
.legal-doc a.inline-link:hover { text-decoration-color: var(--teal); }

/* listes */
.legal-doc ul { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.legal-doc ul li {
  position: relative; padding-left: 26px; color: var(--fg-2); font-size: 16px; line-height: 1.6;
}
.legal-doc ul li::before {
  content: ""; position: absolute; left: 4px; top: 9px;
  width: 7px; height: 7px; border-radius: 2px; background: var(--coral); transform: rotate(45deg);
}
.legal-doc ul li strong { color: var(--fg); }

/* placeholders à compléter (BCE, dates) */
.legal-doc .todo {
  background: rgba(233,196,106,.22); color: #8A6A12; font-weight: 700;
  padding: 1px 7px; border-radius: 5px; font-size: .92em; white-space: nowrap;
}

/* tableaux */
.legal-table-wrap { margin: 0 0 18px; overflow-x: auto; border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-sm); }
.legal-doc table { width: 100%; border-collapse: collapse; font-size: 14.5px; min-width: 460px; }
.legal-doc thead th {
  background: var(--navy); color: #fff; font-weight: 800; text-align: left;
  padding: 13px 16px; font-size: 13px; letter-spacing: .01em; white-space: nowrap;
}
.legal-doc thead th:first-child { border-top-left-radius: 0; }
.legal-doc tbody td { padding: 12px 16px; border-top: 1px solid var(--border); color: var(--fg-2); line-height: 1.5; vertical-align: top; }
.legal-doc tbody tr:nth-child(even) { background: var(--bg-alt); }
.legal-doc tbody td:first-child { font-weight: 700; color: var(--fg); }

/* encart "contact / adresse" */
.legal-callout {
  background: #fff; border: 1px solid var(--border); border-left: 4px solid var(--teal);
  border-radius: var(--r-md); box-shadow: var(--shadow-sm);
  padding: 20px 22px; margin: 0 0 18px;
}
.legal-callout p { margin: 0 0 6px; font-size: 15.5px; line-height: 1.6; }
.legal-callout p:last-child { margin-bottom: 0; }
.legal-callout .legal-callout__name { font-weight: 800; color: var(--fg); font-size: 16.5px; }

/* note de bas de section discrète */
.legal-doc .legal-aside {
  font-style: italic; color: var(--muted); font-size: 14.5px; line-height: 1.6;
  border-left: 3px solid var(--border); padding-left: 16px; margin: 0 0 16px;
}

/* lien retour + entre pages légales */
.legal-foot-links {
  display: flex; flex-wrap: wrap; gap: 14px; align-items: center;
  margin-top: 46px; padding-top: 28px; border-top: 1px solid var(--border);
}
.legal-foot-links a {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14.5px; font-weight: 800; color: var(--coral-dark);
}
.legal-foot-links a svg { width: 16px; height: 16px; }
.legal-foot-links a:hover { color: var(--coral); }
.legal-foot-links .sep { color: var(--border); }

@media (max-width: 880px) {
  .legal-layout { grid-template-columns: 1fr; gap: 0; }
  .legal-toc { display: none; }
}
@media (max-width: 560px) {
  .legal-doc h2 { gap: 9px; }
}
