/* ============================================================
   FOC STUDIO — PAGES LÉGALES (confidentialité, mentions légales)
   ------------------------------------------------------------
   Pages de texte : lisibilité d'abord. Conteneur étroit, prose au
   line-height généreux, fond rose hérité du site. Le contenu n'est PAS
   masqué au scroll (pas de .reveal sur la prose) : il doit rester lisible
   et indexable même sans JS.
   ============================================================ */
.legal {
  padding: clamp(6rem, 10vw, 9rem) var(--gutter) var(--section-pad);
  color: var(--noir);
}

.legal-inner {
  max-width: 760px;
  margin: 0 auto;
}

/* En-tête de page */
.legal-head {
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
  padding-bottom: clamp(1.5rem, 3vw, 2rem);
  border-bottom: 2px solid var(--noir);
}

.legal-head .title-seo { color: var(--noir); }

.legal-title {
  color: var(--noir);
  margin-bottom: 0.75rem;
}

.legal-updated {
  font-family: var(--font-body);
  font-size: 0.9rem;
  color: rgba(10, 10, 10, 0.6);
}

/* ---------- PROSE ---------- */
.legal-prose {
  font-family: var(--font-body);
  font-size: 1.02rem;
  line-height: 1.65;
  color: rgba(10, 10, 10, 0.85);
}

.legal-prose > * + * { margin-top: 1.1rem; }

.legal-prose h2 {
  font-family: var(--font-title);
  font-weight: 700;
  font-size: clamp(1.4rem, 2.6vw, 1.9rem);
  text-transform: uppercase;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--noir);
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  margin-bottom: 0.25rem;
}

.legal-prose h3 {
  font-family: var(--font-title);
  font-weight: 700;
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--noir);
  margin-top: 1.75rem;
}

.legal-prose a {
  color: var(--noir);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
}
.legal-prose a:hover { color: var(--feu); }

.legal-prose ul {
  list-style: none;
  padding-left: 0;
}

.legal-prose li {
  position: relative;
  padding-left: 1.4rem;
  margin-top: 0.5rem;
}

.legal-prose li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--feu);
  font-weight: 700;
}

.legal-prose strong { font-weight: 700; color: var(--noir); }

/* Adresse / coordonnées en bloc */
.legal-prose address {
  font-style: normal;
  line-height: 1.6;
}

/* Petite mention atténuée (ex. « adresse communiquée sur demande »). */
.legal-prose .legal-fineprint {
  font-size: 0.85rem;
  color: rgba(10, 10, 10, 0.55);
  margin-top: 0.75rem;
}

/* ---------- TABLEAU DES COOKIES ---------- */
.legal-table-wrap {
  overflow-x: auto;
  margin: 1.5rem 0;
  -webkit-overflow-scrolling: touch;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  min-width: 480px;
}

.legal-table th,
.legal-table td {
  border: 1px solid rgba(10, 10, 10, 0.25);
  padding: 0.65rem 0.8rem;
  text-align: left;
  vertical-align: top;
}

.legal-table th {
  font-family: var(--font-title);
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.03em;
  background: rgba(10, 10, 10, 0.07);
}

/* ---------- PLACEHOLDER « À COMPLÉTER » ---------- */
/* Signale en évidence les infos factuelles que Janine doit remplir.
   Impossible à manquer en preview comme en prod. */
.legal-todo {
  background: var(--feu);
  color: var(--blanc);
  font-weight: 700;
  padding: 0.05em 0.45em;
  border-radius: 2px;
  text-transform: uppercase;
  font-size: 0.85em;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
