/* =============================================================
   LECOINGAMING — pages/legal.css
   CSS partagé pour toutes les pages informationnelles :
     mentions légales, CGV, politique confidentialité,
     contact, à propos, paiements & sécurité, FAQ.
   Chargé via info_page.html — un seul fichier pour toutes.
   Mobile-first. Tokens uniquement.
   ============================================================= */


/* -----------------------------------------------------------
   PAGE — wrapper commun
----------------------------------------------------------- */
.info-page {
  max-inline-size: 820px;
  margin-inline: auto;
  padding: var(--space-7) var(--space-4) var(--space-8);
}

@media (min-width: 768px) {
  .info-page {
    padding: var(--space-8) var(--space-5);
  }
}


/* -----------------------------------------------------------
   LAYOUT DEUX COLONNES — disponible pour pages with sidebar
   Usage : <section class="info-page info-page--with-nav">
----------------------------------------------------------- */
@media (min-width: 1024px) {
  .info-page--with-nav {
    max-inline-size: 1100px;
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: var(--space-8);
    align-items: start;
  }
}


/* -----------------------------------------------------------
   HEADER DE PAGE — titre principal + meta
----------------------------------------------------------- */
.legal-header {
  margin-bottom: var(--space-7);
  padding-bottom: var(--space-6);
  border-bottom: 2px solid var(--gold-dark);
}

.legal-header h1 {
  font-family: var(--font-display), sans-serif;
  font-size: clamp(26px, 3.5vw, 40px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--text-dark);
  margin-bottom: var(--space-3);
}

.legal-meta {
  font-family: var(--font-mono), monospace;
  font-size: var(--font-xs);
  color: var(--text-muted);
}


/* -----------------------------------------------------------
   PROSE — contenu éditorial des pages légales
   S'applique aux blocs h2/p/ul/li injectés via les *_content.html
----------------------------------------------------------- */
.info-page h1 {
  font-family: var(--font-display), sans-serif;
  font-size: clamp(26px, 3.5vw, 40px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--text-dark);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 2px solid var(--gold-dark);
}

.info-page h2 {
  font-family: var(--font-display), sans-serif;
  font-size: var(--font-xl);
  font-weight: 700;
  color: var(--text-dark);
  letter-spacing: -0.01em;
  margin-top: var(--space-7);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: var(--border-light);
}

/* Premier h2 — pas de margin-top */
.info-page h2:first-of-type {
  margin-top: 0;
}

.info-page h3 {
  font-family: var(--font-display), sans-serif;
  font-size: var(--font-lg);
  font-weight: 700;
  color: var(--text-dark);
  margin-top: var(--space-5);
  margin-bottom: var(--space-2);
}

.info-page p {
  font-size: var(--font-md);
  color: var(--text-dark);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
  max-inline-size: none;
}

.info-page p.text-muted {
  font-family: var(--font-mono), monospace;
  font-size: var(--font-xs);
  color: var(--text-muted);
  margin-bottom: var(--space-5);
}

/* Listes */
.info-page ul,
.info-page ol {
  margin-bottom: var(--space-4);
  padding-left: var(--space-5);
}

.info-page ul { list-style: none; }

.info-page ul li {
  position: relative;
  padding-left: var(--space-4);
  margin-bottom: var(--space-2);
  font-size: var(--font-md);
  line-height: var(--leading-relaxed);
  color: var(--text-dark);
}

.info-page ul li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--gold-dark);
  font-weight: 700;
}

.info-page ol {
  list-style: decimal;
  counter-reset: none;
}

.info-page ol li {
  margin-bottom: var(--space-2);
  font-size: var(--font-md);
  line-height: var(--leading-relaxed);
  padding-left: var(--space-2);
}

/* Liens dans le contenu */
.info-page a {
  color: var(--gold-dark);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color 0.15s ease;
}

.info-page a:hover { color: var(--gold-light); }

/* Strong */
.info-page strong {
  font-weight: 700;
  color: var(--text-dark);
}

/* Bloc info / encadré */
.info-box {
  background: rgba(184, 155, 46, 0.06);
  border: 1px solid rgba(184, 155, 46, 0.20);
  border-left: 3px solid var(--gold-dark);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  margin-block: var(--space-5);
}

.info-box p { margin-bottom: 0; }


/* -----------------------------------------------------------
   NAVIGATION LATÉRALE — table des matières (optionnelle)
   Usage pour pages longues (CGV, politique...)
----------------------------------------------------------- */
.legal-nav {
  display: none;
}

@media (min-width: 1024px) {
  .legal-nav {
    display: block;
    position: sticky;
    top: calc(var(--nav-main-h) + var(--nav-desktop-h) + var(--space-4));
    align-self: start;
  }
}

.legal-nav-title {
  font-family: var(--font-mono), monospace;
  font-size: var(--font-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--text-muted);
  margin-bottom: var(--space-3);
}

.legal-nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.legal-nav-list a {
  display: block;
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-xs);
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  border-left: 2px solid transparent;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.legal-nav-list a:hover {
  color: var(--gold-dark);
  border-left-color: rgba(184, 155, 46, 0.4);
  background: rgba(184, 155, 46, 0.04);
}

.legal-nav-list a.active {
  color: var(--gold-dark);
  border-left-color: var(--gold-dark);
  background: rgba(184, 155, 46, 0.06);
  font-weight: 700;
}


/* -----------------------------------------------------------
   PAGE À PROPOS — mise en avant spécifique
----------------------------------------------------------- */
.page-a-propos .info-page-intro {
  font-size: var(--font-lg);
  color: var(--text-dark);
  line-height: 1.75;
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: var(--border-light);
}

/* Valeurs / missions — cards optionnelles */
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-block: var(--space-6);
}

@media (min-width: 640px) {
  .about-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .about-grid { grid-template-columns: repeat(3, 1fr); }
}

.about-card {
  background: var(--bg-card);
  border: var(--border-medium);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  box-shadow: var(--shadow-xs);
}

.about-card-icon {
  font-size: 28px;
  margin-bottom: var(--space-3);
}

.about-card h3 {
  font-family: var(--font-display), sans-serif;
  font-size: var(--font-md);
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: var(--space-2);
}

.about-card p {
  font-size: var(--font-sm);
  color: var(--text-muted);
  margin: 0;
  max-inline-size: none;
}


/* -----------------------------------------------------------
   PAGE CONTACT — mise en avant email
----------------------------------------------------------- */
.contact-email-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--bg-card);
  border: var(--border-medium);
  border-left: 3px solid var(--gold-dark);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  margin-block: var(--space-5);
}

.contact-email-card .contact-icon {
  font-size: 28px;
  flex-shrink: 0;
}

.contact-email-card p { margin: 0; max-inline-size: none; }

.contact-email-card a {
  font-family: var(--font-display), sans-serif;
  font-size: var(--font-lg);
  font-weight: 800;
  color: var(--gold-dark);
  letter-spacing: -0.01em;
}

.contact-delay {
  font-family: var(--font-mono), monospace;
  font-size: var(--font-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
}