/* ==========================================================================
   European Accessibility Act - feuille de styles principale
   Inspirée de la charte visuelle monparcourshandicap.gouv.fr (DSFR)
   Approche BEM, variables CSS, mobile-first.
   ========================================================================== */

/* --- 1. Reset & base ----------------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  margin: 0;
  font-family: "Marianne", "Arial", system-ui, -apple-system, sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--texte-noir);
  background: var(--blanc);
  -webkit-font-smoothing: antialiased;
}

img,
svg {
  max-width: 100%;
  height: auto;
  display: block;
}

button {
  font-family: inherit;
  cursor: pointer;
}

a {
  color: var(--bleu-france);
  text-decoration: underline;
  text-underline-offset: 2px;
}

a:hover {
  text-decoration-thickness: 2px;
}

:focus-visible {
  outline: 2px solid var(--bleu-france);
  outline-offset: 2px;
  border-radius: 2px;
}

/* --- 2. Variables -------------------------------------------------------- */
:root {
  --bleu-france: #000091;
  --bleu-france-clair: #e3e3fd;
  --bleu-france-survol: #1212ff;
  --bleu-fonce-titre: #161650;
  --bleu-lien: #0063cb;
  --gris-fond: #f6f6f6;
  --gris-clair: #eeeeee;
  --gris-bordure: #dddddd;
  --gris-medium: #929292;
  --gris-texte: #3a3a3a;
  --texte-noir: #161616;
  --blanc: #ffffff;
  --vert-success: #18753c;
  --rouge-erreur: #ce0500;

  --largeur-max: 1200px;
  --largeur-texte: 800px;

  --espace-xs: 0.5rem;
  --espace-s: 1rem;
  --espace-m: 1.5rem;
  --espace-l: 2rem;
  --espace-xl: 3rem;
  --espace-xxl: 4rem;

  --rayon: 4px;
  --rayon-grand: 8px;

  --ombre-card: 0 2px 6px rgba(0, 0, 0, 0.06);
  --ombre-menu: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* --- 3. Police Marianne (self-hosted, fallback système) ------------------ */
@font-face {
  font-family: "Marianne";
  src: local("Marianne"), local("Arial");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Marianne";
  src: local("Marianne Bold"), local("Arial Bold");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* --- 4. Utilitaires accessibilité ---------------------------------------- */
.visu-cachee {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.lien-evitement {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--bleu-france);
  color: var(--blanc);
  padding: var(--espace-s) var(--espace-m);
  font-weight: 700;
  text-decoration: none;
  z-index: 1000;
  transition: top 0.2s;
}

.lien-evitement:focus {
  top: 0;
}

/* --- 5. En-tête (header) ------------------------------------------------- */
.entete {
  background: var(--blanc);
  border-bottom: 1px solid var(--gris-bordure);
}

.entete__conteneur {
  max-width: var(--largeur-max);
  margin: 0 auto;
  padding: var(--espace-m) var(--espace-l);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--espace-l);
  align-items: center;
}

.entete__marque {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--texte-noir);
  font-family: "Marianne", "Arial", sans-serif;
  letter-spacing: 0.5px;
  line-height: 1.1;
  border-right: 1px solid var(--gris-bordure);
  padding-right: var(--espace-l);
}

.entete__marque-l1 {
  font-size: 0.95rem;
  font-weight: 700;
}

.entete__marque-l2 {
  font-size: 0.95rem;
  font-weight: 700;
}

.entete__marque-domaine {
  font-size: 0.95rem;
  font-weight: 400;
  margin-left: 4px;
  vertical-align: baseline;
}

.entete__baseline {
  margin: 0;
  font-size: 0.9rem;
  color: var(--gris-texte);
  line-height: 1.4;
  max-width: 380px;
}

.entete__actions {
  display: flex;
  flex-direction: column;
  gap: var(--espace-s);
  align-items: flex-end;
}

.entete__actions-haut {
  display: flex;
  gap: var(--espace-m);
  align-items: center;
  align-self: stretch;
  min-width: 380px;
}

.btn-icone {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: transparent;
  border: 0;
  color: var(--bleu-france);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.25rem 0.5rem;
}

.btn-icone:hover {
  text-decoration: underline;
}

.btn-icone svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.recherche {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  background: var(--gris-fond);
  min-width: 280px;
  position: relative; /* point d'ancrage pour la liste de résultats absolue */
}

.recherche input[type="search"] {
  border-top-left-radius: var(--rayon);
  border-bottom-left-radius: var(--rayon);
}

.recherche > button[type="submit"] {
  border-top-right-radius: var(--rayon);
  border-bottom-right-radius: var(--rayon);
}

.recherche input[type="search"] {
  border: 0;
  background: transparent;
  padding: 0.6rem 0.75rem;
  font-size: 0.9rem;
  flex: 1;
  font-family: inherit;
}

.recherche input[type="search"]:focus {
  outline: none;
}

.recherche button {
  background: var(--bleu-france);
  border: 0;
  padding: 0 1rem;
  color: var(--blanc);
  display: flex;
  align-items: center;
  justify-content: center;
}

.recherche button svg {
  width: 18px;
  height: 18px;
}

/* --- 6. Navigation principale ------------------------------------------- */
.nav-principale {
  background: var(--blanc);
  border-top: 1px solid var(--gris-bordure);
  border-bottom: 1px solid var(--gris-bordure);
}

.nav-principale__liste {
  max-width: var(--largeur-max);
  margin: 0 auto;
  padding: 0 var(--espace-l);
  list-style: none;
  display: flex;
  align-items: stretch;
  gap: 0;
}

.nav-principale__item--menu {
  position: relative;
}

.nav-principale__lien {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 1rem 1.25rem;
  color: var(--texte-noir);
  text-decoration: none;
  font-weight: 500;
  font-size: 0.95rem;
  line-height: 1;
  border: 0;
  background: transparent;
  font-family: inherit;
  border-bottom: 3px solid transparent;
  border-top: 3px solid transparent;
  cursor: pointer;
  vertical-align: middle;
  box-sizing: border-box;
  height: auto;
  margin: 0;
}

.nav-principale__lien svg {
  display: block;
  flex-shrink: 0;
}

.nav-principale__lien:hover,
.nav-principale__lien:focus-visible {
  color: var(--bleu-france);
}

.nav-principale__lien[aria-current="page"],
.nav-principale__lien.actif {
  color: var(--bleu-france);
  border-bottom-color: var(--bleu-france);
  font-weight: 700;
}

.nav-principale__lien[aria-expanded="true"] {
  color: var(--bleu-france);
  background: var(--bleu-france-clair);
}

.chevron {
  width: 12px;
  height: 12px;
  transition: transform 0.2s;
}

[aria-expanded="true"] .chevron {
  transform: rotate(180deg);
}

.sous-menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 0.5rem 0;
  list-style: none;
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  box-shadow: var(--ombre-menu);
  min-width: 280px;
  z-index: 50;
}

.sous-menu li + li {
  border-top: 1px solid var(--gris-clair);
}

.sous-menu a {
  display: block;
  padding: 0.75rem 1.25rem;
  color: var(--bleu-fonce-titre);
  text-decoration: none;
  font-size: 0.9rem;
}

.sous-menu a:hover,
.sous-menu a:focus-visible {
  background: var(--bleu-france-clair);
  text-decoration: underline;
}

/* --- 7. Bouton "Écouter" ------------------------------------------------- */
.btn-ecouter {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  background: var(--blanc);
  border: 2px solid var(--bleu-france);
  color: var(--bleu-france);
  font-weight: 500;
  font-size: 0.9rem;
  border-radius: var(--rayon);
  cursor: pointer;
  font-family: inherit;
}

.btn-ecouter:hover {
  background: var(--bleu-france-clair);
}

.btn-ecouter svg {
  width: 22px;
  height: 22px;
}

.btn-ecouter[data-etat="lecture"] {
  background: var(--bleu-france);
  color: var(--blanc);
}

/* --- 8. Fil d'Ariane ----------------------------------------------------- */
.fil-ariane {
  margin: 0 0 var(--espace-l);
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  font-size: 0.875rem;
}

.fil-ariane li {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--gris-texte);
}

.fil-ariane li + li::before {
  content: "›";
  color: var(--gris-medium);
  margin-right: 0.4rem;
}

.fil-ariane a {
  color: var(--gris-texte);
  text-decoration: underline;
}

.fil-ariane [aria-current="page"] {
  color: var(--texte-noir);
}

/* --- 9. Layout principal ------------------------------------------------- */
.contenu-principal {
  min-height: 60vh;
}

.conteneur {
  max-width: var(--largeur-max);
  margin: 0 auto;
  padding: var(--espace-l);
}

.contenu-article {
  max-width: var(--largeur-texte);
}

.contenu-article h1 {
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--texte-noir);
  margin: var(--espace-l) 0 var(--espace-m);
  line-height: 1.2;
}

.contenu-article h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin: var(--espace-xl) 0 var(--espace-s);
  line-height: 1.3;
}

.contenu-article h3 {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin: var(--espace-l) 0 var(--espace-s);
}

.contenu-article p {
  margin: 0 0 var(--espace-s);
}

.contenu-article ul,
.contenu-article ol {
  margin: 0 0 var(--espace-s);
  padding-left: 1.5rem;
}

.contenu-article li {
  margin-bottom: 0.4rem;
}

.contenu-article strong {
  font-weight: 700;
}

.intro {
  font-size: 1.1rem;
  color: var(--gris-texte);
  line-height: 1.6;
}

.encadre-info {
  background: var(--gris-fond);
  border-left: 4px solid var(--bleu-france);
  padding: var(--espace-m);
  margin: var(--espace-l) 0;
  border-radius: 0 var(--rayon) var(--rayon) 0;
}

.encadre-cta {
  background: var(--bleu-france-clair);
  padding: var(--espace-l);
  margin: var(--espace-l) 0;
  border-radius: var(--rayon);
}

.encadre-cta p {
  margin-bottom: var(--espace-s);
}

/* --- 10. Page d'accueil - Cartes ----------------------------------------- */
.section-une {
  padding: var(--espace-xl) 0;
}

.section-une__titre {
  font-size: 2rem;
  font-weight: 700;
  color: var(--texte-noir);
  margin: 0 0 var(--espace-l);
}

.grille-cartes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--espace-m);
}

.carte {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s, transform 0.2s;
  text-decoration: none;
  color: inherit;
}

.carte:hover {
  box-shadow: var(--ombre-card);
  transform: translateY(-2px);
  text-decoration: none;
}

.carte__image {
  background: linear-gradient(135deg, var(--bleu-france) 0%, #1212ff 100%);
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blanc);
}

.carte__image svg {
  width: 80px;
  height: 80px;
  opacity: 0.9;
}

.carte__corps {
  padding: var(--espace-m);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.carte__categorie {
  display: inline-block;
  background: var(--gris-clair);
  color: var(--gris-texte);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 0.25rem 0.6rem;
  border-radius: var(--rayon);
  margin-bottom: var(--espace-s);
  align-self: flex-start;
}

.carte__titre {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin: 0 0 var(--espace-s);
  line-height: 1.3;
}

.carte__extrait {
  color: var(--gris-texte);
  font-size: 0.9rem;
  margin-bottom: var(--espace-s);
}

.carte__pied {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: var(--espace-s);
  font-size: 0.85rem;
  color: var(--gris-texte);
}

.carte__fleche {
  width: 24px;
  height: 24px;
  color: var(--bleu-france);
}

/* --- 11. Section "blocs onglets" page d'accueil -------------------------- */
.section-blocs {
  background: var(--gris-fond);
  padding: var(--espace-xl) 0;
}

.section-blocs__titre {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0 0 var(--espace-l);
  color: var(--texte-noir);
}

.grille-blocs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--espace-m);
}

.bloc-onglet {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  padding: var(--espace-l);
  border-radius: var(--rayon);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: var(--espace-s);
  transition: box-shadow 0.2s, transform 0.2s;
}

.bloc-onglet:hover {
  box-shadow: var(--ombre-card);
  transform: translateY(-2px);
}

.bloc-onglet__icone {
  width: 48px;
  height: 48px;
  color: var(--bleu-france);
}

.bloc-onglet__titre {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin: 0;
}

.bloc-onglet__desc {
  font-size: 0.9rem;
  color: var(--gris-texte);
  margin: 0;
}

/* --- 12. Page Accompagnement (layout 2 colonnes) ------------------------- */
.layout-2col {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--espace-xl);
  margin-top: var(--espace-l);
}

.menu-lateral {
  position: sticky;
  top: var(--espace-m);
  align-self: flex-start;
}

.menu-lateral__titre {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 var(--espace-s);
  padding-bottom: var(--espace-s);
  border-bottom: 2px solid var(--bleu-france);
}

.menu-lateral__liste {
  list-style: none;
  margin: 0;
  padding: 0;
}

.menu-lateral__lien {
  display: block;
  padding: 0.75rem 1rem;
  border-left: 3px solid transparent;
  text-decoration: none;
  color: var(--texte-noir);
  font-size: 0.95rem;
  background: transparent;
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  width: 100%;
  text-align: left;
  font-family: inherit;
  cursor: pointer;
}

.menu-lateral__lien:hover {
  background: var(--gris-fond);
}

.menu-lateral__lien[aria-current="page"],
.menu-lateral__lien.actif {
  border-left-color: var(--bleu-france);
  background: var(--bleu-france-clair);
  color: var(--bleu-france);
  font-weight: 700;
}

/* --- 13. Sommaire ancré (page Méthodologie / À propos) ------------------- */
.sommaire {
  background: var(--gris-fond);
  border: 1px solid var(--gris-bordure);
  padding: var(--espace-m);
  margin: var(--espace-l) 0 var(--espace-xl);
  border-radius: var(--rayon);
}

.sommaire__titre {
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--gris-texte);
  margin: 0 0 var(--espace-s);
}

.sommaire__liste {
  list-style: none;
  margin: 0;
  padding-left: 0;
  counter-reset: sommaire;
}

.sommaire__liste li {
  counter-increment: sommaire;
  margin-bottom: 0.5rem;
}

.sommaire__liste li::before {
  content: counter(sommaire) ". ";
  font-weight: 700;
  color: var(--bleu-france);
  margin-right: 0.4rem;
}

.sommaire__liste a {
  color: var(--bleu-fonce-titre);
  font-weight: 500;
  text-decoration: none;
}

.sommaire__liste a:hover {
  text-decoration: underline;
}

.sommaire__liste a.actif {
  font-weight: 700;
  color: var(--bleu-france);
}

/* --- 14. Boutons --------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 500;
  border-radius: var(--rayon);
  text-decoration: none;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background 0.2s;
}

.btn--primaire {
  background: var(--bleu-france);
  color: var(--blanc);
  border-color: var(--bleu-france);
}

.btn--primaire:hover {
  background: var(--bleu-france-survol);
  border-color: var(--bleu-france-survol);
}

.btn--secondaire {
  background: transparent;
  color: var(--bleu-france);
  border-color: var(--bleu-france);
}

.btn--secondaire:hover {
  background: var(--bleu-france-clair);
}

.btn-groupe {
  display: flex;
  flex-wrap: wrap;
  gap: var(--espace-s);
  margin-top: var(--espace-l);
}

/* --- 15. Formulaire ------------------------------------------------------ */
.formulaire {
  display: flex;
  flex-direction: column;
  gap: var(--espace-m);
  max-width: 600px;
}

.champ {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.champ label {
  font-weight: 500;
  font-size: 0.95rem;
}

.champ .obligatoire {
  color: var(--rouge-erreur);
  margin-left: 0.2rem;
}

.champ input,
.champ textarea,
.champ select {
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  font-family: inherit;
  font-size: 0.95rem;
  background: var(--blanc);
}

.champ input:focus,
.champ textarea:focus,
.champ select:focus {
  outline: 2px solid var(--bleu-france);
  outline-offset: 1px;
  border-color: var(--bleu-france);
}

.champ[data-erreur="true"] input,
.champ[data-erreur="true"] textarea,
.champ[data-erreur="true"] select {
  border-color: var(--rouge-erreur);
  border-width: 2px;
}

.champ__erreur {
  color: var(--rouge-erreur);
  font-size: 0.875rem;
  display: none;
}

.champ[data-erreur="true"] .champ__erreur {
  display: block;
}

.champ__aide {
  color: var(--gris-texte);
  font-size: 0.85rem;
}

.mention-rgpd {
  font-size: 0.85rem;
  color: var(--gris-texte);
  margin-top: var(--espace-m);
  padding-top: var(--espace-m);
  border-top: 1px solid var(--gris-bordure);
}

/* --- 16. Tableaux -------------------------------------------------------- */
.contenu-article table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--espace-m) 0;
  font-size: 0.95rem;
}

.contenu-article th,
.contenu-article td {
  padding: 0.75rem;
  border: 1px solid var(--gris-bordure);
  text-align: left;
}

.contenu-article th {
  background: var(--gris-fond);
  font-weight: 700;
}

/* --- 17. Accordéon FAQ --------------------------------------------------- */
.accordeon {
  border-top: 1px solid var(--gris-bordure);
}

.accordeon__item {
  border-bottom: 1px solid var(--gris-bordure);
}

.accordeon__bouton {
  width: 100%;
  background: transparent;
  border: 0;
  padding: 1rem 0;
  text-align: left;
  font-size: 1.05rem;
  font-weight: 500;
  font-family: inherit;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  color: var(--bleu-fonce-titre);
}

.accordeon__bouton:hover {
  color: var(--bleu-france);
}

.accordeon__bouton::after {
  content: "+";
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--bleu-france);
}

.accordeon__bouton[aria-expanded="true"]::after {
  content: "−";
}

.accordeon__contenu {
  padding: 0 0 1rem;
  color: var(--gris-texte);
}

/* --- 18. Modale (dialog) ------------------------------------------------- */
.modale {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: var(--espace-m);
}

.modale[hidden] {
  display: none;
}

.modale__contenu {
  background: var(--blanc);
  border-radius: var(--rayon-grand);
  max-width: 600px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  padding: var(--espace-l);
  position: relative;
}

.modale__entete {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--espace-m);
  gap: var(--espace-s);
}

.modale__titre {
  margin: 0;
  font-size: 1.3rem;
  color: var(--bleu-fonce-titre);
}

.modale__fermer {
  background: transparent;
  border: 0;
  padding: 0.5rem;
  cursor: pointer;
  color: var(--texte-noir);
}

.modale__fermer svg {
  width: 24px;
  height: 24px;
}

.modale__section {
  margin-bottom: var(--espace-m);
}

.modale__section h3 {
  font-size: 1rem;
  margin: 0 0 0.5rem;
}

.options-radio {
  display: flex;
  flex-wrap: wrap;
  gap: var(--espace-s);
}

.options-radio label {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.75rem;
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  cursor: pointer;
  font-size: 0.9rem;
}

.options-radio input[type="radio"]:checked + span {
  font-weight: 700;
  color: var(--bleu-france);
}

.options-radio label:has(input:checked) {
  border-color: var(--bleu-france);
  background: var(--bleu-france-clair);
}

/* Glossaire */
.glossaire-liste {
  list-style: none;
  margin: 0;
  padding: 0;
}

.glossaire-liste dt {
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin-top: var(--espace-s);
}

.glossaire-liste dd {
  margin: 0.25rem 0 0;
  color: var(--gris-texte);
  font-size: 0.95rem;
}

/* --- 19. Pied de page ---------------------------------------------------- */
.pied-page {
  background: var(--gris-fond);
  border-top: 1px solid var(--gris-bordure);
  padding: var(--espace-l) 0;
  margin-top: var(--espace-xxl);
}

.pied-page__conteneur {
  max-width: var(--largeur-max);
  margin: 0 auto;
  padding: 0 var(--espace-l);
  text-align: center;
}

.pied-page__liens {
  list-style: none;
  margin: 0 0 var(--espace-s);
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--espace-l);
}

.pied-page__liens a {
  color: var(--gris-texte);
  text-decoration: none;
  font-size: 0.9rem;
}

.pied-page__liens a:hover {
  color: var(--bleu-france);
  text-decoration: underline;
}

.pied-page__mention {
  font-size: 0.8rem;
  color: var(--gris-medium);
  margin: 0;
}

/* --- 20. Modes accessibilité (préférences mémoire de session) ------------ */
html[data-taille="grande"] {
  font-size: 18px;
}

html[data-taille="tres-grande"] {
  font-size: 20px;
}

html[data-espacement="aere"] body {
  line-height: 1.9;
  letter-spacing: 0.05em;
  word-spacing: 0.1em;
}

html[data-contraste="eleve"] {
  --texte-noir: #000000;
  --gris-texte: #000000;
  --gris-medium: #333333;
  --bleu-france: #000080;
  --bleu-fonce-titre: #000080;
  --bleu-lien: #000080;
  --gris-fond: #ffffff;
  --gris-bordure: #000000;
}

html[data-contraste="sombre"] {
  --blanc: #1b1b1b;
  --texte-noir: #f5f5f5;
  --gris-texte: #d0d0d0;
  --gris-medium: #999999;
  --gris-fond: #2a2a2a;
  --gris-clair: #333333;
  --gris-bordure: #444444;
  --bleu-france: #8585f6;
  --bleu-france-clair: #2d2d6e;
  --bleu-fonce-titre: #c5c5ff;
  --bleu-lien: #8585f6;
}

html[data-contraste="sombre"] body {
  background: #1b1b1b;
}

html[data-police="dyslexie"] body {
  font-family: "Atkinson Hyperlegible", "OpenDyslexic", Verdana, sans-serif;
  letter-spacing: 0.03em;
}

/* --- 21. Responsive ------------------------------------------------------ */
@media (max-width: 960px) {
  .entete__conteneur {
    grid-template-columns: 1fr;
    gap: var(--espace-s);
  }

  .entete__marque {
    border-right: 0;
    padding-right: 0;
  }

  .entete__actions {
    align-items: flex-start;
  }

  .entete__actions-haut {
    flex-wrap: wrap;
  }

  .recherche {
    width: 100%;
  }

  .nav-principale__liste {
    flex-wrap: wrap;
    padding: 0;
  }

  .nav-principale__lien {
    padding: 0.75rem 1rem;
    font-size: 0.9rem;
  }

  .layout-2col {
    grid-template-columns: 1fr;
  }

  .menu-lateral {
    position: static;
  }

  .contenu-article h1 {
    font-size: 1.75rem;
  }

  .contenu-article h2 {
    font-size: 1.25rem;
  }
}

@media (max-width: 600px) {
  .conteneur {
    padding: var(--espace-m);
  }

  .section-une__titre,
  .section-blocs__titre {
    font-size: 1.5rem;
  }

  .pied-page__liens {
    flex-direction: column;
    gap: var(--espace-s);
  }
}

/* --- Google Translate : masquer la bannière et badges ------------------- */
body { top: 0 !important; }
.goog-te-banner-frame.skiptranslate,
.goog-te-banner-frame,
#goog-gt-tt,
.goog-te-balloon-frame,
.goog-tooltip,
.goog-tooltip:hover {
  display: none !important;
  visibility: hidden !important;
}
.goog-text-highlight {
  background: none !important;
  box-shadow: none !important;
}
#google_translate_element { display: none !important; }
.skiptranslate iframe { display: none !important; }

/* --- 22. Drapeau de traduction (UK / FR) -------------------------------- */
.btn-drapeau {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: transparent;
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.8rem;
  color: var(--gris-texte);
  margin-left: auto;
}

.btn-drapeau:hover {
  border-color: var(--bleu-france);
  color: var(--bleu-france);
}

.btn-drapeau svg {
  width: 28px;
  height: 20px;
  border-radius: 2px;
  display: block;
}

/* --- 23. Recherche : résultats -------------------------------------------- */
.recherche {
  position: relative;
}

.recherche-resultats {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 4px;
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  box-shadow: var(--ombre-menu);
  max-height: 400px;
  overflow-y: auto;
  z-index: 100;
}

.recherche-resultats[hidden] {
  display: none;
}

.recherche-resultats__titre {
  padding: 0.5rem 0.75rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--gris-texte);
  border-bottom: 1px solid var(--gris-clair);
  margin: 0;
}

.recherche-resultats ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.recherche-resultats li + li {
  border-top: 1px solid var(--gris-clair);
}

.recherche-resultats a {
  display: block;
  padding: 0.6rem 0.75rem;
  color: var(--bleu-fonce-titre);
  text-decoration: none;
  font-size: 0.9rem;
}

.recherche-resultats a:hover,
.recherche-resultats a:focus {
  background: var(--bleu-france-clair);
}

.recherche-resultats__vide {
  padding: 0.75rem;
  color: var(--gris-texte);
  font-size: 0.9rem;
  font-style: italic;
}

/* --- 24. Section "À regarder" (carrousel vidéo) ------------------------- */
.section-a-regarder {
  background: linear-gradient(135deg, #5b1a3e 0%, #7e1f4f 50%, #5b1a3e 100%);
  padding: var(--espace-xl) 0;
  color: var(--blanc);
}

.section-a-regarder__entete {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--espace-l);
  flex-wrap: wrap;
  gap: var(--espace-s);
}

.section-a-regarder__titre {
  font-size: 2rem;
  font-weight: 700;
  margin: 0;
  color: var(--blanc);
}

.section-a-regarder__voir-tout {
  color: var(--blanc);
  text-decoration: underline;
  font-size: 0.95rem;
}

.section-a-regarder__voir-tout:hover {
  text-decoration-thickness: 2px;
}

.carrousel {
  position: relative;
}

.carrousel__viewport {
  overflow: hidden;
}

.carrousel__piste {
  display: flex;
  gap: var(--espace-m);
  transition: transform 0.4s ease;
  will-change: transform;
}

.video-carte {
  flex: 0 0 calc(33.333% - var(--espace-m) * 2 / 3);
  min-width: 320px;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  padding: 0;
  font-family: inherit;
  color: var(--blanc);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.video-carte__vignette {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--rayon);
  background: #1b1b1b;
}

.video-carte__vignette img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.video-carte__play {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 64px;
  height: 64px;
  transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.65);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: transform 0.2s, background 0.2s;
  opacity: 0;
}

.video-carte:hover .video-carte__play,
.video-carte:focus-visible .video-carte__play {
  background: var(--bleu-france);
  transform: translate(-50%, -50%) scale(1.1);
  opacity: 1;
}

.video-carte__play svg {
  width: 28px;
  height: 28px;
  fill: var(--blanc);
  margin-left: 3px;
}

.video-carte__titre {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--blanc);
  line-height: 1.4;
}

.carrousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--blanc);
  border: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
  z-index: 2;
  color: var(--bleu-fonce-titre);
}

.carrousel__btn:hover {
  background: var(--bleu-france);
  color: var(--blanc);
}

.carrousel__btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.carrousel__btn--prev {
  left: -22px;
}

.carrousel__btn--next {
  right: -22px;
}

.carrousel__btn svg {
  width: 20px;
  height: 20px;
}

.carrousel__pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  margin-top: var(--espace-m);
  flex-wrap: wrap;
}

.carrousel__pagination button {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  padding: 0;
  transition: background 0.2s, transform 0.2s;
}

.carrousel__pagination button[aria-current="true"] {
  background: var(--blanc);
  transform: scale(1.3);
}

.carrousel__nav {
  display: flex;
  justify-content: center;
  gap: var(--espace-m);
  margin-top: var(--espace-s);
  align-items: center;
}

.carrousel__nav-bouton {
  background: transparent;
  border: 0;
  color: rgba(255, 255, 255, 0.85);
  font-family: inherit;
  font-size: 0.95rem;
  cursor: pointer;
  padding: 0.4rem 0.6rem;
}

.carrousel__nav-bouton:hover {
  color: var(--blanc);
  text-decoration: underline;
}

.carrousel__nav-bouton:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

@media (max-width: 1100px) {
  .video-carte {
    flex-basis: calc(50% - var(--espace-m) / 2);
    min-width: 280px;
  }
}

@media (max-width: 700px) {
  .video-carte {
    flex-basis: 90%;
    min-width: 0;
  }
  .carrousel__btn--prev { left: 4px; }
  .carrousel__btn--next { right: 4px; }
}

/* --- Section "Articles" (cartes horizontales : image à gauche, titre à droite) ---- */
.section-articles {
  background: var(--blanc);
  padding: var(--espace-xl) 0;
}

.section-articles__titre {
  font-size: 2rem;
  font-weight: 700;
  margin: 0 0 var(--espace-l);
  color: var(--texte-noir);
}

.grille-articles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--espace-m);
}

.article-carte {
  display: flex;
  align-items: stretch;
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--rayon);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
  min-height: 180px;
}

.article-carte:hover {
  box-shadow: var(--ombre-card);
  transform: translateY(-2px);
  text-decoration: none;
}

.article-carte__image {
  flex: 0 0 45%;
  position: relative;
  overflow: hidden;
  background: var(--gris-fond);
}

.article-carte__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-carte__corps {
  flex: 1;
  padding: var(--espace-m) var(--espace-l);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.5rem;
}

.article-carte__titre {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--bleu-fonce-titre);
  margin: 0;
  line-height: 1.3;
}

.article-carte__meta {
  font-size: 0.85rem;
  color: var(--gris-texte);
  margin: 0;
}

@media (max-width: 800px) {
  .grille-articles {
    grid-template-columns: 1fr;
  }
  .article-carte__image {
    flex-basis: 40%;
  }
}

@media (max-width: 500px) {
  .article-carte {
    flex-direction: column;
  }
  .article-carte__image {
    flex-basis: auto;
    height: 180px;
  }
}

/* --- 25. Modale vidéo (lecteur YouTube embarqué) ------------------------- */
.modale-video__contenu {
  background: #000;
  max-width: 900px;
  width: 100%;
  padding: 0;
  border-radius: var(--rayon-grand);
  overflow: hidden;
}

.modale-video__entete {
  display: flex;
  justify-content: flex-end;
  background: #000;
  padding: 0.5rem;
}

.modale-video__entete button {
  background: transparent;
  border: 0;
  color: var(--blanc);
  cursor: pointer;
  padding: 0.5rem;
}

.modale-video__entete svg {
  width: 24px;
  height: 24px;
}

.modale-video__lecteur {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}

.modale-video__lecteur iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* --- 26. Carte avec image (page d'accueil - périmètre) ------------------ */
.carte__image-photo {
  height: 180px;
  overflow: hidden;
  position: relative;
}

.carte__image-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* --- 27. Print ----------------------------------------------------------- */
@media print {
  .entete__actions,
  .nav-principale,
  .btn-ecouter,
  .modale,
  .pied-page {
    display: none;
  }
}
