/* ═══════════════════════════════════════════════
   MORGAN STUDIO — legal.css
   Mentions légales + Politique de confidentialité
═══════════════════════════════════════════════ */

.legal-hero {
  display: flex;
  flex-direction: column;
  padding: 160px 40px 80px;
  max-width: var(--max-w); margin: 0 auto;
}
.legal-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--bleu-clair); margin-bottom: 24px;
}
.legal-badge::before { content: ''; width: 5px; height: 5px; background: var(--bleu-violet); border-radius: 50%; }
.legal-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3.5rem);
  line-height: 1.45; margin-bottom: 16px;
}
.legal-updated { font-size: .75rem; color: var(--gris); margin-top: 12px; }

.legal-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .75rem; color: var(--gris); margin-bottom: 40px; transition: color .3s;
}
.legal-back:hover { color: var(--bleu-clair); }
.legal-back svg { width: 14px; height: 14px; }

.legal-body {
  max-width: var(--max-w); margin: 0 auto;
  padding: 0 40px 120px;
  display: grid; grid-template-columns: 220px 1fr;
  gap: 60px; align-items: start;
}

/* Nav latérale */
.legal-nav { position: sticky; top: 100px; }
.legal-nav-title {
  font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--bleu-violet); margin-bottom: 16px;
}
.legal-nav a {
  display: block; font-size: .88rem; color: var(--gris); padding: 6px 0;
  border-left: 2px solid var(--gris-fin); padding-left: 14px;
  transition: color .3s, border-color .3s;
}
.legal-nav a:hover { color: var(--bleu-clair); border-color: var(--bleu-clair); }

/* Contenu */
.legal-section {
  margin-bottom: 60px; padding-bottom: 60px;
  border-bottom: 1px solid var(--gris-fin);
}
.legal-section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.legal-section-num {
  font-family: var(--font-display); font-size: .65rem; letter-spacing: .10em;
  color: var(--bleu-violet); margin-bottom: 10px; display: block;
}
.legal-section h2 {
  font-family: var(--font-display); font-size: 1.4rem; line-height: 1.4;
  color: var(--blanc); margin-bottom: 20px;
}
.legal-section p { font-size: .9rem; line-height: 1.7; color: var(--gris); margin-bottom: 14px; }
.legal-section p:last-child { margin-bottom: 0; }

.legal-info-block {
  background: rgba(91,91,214,.06); border: 1px solid rgba(91,91,214,.15);
  border-radius: 12px; padding: 24px 28px; margin: 20px 0;
}
.legal-info-block p { margin-bottom: 8px; }
.legal-info-block p:last-child { margin-bottom: 0; }
.legal-info-block strong { color: var(--bleu-clair); font-weight: 600; }

/* Placeholder visible */
.placeholder {
  background: rgba(255, 180, 0, .1);
  border: 1px dashed rgba(255, 180, 0, .3);
  border-radius: 4px; padding: 1px 8px; color: #ffb400;
  font-size: .85em; font-style: italic;
}

/* Tableaux (confidentialité) */
.data-table { width: 100%; border-collapse: collapse; margin: 20px 0; font-size: .88rem; }
.data-table th {
  text-align: left; padding: 10px 14px;
  background: rgba(91,91,214,.1); color: var(--bleu-clair);
  font-size: .68rem; letter-spacing: .18em; text-transform: uppercase;
  border-bottom: 1px solid rgba(91,91,214,.2);
}
.data-table td {
  padding: 12px 14px; color: var(--gris);
  border-bottom: 1px solid var(--gris-fin); vertical-align: top; line-height: 1.55;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: rgba(255,255,255,.02); }

@media (max-width: 768px) {
  .legal-hero { padding: 130px 32px 60px; text-align: center; align-items: center; }
  .legal-body { grid-template-columns: 1fr; padding: 0 32px 80px; gap: 40px; }
  .legal-nav { display: none; }
  .data-table { font-size: .88rem; }
  .legal-section { text-align: center; overflow-wrap: break-word; word-break: break-word; }
  .legal-section p { max-width: 100%; overflow-wrap: break-word; word-break: break-word; }
  .legal-section-num { text-align: center; }
  .legal-info-block { text-align: center; overflow-wrap: break-word; }
}