/* ═══════════════════════════════════════════════════
   POLYZEA · legal.css
   Styles partagés — CGU, Confidentialité, Cookies
═══════════════════════════════════════════════════ */

:root {
  --bg:           #FFFDF8;
  --primary:      #14B8A6;
  --primary-deep: #0EA5A4;
  --primary-10:   rgba(20,184,166,0.10);
  --primary-05:   rgba(20,184,166,0.05);
  --accent:       #84CC16;
  --accent-10:    rgba(132,204,22,0.12);
  --orange:       #FB923C;
  --orange-10:    rgba(251,146,60,0.12);
  --text:         #1F2937;
  --text-sec:     #6B7280;
  --text-light:   #9CA3AF;
  --border:       rgba(20,184,166,0.14);
  --shadow-sm:    0 2px 12px rgba(20,184,166,0.07);
  --shadow-md:    0 8px 32px rgba(20,184,166,0.12);
  --radius-sm:    14px;
  --radius-md:    22px;
  --radius-lg:    32px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'DM Sans', system-ui, sans-serif;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.7;
}
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Fond hexagones ────────────────────────────────── */
.hex-bg {
  position: fixed; inset: 0;
  pointer-events: none; z-index: 0; opacity: 0.7;
}

/* ── Page layout ───────────────────────────────────── */
.page {
  position: relative; z-index: 1;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1.5rem 4rem;
}

/* ═══════════════════════════════════════════════════
   NAVIGATION LÉGALE
═══════════════════════════════════════════════════ */
.legal-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.8rem;
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2.5rem;
  position: sticky; top: 0;
  background: rgba(255,253,248,0.92);
  backdrop-filter: blur(12px);
  z-index: 50;
}

.legal-nav__back {
  font-size: 0.85rem; font-weight: 500; color: var(--text-sec);
  display: inline-flex; align-items: center; gap: 0.3rem;
  padding: 0.35rem 0.9rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: all 0.2s;
}
.legal-nav__back:hover {
  color: var(--primary); border-color: var(--primary);
  background: var(--primary-05); text-decoration: none;
}

.legal-nav__links {
  display: flex; gap: 0.3rem;
}
.legal-nav__link {
  font-size: 0.82rem; font-weight: 500; color: var(--text-sec);
  padding: 0.35rem 0.9rem;
  border-radius: 999px;
  transition: all 0.2s;
}
.legal-nav__link:hover { background: var(--primary-05); color: var(--primary); text-decoration: none; }
.legal-nav__link--active {
  background: var(--primary-10); color: var(--primary); font-weight: 600;
}

/* ═══════════════════════════════════════════════════
   EN-TÊTE DOCUMENT
═══════════════════════════════════════════════════ */
.legal-header {
  margin-bottom: 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--border);
}

.legal-header__badge {
  display: inline-block;
  font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--primary-deep);
  background: var(--primary-10);
  padding: 0.28rem 0.9rem; border-radius: 999px;
  border: 1px solid var(--border);
  margin-bottom: 1rem;
}

.legal-header__title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 900; color: var(--text);
  line-height: 1.15; margin-bottom: 0.8rem;
}

.legal-header__meta {
  font-size: 0.82rem; color: var(--text-light);
  margin-bottom: 1rem;
}

.legal-header__intro {
  font-size: 1rem; color: var(--text-sec);
  max-width: 680px; line-height: 1.6;
}

.legal-header__warning {
  margin-top: 1rem;
  padding: 1rem 1.3rem;
  background: var(--orange-10);
  border: 1px solid rgba(251,146,60,0.25);
  border-radius: var(--radius-sm);
  font-size: 0.88rem; color: #92400e;
  line-height: 1.5;
}

/* ═══════════════════════════════════════════════════
   SOMMAIRE
═══════════════════════════════════════════════════ */
.toc {
  background: rgba(255,255,255,0.72);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1.4rem 1.8rem;
  margin-bottom: 2.5rem;
  box-shadow: var(--shadow-sm);
}

.toc__title {
  font-family: var(--font-display);
  font-size: 0.95rem; font-weight: 700; color: var(--text);
  margin-bottom: 0.8rem;
  text-transform: uppercase; letter-spacing: 0.05em;
}

.toc__list {
  list-style: none; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.3rem;
  counter-reset: toc-counter;
}

.toc__list li { counter-increment: toc-counter; }

.toc__list a {
  font-size: 0.85rem; color: var(--text-sec); font-weight: 500;
  display: block; padding: 0.3rem 0.5rem;
  border-radius: var(--radius-sm);
  transition: all 0.18s;
}
.toc__list a:hover { background: var(--primary-05); color: var(--primary); text-decoration: none; }
.toc__link--active { background: var(--primary-05) !important; color: var(--primary) !important; }

/* ═══════════════════════════════════════════════════
   CORPS DU DOCUMENT
═══════════════════════════════════════════════════ */
.legal-body {
  display: flex; flex-direction: column; gap: 0;
}

.legal-section {
  padding: 2rem 0;
  border-bottom: 1px solid var(--border);
}
.legal-section:last-child { border-bottom: none; }

.legal-section__title {
  font-family: var(--font-display);
  font-size: 1.35rem; font-weight: 700; color: var(--text);
  margin-bottom: 1rem;
  display: flex; align-items: center; gap: 0.8rem;
}

.art-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; flex-shrink: 0;
  background: var(--primary-10);
  border: 1.5px solid rgba(20,184,166,0.25);
  border-radius: 50%;
  font-size: 0.85rem; font-weight: 700; color: var(--primary);
  font-family: var(--font-body);
}

.legal-section__sub {
  font-size: 1rem; font-weight: 700; color: var(--primary-deep);
  margin: 1.4rem 0 0.6rem;
}

.legal-section p {
  font-size: 0.92rem; color: var(--text-sec);
  margin-bottom: 0.75rem; line-height: 1.7;
}
.legal-section p:last-child { margin-bottom: 0; }

/* ── Listes ────────────────────────────────────────── */
.legal-list {
  list-style: none; padding: 0;
  margin: 0.5rem 0 0.8rem;
  display: flex; flex-direction: column; gap: 0.45rem;
}
.legal-list li {
  font-size: 0.9rem; color: var(--text-sec);
  padding-left: 1.4rem; position: relative;
  line-height: 1.6;
}
.legal-list li::before {
  content: '→';
  position: absolute; left: 0;
  color: var(--primary); font-weight: 700;
}

/* ── Highlights ────────────────────────────────────── */
.legal-highlight {
  padding: 1rem 1.3rem;
  border-radius: var(--radius-sm);
  font-size: 0.88rem; line-height: 1.6;
  margin: 1rem 0;
}
.legal-highlight--teal {
  background: var(--primary-05);
  border: 1px solid rgba(20,184,166,0.2);
  color: #134e4a;
}
.legal-highlight--orange {
  background: var(--orange-10);
  border: 1px solid rgba(251,146,60,0.25);
  color: #92400e;
}
.legal-highlight--green {
  background: var(--accent-10);
  border: 1px solid rgba(132,204,22,0.25);
  color: #365314;
}

/* ── Tableaux ──────────────────────────────────────── */
.legal-table-wrap {
  overflow-x: auto; margin: 1rem 0;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}
.legal-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.85rem;
}
.legal-table thead tr {
  background: var(--primary-10);
}
.legal-table th {
  padding: 0.75rem 1rem;
  text-align: left; font-weight: 700;
  color: var(--primary-deep);
  font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em;
  border-bottom: 1px solid var(--border);
}
.legal-table td {
  padding: 0.7rem 1rem;
  color: var(--text-sec);
  border-bottom: 1px solid rgba(20,184,166,0.07);
  line-height: 1.5;
}
.legal-table tr:last-child td { border-bottom: none; }
.legal-table tr:hover td { background: var(--primary-05); }

/* ── Cards grille ──────────────────────────────────── */
.legal-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem; margin: 1rem 0;
}
.legal-card {
  padding: 1.2rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.72);
}
.legal-card--teal  { border-top: 3px solid var(--primary); }
.legal-card--green { border-top: 3px solid var(--accent);  }
.legal-card--orange{ border-top: 3px solid var(--orange);  }

.legal-card__icon { font-size: 1.6rem; margin-bottom: 0.5rem; }
.legal-card h4 {
  font-size: 0.88rem; font-weight: 700; color: var(--text);
  margin-bottom: 0.4rem;
}
.legal-card p { font-size: 0.8rem; color: var(--text-sec); line-height: 1.5; }

/* ═══════════════════════════════════════════════════
   GESTION COOKIES (page cookies.html)
═══════════════════════════════════════════════════ */
.cookie-prefs-box {
  background: rgba(255,255,255,0.78);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1.5rem;
  margin: 1.2rem 0;
  box-shadow: var(--shadow-sm);
}
.cookie-prefs-box h3 {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 700; color: var(--text);
  margin-bottom: 1.2rem;
}
.cookie-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: 0.9rem 0;
  border-bottom: 1px solid var(--border);
}
.cookie-toggle-row:last-of-type { border-bottom: none; margin-bottom: 1rem; }
.cookie-toggle-info { flex: 1; }
.cookie-toggle-info strong { display: block; font-size: 0.9rem; color: var(--text); }
.cookie-toggle-info span  { font-size: 0.78rem; color: var(--text-sec); }
.cookie-toggle--forced {
  font-size: 0.72rem; font-weight: 600; color: #3d6b00;
  background: var(--accent-10); padding: 0.25rem 0.8rem;
  border-radius: 999px; border: 1px solid rgba(132,204,22,0.25);
  white-space: nowrap;
}

/* Toggle switch */
.toggle-switch {
  position: relative; display: inline-block;
  width: 46px; height: 26px; flex-shrink: 0;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0; cursor: pointer;
  background: rgba(107,114,128,0.3); border-radius: 999px;
  transition: 0.28s;
}
.toggle-slider::before {
  content: ''; position: absolute;
  width: 20px; height: 20px; border-radius: 50%;
  left: 3px; top: 3px;
  background: white; box-shadow: 0 1px 4px rgba(0,0,0,0.2);
  transition: 0.28s;
}
.toggle-switch input:checked + .toggle-slider { background: var(--primary); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); }

.btn-save-prefs {
  background: var(--primary); color: white; border: none;
  padding: 0.75rem 1.6rem; border-radius: 999px;
  font-family: var(--font-body); font-weight: 600; font-size: 0.9rem;
  cursor: pointer; transition: all 0.22s;
  box-shadow: 0 4px 16px rgba(20,184,166,0.25);
}
.btn-save-prefs:hover { background: var(--primary-deep); transform: translateY(-2px); }

/* ═══════════════════════════════════════════════════
   FOOTER LÉGAL
═══════════════════════════════════════════════════ */
.legal-footer {
  margin-top: 3rem; padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  display: flex; flex-direction: column; align-items: center; gap: 0.8rem;
  text-align: center;
}
.legal-footer__links {
  display: flex; flex-wrap: wrap; gap: 0.3rem; justify-content: center;
}
.legal-footer__links a {
  font-size: 0.8rem; color: var(--text-sec); font-weight: 500;
  padding: 0.28rem 0.75rem; border-radius: 999px;
  transition: all 0.18s;
}
.legal-footer__links a:hover { background: var(--primary-05); color: var(--primary); text-decoration: none; }
.legal-footer__copy { font-size: 0.72rem; color: var(--text-light); }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media (max-width: 640px) {
  .page { padding: 0 1rem 3rem; }
  .legal-header__title { font-size: 1.6rem; }
  .legal-nav { padding: 0.9rem 0; }
  .legal-nav__links { gap: 0.2rem; }
  .legal-card-grid { grid-template-columns: 1fr; }
  .toc__list { grid-template-columns: 1fr; }
  .cookie-toggle-row { flex-direction: column; align-items: flex-start; gap: 0.6rem; }
}