/* ============================================
   PAGES LÉGALES (Mentions légales + Politique RGPD)
   --------------------------------------------
   Layout sobre : container narrow + sections texte
   avec définition lists pour les champs structurés.
   ============================================ */

.legal-container {
  max-width: 760px;
}

.legal-block {
  padding-block: var(--space-7);
  border-bottom: 1px solid var(--color-border);
}

.legal-block:first-child {
  padding-top: 0;
}

.legal-block:last-child {
  border-bottom: none;
}

.legal-block__title {
  font-family:    var(--font-display);
  font-size:      clamp(1.5rem, 3vw, var(--fs-2xl));
  font-weight:    var(--fw-bold);
  line-height:    var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  color:          var(--color-iroise-blue);
  margin:         0 0 var(--space-5);
}

.legal-prose {
  font-size:   var(--fs-md);
  line-height: var(--lh-relaxed);
  color:       var(--color-text);
  margin:      0 0 var(--space-4);
  max-width:   62ch;
}

.legal-prose:last-child {
  margin-bottom: 0;
}

.legal-prose a {
  color:           var(--color-iroise-blue);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.legal-prose a:hover,
.legal-prose a:focus-visible {
  color: var(--color-iroise-cyan);
}

.legal-block ul.legal-prose {
  padding-left: 1.25rem;
}

.legal-block ul.legal-prose li {
  margin-bottom: var(--space-2);
}

/* Définition list — structurée clé / valeur */
.legal-meta {
  margin: 0;
  display: grid;
  gap: var(--space-3);
}

.legal-meta__row {
  display:               grid;
  grid-template-columns: 1fr;
  gap:                   var(--space-1);
  padding-block:         var(--space-3);
  border-bottom:         1px solid var(--color-border-light, rgba(0,0,0,0.06));
}

.legal-meta__row:last-child {
  border-bottom: none;
}

@media (min-width: 600px) {
  .legal-meta__row {
    grid-template-columns: minmax(180px, 32%) 1fr;
    gap:                   var(--space-5);
    align-items:           baseline;
  }
}

.legal-meta dt {
  font-family:    var(--font-mono);
  font-size:      var(--fs-xs);
  font-weight:    var(--fw-medium);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color:          var(--color-text-muted);
  margin:         0;
}

.legal-meta dd {
  margin:       0;
  font-size:    var(--fs-md);
  line-height:  var(--lh-normal);
  color:        var(--color-text);
}

.legal-meta dd a {
  color:           var(--color-iroise-blue);
  text-decoration: none;
}

.legal-meta dd a:hover,
.legal-meta dd a:focus-visible {
  text-decoration: underline;
}

/* Note méta : "Dernière mise à jour" en pied de page */
.legal-updated {
  margin-top:   var(--space-7);
  padding-top:  var(--space-5);
  border-top:   1px solid var(--color-border);
  font-family:  var(--font-mono);
  font-size:    var(--fs-xs);
  color:        var(--color-text-muted);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}
