/* ============================================================
   LE GUIDE VTC — style.css
   Éditorial, mode sombre. Playfair Display + Inter.

   Sommaire :
     1. Reset moderne
     2. Tokens (custom properties)
     3. Base & layout utilities
     4. Typographie globale
     5. Boutons & pastilles
     6. Header & navigation
     7. Hero
     8. Stats bar
     9. Section header + grilles
    10. Guide card
    11. News card
    12. City card
    13. CTA banner
    14. Footer
    15. Accessibilité (focus, skip-link)
    16. Responsive (mobile-first)
   ============================================================ */

/* ---------- 1. Reset moderne ------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd, ul, ol {
  margin: 0;
}
ul[class], ol[class] { padding: 0; list-style: none; }
img, picture, video, svg { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }


/* ---------- 2. Tokens -------------------------------------- */
:root {
  /* Header plus haut pour accueillir un logo 48px confortablement */
  --bg-primary:     #1C1F24;
  --bg-secondary:   #16181C;
  --bg-card:        #22262C;
  --bg-elevated:    #2A2F36;

  /* Textes */
  --text-primary:   #F5F5F3;
  --text-secondary: #A8ADB5;
  --text-tertiary:  #6B7079;

  /* Couleurs de catégorie */
  --cat-reconversion: #D85A30;
  --cat-revenus:      #E24B4A;
  --cat-financement:  #5DCAA5;
  --cat-juridique:    #7F77DD;
  --cat-demarches:    #378ADD;
  --cat-examen:       #EF9F27;

  /* Bordures */
  --border:        rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.15);

  /* Typographie */
  --font-serif: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* Mise en page */
  --container: 1120px;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;

  /* Accent (CTA primaire = --cat-reconversion) */
  --accent:       #D85A30;
  --accent-hover: #C44D27;

  /* Dimensions */
  --header-h: 120px;

  /* Transitions */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --t:    180ms;
}

/* Mode clair — palette éditoriale claire (sépia froid). Conserve les couleurs catégorielles. */
:root[data-theme="light"] {
  --bg-primary:     #FAFAF7;
  --bg-secondary:   #F2F1EC;
  --bg-card:        #FFFFFF;
  --bg-elevated:    #ECEAE3;

  --text-primary:   #1F2126;
  --text-secondary: #4A5058;
  --text-tertiary:  #767E89;

  --border:        rgba(0, 0, 0, 0.10);
  --border-strong: rgba(0, 0, 0, 0.20);
}
:root[data-theme="light"] body { background: var(--bg-primary); color: var(--text-primary); }
:root[data-theme="light"] .site-header,
:root[data-theme="light"] .site-footer { background: var(--bg-card); }
/* Mêmes contrastes : on garde l'orange CTA, on assombrit juste les ombres */
:root[data-theme="light"] .reader-toggle { box-shadow: 0 6px 24px -8px rgba(0,0,0,0.15); }
:root[data-theme="light"] .search-ac { box-shadow: 0 16px 48px rgba(0, 0, 0, 0.15); }
:root[data-theme="light"] meta[name="theme-color"] { /* purement indicatif, le DOM n'est pas mis à jour ici */ }


/* ---------- 3. Base & layout ------------------------------- */
body {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
}

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: 20px;
  padding-right: 20px;
}

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}


/* ---------- 4. Typographie --------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-serif);
  font-weight: 500;
  line-height: 1.2;
  color: var(--text-primary);
}

.eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}


/* ---------- 5. Boutons & pastilles ------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  padding: 12px 22px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  transition:
    background var(--t) var(--ease),
    border-color var(--t) var(--ease),
    color var(--t) var(--ease);
}
.btn--primary {
  background: var(--accent);
  color: #fff;
}
.btn--primary:hover { background: var(--accent-hover); }

.btn--outline {
  background: transparent;
  color: var(--text-primary);
  border-color: var(--border-strong);
}
.btn--outline:hover {
  background: var(--bg-elevated);
  border-color: var(--text-secondary);
}

/* Pastilles "Populaire : ..." */
.pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  font-size: 13px;
  transition: background var(--t) var(--ease), color var(--t) var(--ease);
}
.pill:hover { background: var(--bg-card); color: var(--text-primary); }


/* ---------- 6. Header & navigation ------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid var(--border);
}
/* Flou/opacité portés par un pseudo-élément pour NE PAS créer de
   containing block sur .site-header (sinon les descendants position:fixed
   comme le panneau mobile sont piégés dans la hauteur du header). */
.site-header::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(28, 31, 36, 0.95);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  z-index: -1;
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .site-header::before { background: var(--bg-primary); }
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  gap: 24px;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--text-primary);
  font-weight: 500;
  position: relative;
  z-index: 56;  /* reste au-dessus du panneau mobile ouvert */
}
.site-logo__mark {
  width: 96px;
  height: 96px;
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
}
/* Fallback si on utilise un <span> comme avant (texte "V") */
span.site-logo__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border-strong);
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 18px;
  line-height: 1;
  color: var(--text-primary);
  object-fit: unset;
}
.site-logo__text { font-size: 18px; letter-spacing: 0.01em; }

.site-nav__list {
  display: flex;
  align-items: center;
  gap: 40px;
}
.site-nav__link {
  color: var(--text-secondary);
  font-size: 20px;
  font-weight: 500;
  transition: color var(--t) var(--ease);
}
.site-nav__link:hover { color: var(--text-primary); }

/* Desktop : les pages utilitaires (À propos, Contact, Mentions légales…)
   n'apparaissent QUE dans le pied de page, pas dans la barre principale.
   Elles restent disponibles dans le menu burger sur mobile/tablette. */
@media (min-width: 1024px) {
  .site-nav__item--secondary { display: none; }
}

/* Lien CTA dans la nav (Simulateur) — visuellement mis en avant comme un bouton */
.site-nav__link--cta {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 999px;
  background: var(--cat-reconversion);
  color: #fff !important;
  font-weight: 600;
  letter-spacing: 0.01em;
  border: 1px solid var(--cat-reconversion);
  transition: filter .15s ease, transform .15s ease, box-shadow .15s ease;
  box-shadow: 0 0 0 0 rgba(216, 90, 48, 0.45);
}
.site-nav__link--cta:hover,
.site-nav__link--cta:focus-visible {
  filter: brightness(1.08);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px -4px rgba(216, 90, 48, 0.55);
  outline: none;
}
.site-nav__link--cta.is-active {
  background: #fff;
  color: var(--cat-reconversion) !important;
  border-color: var(--cat-reconversion);
}
.site-nav__cta-icon { flex-shrink: 0; }

/* Sur mobile (menu burger ouvert), le CTA reste visible mais s'aligne avec les autres */
@media (max-width: 1023px) {
  .site-nav__link--cta {
    align-self: flex-start;
    margin: 4px 0;
  }
}

/* Burger (mobile/tablette) */
.burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: 10px;
  margin-right: -10px;
  position: relative;
  z-index: 56;          /* reste cliquable au-dessus du panneau ouvert */
}

/* Icône "Visite guidée" — présente en haut à droite sur toutes les pages */
.tour-relaunch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin-left: 12px;
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--border);
  border-radius: 50%;
  cursor: pointer;
  position: relative;
  z-index: 56;
  transition: color .15s ease, border-color .15s ease, background .15s ease, transform .15s ease;
}
.tour-relaunch:hover,
.tour-relaunch:focus-visible {
  color: var(--text-primary);
  border-color: var(--border-strong);
  background: var(--bg-elevated);
  outline: none;
}
.tour-relaunch:hover { transform: translateY(-1px); }
/* Pastille orange "attire-l'œil" la première fois */
.tour-relaunch[data-fresh="1"]::after {
  content: '';
  position: absolute;
  top: 2px; right: 2px;
  width: 8px; height: 8px;
  background: var(--cat-reconversion);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--bg-primary);
  animation: tour-pulse 2s ease-out infinite;
}
@keyframes tour-pulse {
  0%   { transform: scale(1);   opacity: 1; }
  70%  { transform: scale(1.8); opacity: 0; }
  100% { transform: scale(1);   opacity: 0; }
}
.burger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--text-primary);
  transition: transform var(--t) var(--ease), opacity var(--t) var(--ease);
  transform-origin: center;
}


/* ---------- 7. Hero ---------------------------------------- */
.hero {
  padding: 12px 0 40px;
  position: relative;
}
.hero__grid {
  display: grid;
  gap: 40px;
}
.hero__content { max-width: 640px; }
.hero__title {
  font-size: 32px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-top: 16px;
}
.hero__subtitle {
  margin-top: 16px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--text-secondary);
}

.search-bar {
  margin-top: 24px;
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 6px 6px 6px 14px;
  transition: border-color var(--t) var(--ease);
}
.search-bar:focus-within { border-color: var(--border-strong); }
.search-bar__input {
  flex: 1;
  min-width: 0;
  border: 0;
  background: transparent;
  outline: none;
  font-size: 15px;
  padding: 10px 0;
  color: var(--text-primary);
}
.search-bar__input::placeholder { color: var(--text-tertiary); }

.hero__pills {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.hero__pills-label {
  font-size: 13px;
  color: var(--text-tertiary);
  margin-right: 4px;
}

/* Image hero — colonne droite (tablette+). L'image finale est injectée
   via background-image à partir de 768px pour éviter tout download sur mobile
   (où .hero__media est display:none et l'image est posée en fond de section). */
.hero__media {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-elevated);
}
.hero__media-placeholder {
  position: absolute; inset: 0;
  background-color: var(--bg-elevated);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}


/* ---------- 8. Stats bar ----------------------------------- */
.stats {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 28px 0;
}
.stats__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 0;
}
.stats__item {
  padding: 4px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  border-left: 1px solid var(--border);
}
.stats__item:first-child,
.stats__item:nth-child(3) {
  border-left: 0;
  padding-left: 0;
}
.stats__number {
  font-family: var(--font-serif);
  font-size: 32px;
  line-height: 1;
  color: var(--text-primary);
}
.stats__label {
  font-size: 13px;
  color: var(--text-tertiary);
}


/* ---------- 9. Section header + grilles -------------------- */
.section { padding: 32px 0; }
.section--cta { padding-top: 0; }

.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px 20px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.section-header__title {
  font-size: 28px;
  line-height: 1.2;
  margin-top: 8px;
}
.section-header__link {
  color: var(--text-secondary);
  font-size: 14px;
  transition: color var(--t) var(--ease);
}
.section-header__link:hover { color: var(--text-primary); }

.cards-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: 1fr;
}


/* ---------- 10. Guide card --------------------------------- */
.guide-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease);
}
.guide-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
}
.guide-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.guide-card__thumb {
  aspect-ratio: 16 / 9;
  background: var(--bg-elevated);
  overflow: hidden;
}
.guide-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform var(--t) var(--ease);
}
.guide-card:hover .guide-card__thumb img { transform: scale(1.03); }
.guide-card__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  flex: 1;
}
.guide-card__eyebrow {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.guide-card__title {
  font-size: 18px;
  line-height: 1.3;
}
.guide-card__description {
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-secondary);
  flex: 1;
}
.guide-card__meta {
  font-size: 13px;
  color: var(--text-tertiary);
}

/* Couleurs d'accent par catégorie (appliquées à l'eyebrow) */
.guide-card--reconversion .guide-card__eyebrow { color: var(--cat-reconversion); }
.guide-card--revenus      .guide-card__eyebrow { color: var(--cat-revenus); }
.guide-card--financement  .guide-card__eyebrow { color: var(--cat-financement); }
.guide-card--juridique    .guide-card__eyebrow { color: var(--cat-juridique); }
.guide-card--demarches    .guide-card__eyebrow { color: var(--cat-demarches); }
.guide-card--examen       .guide-card__eyebrow { color: var(--cat-examen); }


/* ---------- 11. News card ---------------------------------- */
.news-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease);
}
.news-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
}
.news-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.news-card__thumb {
  aspect-ratio: 16 / 9;
  background: var(--bg-elevated);
  overflow: hidden;
}
.news-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 400ms var(--ease, ease-out);
}
.news-card:hover .news-card__thumb img {
  transform: scale(1.03);
}
.news-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 22px 22px;
}
.news-card__date {
  font-size: 13px;
  color: var(--text-tertiary);
}
.news-card__title {
  font-size: 18px;
  line-height: 1.35;
}


/* ---------- 12. City card ---------------------------------- */
.city-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 20px 22px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--t) var(--ease), background var(--t) var(--ease);
}
.city-card:hover {
  border-color: var(--border-strong);
  background: var(--bg-elevated);
}
.city-card__name {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}
.city-card__meta {
  font-size: 13px;
  color: var(--text-tertiary);
}

/* Variante "Voir les 30 villes →" : même forme, contenu centré */
.city-card--more {
  align-items: center;
  justify-content: center;
  text-align: center;
}
.city-card--more .city-card__more {
  font-size: 15px;
  color: var(--text-secondary);
  transition: color var(--t) var(--ease);
}
.city-card--more:hover .city-card__more { color: var(--text-primary); }


/* ---------- 13. CTA banner --------------------------------- */
.cta-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 32px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  flex-wrap: wrap;
}
.cta-banner__title {
  font-size: 24px;
  line-height: 1.3;
}


/* ---------- 14. Footer ------------------------------------- */
.site-footer {
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  padding: 64px 0 24px;
  margin-top: 40px;
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px 24px;
}
.site-footer__col h4 {
  margin-bottom: 14px;
  color: var(--text-tertiary);
}
.site-footer__links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.site-footer__links a {
  color: var(--text-secondary);
  font-size: 14px;
  transition: color var(--t) var(--ease);
}
.site-footer__links a:hover { color: var(--text-primary); }

.site-footer__bottom {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
.site-footer__brand { display: flex; flex-direction: column; gap: 6px; }
.site-footer__tagline {
  font-size: 13px;
  color: var(--text-tertiary);
}

.site-footer__social {
  display: flex;
  gap: 12px;
}
.social-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  border: 1px solid var(--border);
  transition:
    color var(--t) var(--ease),
    border-color var(--t) var(--ease),
    background var(--t) var(--ease);
}
.social-icon:hover {
  color: var(--text-primary);
  border-color: var(--border-strong);
  background: var(--bg-elevated);
}

.site-footer__copy {
  font-size: 13px;
  color: var(--text-tertiary);
}


/* ---------- 15. Accessibilité ------------------------------ */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  background: var(--accent);
  color: #fff;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  z-index: 999;
  font-size: 14px;
  font-weight: 500;
}
.skip-link:focus { top: 12px; }


/* ---------- 16. Responsive (mobile-first) ------------------ */

/* Hero mobile : image en fond de section + overlay pour la lisibilité du texte. */
@media (max-width: 767px) {
  .hero {
    padding: 12px 0 40px;
    overflow: hidden;
  }
  .hero::before {
    content: "";
    position: absolute; inset: 0;
    background:
      linear-gradient(
        to bottom,
        rgba(28, 31, 36, 0.60) 0%,
        rgba(28, 31, 36, 0.92) 100%),
      url('/assets/images/hero-mobile.webp') center/cover no-repeat var(--bg-elevated);
    z-index: 0;
  }
  .hero > .container { position: relative; z-index: 1; }
  .hero__media { display: none; }
}

/* Burger visible < 1024px (mobile + tablette) */
@media (max-width: 1023px) {
  .burger { display: flex; }
  .site-nav {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;   /* couvre tout le viewport */
    background: var(--bg-primary);           /* opaque */
    padding: calc(var(--header-h) + 16px) 20px 32px;
    transform: translateX(100%);
    transition: transform 240ms var(--ease);
    z-index: 55;                             /* au-dessus du header (50) */
    visibility: hidden;
    overflow-y: auto;
  }
  .site-nav.is-open {
    transform: translateX(0);
    visibility: visible;
  }
  .site-nav__list {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }
  .site-nav__link {
    font-size: 22px;
    font-family: var(--font-serif);
    color: var(--text-primary);
  }
  /* Distinction mobile : les pages utilitaires sont regroupées en bas du
     panneau, séparées des rubriques par un filet, et en texte plus discret. */
  .site-nav__item--secondary .site-nav__link {
    font-size: 16px;
    font-family: var(--font-sans);
    font-weight: 500;
    color: var(--text-secondary);
  }
  .site-nav__item--group-start {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--border);
    width: 100%;
    align-self: stretch;
  }
  body.menu-open { overflow: hidden; }

  /* Burger → croix quand menu ouvert */
  .burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
}

/* Tablette (≥ 768px) */
@media (min-width: 768px) {
  .container { padding-left: 32px; padding-right: 32px; }

  .hero { padding: 16px 0 56px; }
  .hero__title { font-size: 40px; }

  .hero__media-placeholder {
    background-image: url('/assets/images/hero-desktop.webp');
  }

  .stats__grid { grid-template-columns: repeat(4, 1fr); gap: 0; }
  .stats__item { border-left: 1px solid var(--border); padding-left: 20px; }
  .stats__item:first-child { border-left: 0; padding-left: 0; }
  .stats__item:nth-child(3) { border-left: 1px solid var(--border); padding-left: 20px; }

  .cards-grid--3 { grid-template-columns: repeat(2, 1fr); }
  .cards-grid--4 { grid-template-columns: repeat(2, 1fr); }

  .site-footer__grid { grid-template-columns: repeat(3, 1fr); }
  .site-footer__bottom {
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
  }
  .site-footer__copy { text-align: right; }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
  .hero {
    padding: 20px 0 72px;
    overflow: hidden;
  }
  /* L'image devient le fond de tout le hero, avec un dégradé gauche → droite
     qui maintient la lisibilité du texte sur la partie gauche. */
  .hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(
        to right,
        var(--bg-primary) 0%,
        var(--bg-primary) 35%,
        rgba(28, 31, 36, 0.85) 50%,
        rgba(28, 31, 36, 0.35) 75%,
        rgba(28, 31, 36, 0) 100%
      ),
      url('/assets/images/hero-desktop.webp') right center / contain no-repeat;
    z-index: 0;
  }
  .hero > .container {
    position: relative;
    z-index: 1;
  }
  .hero__media { display: none; } /* remplacée par le background de la section */
  .hero__grid {
    grid-template-columns: 1fr;
    gap: 0;
    min-height: 440px;
    align-items: center;
  }
  .hero__title { font-size: 48px; }
  .hero__content { max-width: 620px; }

  .section-header { flex-wrap: nowrap; }

  .cards-grid--3 { grid-template-columns: repeat(3, 1fr); }
  .cards-grid--4 { grid-template-columns: repeat(4, 1fr); }

  .site-footer__grid { grid-template-columns: repeat(5, 1fr); }
}


/* ============================================================
   PHASE 2 — Styles pages intérieures
   ============================================================ */

/* ---------- Page header (sub-pages) ----------------------- */
.page-header {
  border-bottom: 1px solid var(--border);
  padding-bottom: 40px;
}
.page-header__title {
  font-family: var(--font-serif);
  font-size: 32px;
  font-weight: 500;
  line-height: 1.15;
  margin: 12px 0 0;
  max-width: 820px;
}
.page-header__subtitle {
  margin: 16px 0 0;
  color: var(--text-secondary);
  font-size: 17px;
  line-height: 1.6;
  max-width: 720px;
}
.page-header__meta {
  margin-top: 12px;
  color: var(--text-tertiary);
  font-size: 14px;
}
@media (min-width: 1024px) {
  .page-header__title { font-size: 44px; }
}
.eyebrow-link {
  color: inherit;
  transition: color var(--t) var(--ease);
}
.eyebrow-link:hover { color: var(--text-primary); }
.cat-accent { color: var(--cat-color, var(--text-primary)); }

/* ---------- Prose (rendu Markdown) ------------------------ */
.prose {
  max-width: 740px;
  font-size: 17px;
  line-height: 1.75;
  color: var(--text-primary);
}
.prose > * + * { margin-top: 1em; }
.prose h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.2;
  margin-top: 1.4em;
  margin-bottom: 0.5em;
}
.prose h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.25;
  margin-top: 1.1em;
  margin-bottom: 0.4em;
}
.prose h4 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 18px;
  margin-top: 1em;
  margin-bottom: 0.3em;
}
/* H3 qui suit immédiatement un H2 : colle au H2 */
.prose h2 + h3 { margin-top: 0.3em; }
/* Premier titre du contenu : pas de marge haute (colle au chapô) */
.prose > h2:first-child,
.prose > h3:first-child { margin-top: 0; }
.prose a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.prose a:hover { color: var(--accent-hover); }
.prose strong { font-weight: 600; }
.prose ul, .prose ol { padding-left: 24px; }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose ul li, .prose ol li { margin: 0.4em 0; }
.prose code {
  background: var(--bg-elevated);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
  font-family: 'SF Mono', Menlo, Consolas, monospace;
}
.prose pre {
  background: var(--bg-card);
  border: 1px solid var(--border);
  padding: 16px;
  border-radius: var(--radius-sm);
  overflow-x: auto;
  font-size: 14px;
}
.prose pre code { background: transparent; padding: 0; }
.prose blockquote {
  border-left: 3px solid var(--border-strong);
  padding-left: 20px;
  margin: 1.5em 0;
  color: var(--text-secondary);
  font-style: italic;
}
.prose hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 2em 0;
}
.prose table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
  margin: 1.5em 0;
}
.prose th, .prose td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.prose th {
  color: var(--text-tertiary);
  font-weight: 500;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--border-strong);
}
.prose img {
  border-radius: var(--radius-md);
  margin: 1em 0;
  max-width: 100%;
}

/* ---------- Grid helper 2 cols ---------------------------- */
.cards-grid--2 { grid-template-columns: 1fr; }
@media (min-width: 768px) { .cards-grid--2 { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Category card (index guides) ------------------ */
.cat-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-top: 3px solid var(--cat-color, var(--border-strong));
  border-radius: var(--radius-md);
  color: var(--text-primary);
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease);
}
.cat-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  border-top-color: var(--cat-color, var(--border-strong));
}
.cat-card__eyebrow {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  color: var(--text-primary);
  margin: 0;
}
.cat-card__desc {
  color: var(--text-secondary);
  font-size: 15px;
  line-height: 1.5;
  flex: 1;
  margin: 0;
}
.cat-card__count {
  color: var(--text-tertiary);
  font-size: 13px;
  margin: 4px 0 0;
}

/* ---------- Centre card (listing) ------------------------- */
.centre-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform var(--t) var(--ease), border-color var(--t) var(--ease);
}
.centre-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
}
.centre-card__link {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 24px;
  color: var(--text-primary);
  height: 100%;
}
.centre-card__head { display: flex; flex-direction: column; gap: 4px; }
.centre-card__name {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 500;
  margin: 0;
}
.centre-card__ville { color: var(--text-tertiary); font-size: 14px; }
.centre-card__pills { display: flex; gap: 6px; flex-wrap: wrap; }
.centre-card__tarif {
  color: var(--text-secondary);
  font-size: 14px;
  margin: auto 0 0;
}

/* ---------- Sélection de la rédaction (featured centres) ------ */
.section--featured {
  padding-bottom: 16px;
}
.featured-head {
  max-width: 720px;
  margin-bottom: 24px;
}
.featured-head__eyebrow {
  color: var(--cat-reconversion, #D85A30);
  margin: 0 0 8px;
}
.featured-head__title {
  font-family: var(--font-serif);
  font-size: 28px;
  font-weight: 500;
  margin: 0 0 12px;
  line-height: 1.2;
}
@media (max-width: 767px) {
  .featured-head__title { font-size: 22px; }
}
.featured-head__note {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
.featured-head__link {
  color: var(--text-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  margin-left: 4px;
  display: inline-block;
}
.featured-head__link:hover { color: var(--cat-reconversion, #D85A30); }

.featured-grid { margin-bottom: 12px; }

.centre-card--featured {
  position: relative;
  border-color: var(--cat-reconversion, #D85A30);
  background: linear-gradient(180deg,
    color-mix(in oklab, var(--cat-reconversion, #D85A30) 7%, var(--bg-card)) 0%,
    var(--bg-card) 60%);
}
.centre-card--featured:hover {
  border-color: var(--cat-reconversion, #D85A30);
  transform: translateY(-3px);
}
.centre-card__featured-badge {
  position: absolute;
  top: 14px;
  right: 14px;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--cat-reconversion, #D85A30);
  color: #fff;
  line-height: 1.2;
}
.centre-card--featured .centre-card__name {
  font-size: 22px;
  padding-right: 90px;  /* laisse la place au badge */
}
.centre-card__excerpt {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.55;
  margin: 6px 0 0;
}

/* ---------- Pills (shared) ------------------------------- */
.pill--ok { background: rgba(93, 202, 165, 0.15); color: #9be3c8; }
.pill--muted { background: var(--bg-card); color: var(--text-tertiary); }

/* ---------- Centre detail page ---------------------------- */
.centre-pills { display: flex; gap: 8px; margin-top: 16px; flex-wrap: wrap; }
.centre-detail {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}
@media (min-width: 900px) {
  .centre-detail {
    grid-template-columns: minmax(280px, 340px) 1fr;
    gap: 48px;
    align-items: start;
  }
}
.centre-infos {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 24px;
  position: sticky;
  top: calc(var(--header-h) + 20px);
}
.centre-infos__title {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  margin: 0 0 16px;
}
.centre-infos__list { margin: 0; }
.centre-infos__list dt {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-tertiary);
  margin-top: 14px;
}
.centre-infos__list dt:first-of-type { margin-top: 0; }
.centre-infos__list dd {
  margin: 4px 0 0;
  font-size: 15px;
  color: var(--text-primary);
}
.centre-infos__list a {
  color: var(--text-primary);
  border-bottom: 1px solid var(--border-strong);
  transition: color var(--t) var(--ease), border-color var(--t) var(--ease);
}
.centre-infos__list a:hover { color: var(--accent); border-color: var(--accent); }
.plain-list {
  margin: 0;
  padding-left: 18px;
  list-style: disc;
  font-size: 14px;
}
.centre-body { min-width: 0; }

/* ---------- Simulateur de rentabilité VTC ------------------ */
.simu {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  max-width: var(--container);
  margin: 0 auto;
}
@media (min-width: 1100px) {
  .simu { grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: start; }
}
.simu__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 700px) { .simu__grid { grid-template-columns: 1fr 1fr; } }

.simu__group {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-card);
  padding: 18px 20px 22px;
  margin: 0;
}
.simu__group legend {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 0 8px;
}
.simu__field {
  display: block;
  margin-top: 16px;
}
.simu__label {
  display: block;
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.simu__row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.simu__row input[type="range"] { flex: 1; min-width: 0; accent-color: var(--cat-reconversion); }
.simu__row input[type="number"] {
  width: 100px;
  padding: 7px 9px;
  font: inherit;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
}
.simu__row input[type="number"]:focus-visible {
  border-color: var(--cat-reconversion);
  outline: none;
}
.simu__row output {
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--text-primary);
  min-width: 3.5em;
  text-align: right;
}
.simu__group select {
  width: 100%;
  padding: 8px 10px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font: inherit;
}
.simu__hint {
  display: block;
  margin-top: 5px;
  color: var(--text-tertiary);
  font-size: 12px;
}
.simu__field--check {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  cursor: pointer;
}
.simu__field--check input { width: 16px; height: 16px; accent-color: var(--cat-reconversion); }
.simu__field--check span { font-size: 14px; color: var(--text-primary); }

/* Résultat */
.simu__result {
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 28px 28px 24px;
  position: sticky;
  top: 100px;
}
.simu__headline { text-align: center; margin-bottom: 22px; }
.simu__big-label {
  margin: 0 0 6px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.simu__big-value {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 42px;
  line-height: 1.05;
  margin: 0 0 8px;
  color: var(--cat-reconversion);
  font-variant-numeric: tabular-nums;
}
.simu__big-value.is-negative { color: var(--cat-revenus); }
.simu__big-value small { font-size: 14px; color: var(--text-secondary); font-family: var(--font-sans); font-weight: 400; }
.simu__big-sub { margin: 0; font-size: 13px; color: var(--text-secondary); }
.simu__big-sub strong { color: var(--text-primary); font-weight: 500; }

.simu__breakdown { margin-top: 8px; }
.simu__breakdown-title {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin: 0 0 10px;
}
.simu__lines {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px 16px;
  font-size: 13px;
}
.simu__lines dt { color: var(--text-secondary); }
.simu__lines dd {
  margin: 0;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
}
.simu__lines dd.is-debit  { color: var(--cat-revenus); }
.simu__lines dd.is-strong { color: var(--text-primary); font-weight: 500; }
.simu__lines dd.is-result {
  color: var(--cat-reconversion);
  font-weight: 600;
  font-size: 15px;
}
.simu__lines dd.is-zero { opacity: 0.4; }

.simu__bar {
  display: flex;
  height: 12px;
  margin-top: 22px;
  border-radius: 999px;
  overflow: hidden;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
}
.simu__bar-seg { display: block; height: 100%; transition: flex-basis .25s ease; }
.simu__bar-seg--commission { background: #6B7079; }
.simu__bar-seg--urssaf     { background: var(--cat-juridique); }
.simu__bar-seg--vehicule   { background: var(--cat-demarches); }
.simu__bar-seg--frais      { background: var(--cat-examen); }
.simu__bar-seg--net        { background: var(--cat-financement); }

.simu__bar-legend {
  list-style: none;
  margin: 10px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  font-size: 11px;
  color: var(--text-secondary);
}
.simu__bar-legend li { display: inline-flex; align-items: center; gap: 6px; }
.simu__swatch { display: inline-block; width: 10px; height: 10px; border-radius: 2px; }
.simu__swatch--commission { background: #6B7079; }
.simu__swatch--urssaf     { background: var(--cat-juridique); }
.simu__swatch--vehicule   { background: var(--cat-demarches); }
.simu__swatch--frais      { background: var(--cat-examen); }
.simu__swatch--net        { background: var(--cat-financement); }

.simu__disclaimer {
  margin: 24px auto 0;
  max-width: 760px;
  text-align: center;
  color: var(--text-tertiary);
  font-size: 13px;
}
.simu__disclaimer a { color: var(--text-secondary); }

/* Boutons d'action dans le panneau résultat */
.simu__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
}
.simu__action {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 10px;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.simu__action:hover {
  color: var(--text-primary);
  border-color: var(--border-strong);
  background: var(--bg-card);
}

/* Avertissements */
.simu__warnings {
  margin: 0 0 18px;
  padding: 12px 14px;
  background: rgba(216, 90, 48, 0.08);
  border: 1px solid rgba(216, 90, 48, 0.30);
  border-radius: var(--radius-sm);
  font-size: 12px;
}
.simu__warning-title {
  margin: 0 0 6px;
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--cat-reconversion);
  font-weight: 600;
}
.simu__warnings ul {
  list-style: disc;
  margin: 0;
  padding-left: 18px;
  color: var(--text-secondary);
  line-height: 1.45;
}
.simu__warnings li + li { margin-top: 5px; }

/* Mode "objectif net" */
.simu__goal {
  margin: 0 0 18px;
  padding: 14px 16px;
  background: var(--bg-card);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-sm);
}
.simu__goal-result {
  margin: 8px 0 0;
  font-size: 13px;
  color: var(--text-secondary);
}
.simu__goal-result strong { color: var(--text-primary); }
.simu__goal-ok { color: var(--cat-financement); font-weight: 500; }
.simu__goal-ko { color: var(--cat-revenus); font-weight: 500; }

/* Comparateur 3 statuts */
.simu__compare {
  margin: 32px auto 0;
  max-width: var(--container);
  padding: 24px 24px 28px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
}
.simu__compare-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 24px;
  margin: 0 0 6px;
  text-align: center;
}
.simu__compare-sub {
  margin: 0 0 22px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 13px;
}
.simu__compare-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 760px) {
  .simu__compare-grid { grid-template-columns: 1fr 1fr 1fr; }
}
.simu__compare-col {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px 18px 16px;
  transition: border-color .15s ease;
  position: relative;
}
.simu__compare-col h3 {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  margin: 0 0 10px;
}
.simu__compare-col.is-best {
  border-color: var(--cat-reconversion);
  background: linear-gradient(180deg, rgba(216, 90, 48, 0.08), var(--bg-card) 60%);
}
.simu__compare-col.is-best::after {
  content: 'Meilleur net';
  position: absolute;
  top: 8px; right: 10px;
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--cat-reconversion);
  font-weight: 600;
}
.simu__compare-net {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 28px;
  line-height: 1;
  margin: 0 0 4px;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.simu__compare-sub-line {
  margin: 0 0 14px;
  font-size: 12px;
  color: var(--text-secondary);
}
.simu__compare-lines {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
  font-size: 12px;
}
.simu__compare-lines dt { color: var(--text-tertiary); }
.simu__compare-lines dd {
  margin: 0;
  font-variant-numeric: tabular-nums;
  color: var(--text-secondary);
}
.simu__compare-tip {
  margin: 18px 0 0;
  text-align: center;
  font-size: 12px;
  color: var(--text-tertiary);
  font-style: italic;
}

/* Impression / sauvegarde PDF */
@media print {
  body { background: #fff !important; color: #000 !important; }
  .site-header, .site-footer, .simu__actions, .tour-launch, #tour-relaunch { display: none !important; }
  .simu__result {
    position: static !important;
    border-color: #888 !important;
    box-shadow: none !important;
    background: #fff !important;
    color: #000 !important;
  }
  .simu__big-value, .simu__compare-net, .simu__compare-col h3 { color: #000 !important; }
  .simu__lines dt, .simu__lines dd { color: #000 !important; }
  .simu__lines dd.is-debit { color: #b00 !important; }
  .simu__group { break-inside: avoid; border-color: #888 !important; }
  .simu__compare { background: #fff !important; }
  a { color: #000 !important; text-decoration: underline; }
}

.simu__disclaimer--legal {
  margin-top: 16px;
  padding: 14px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-align: left;
  font-size: 12px;
  line-height: 1.55;
}
.simu__disclaimer--legal strong { color: var(--text-secondary); }
.simu__disclaimer--legal a { color: var(--text-secondary); text-decoration: underline; }

/* ---------- Toggle thème clair / sombre (style switch) ----- */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  margin-left: 12px;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  position: relative;
  z-index: 56;
}
.theme-toggle__track {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  width: 64px;
  height: 30px;
  padding: 0 6px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.18);
  transition: border-color .15s ease, background .15s ease;
}
.theme-toggle:hover .theme-toggle__track,
.theme-toggle:focus-visible .theme-toggle__track {
  border-color: var(--cat-reconversion);
  outline: none;
}
.theme-toggle__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  z-index: 2;
  position: relative;
  transition: color .15s ease;
}
/* Couleurs des icônes selon le thème actif */
.theme-toggle__icon--sun  { color: var(--cat-reconversion); }   /* toujours en orange */
.theme-toggle__icon--moon { color: #F4D78A; }                   /* lune ambre */

/* Atténuer l'icône inactive */
:root:not([data-theme="light"]) .theme-toggle__icon--sun  { color: var(--text-tertiary); opacity: 0.5; }
:root[data-theme="light"]      .theme-toggle__icon--moon { color: var(--text-tertiary); opacity: 0.5; }

/* Le thumb : pastille blanche/sombre qui glisse sur l'icône active */
.theme-toggle__thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.30);
  transition: transform .25s var(--ease), background .15s ease;
  z-index: 1;
}
:root[data-theme="light"] .theme-toggle__thumb {
  /* en mode clair, le thumb est sur le soleil (gauche) */
  transform: translateX(0);
  background: #fff;
}
:root:not([data-theme="light"]) .theme-toggle__thumb {
  /* en mode sombre, le thumb glisse à droite sur la lune */
  transform: translateX(34px);
  background: #2A2F36;
}

/* Halo pulsant tant que jamais cliqué */
.theme-toggle[data-fresh="1"] .theme-toggle__track::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 999px;
  border: 2px solid var(--cat-reconversion);
  opacity: 0;
  animation: theme-toggle-pulse 2.4s ease-out infinite;
  pointer-events: none;
}
@keyframes theme-toggle-pulse {
  0%   { transform: scale(0.92); opacity: 0.85; }
  70%  { transform: scale(1.10); opacity: 0; }
  100% { transform: scale(1.10); opacity: 0; }
}

/* Mobile : on garde le switch lisible */
@media (max-width: 1023px) {
  .theme-toggle { margin-left: 6px; }
}

/* ---------- Sources & références (article) ----------------- */
.article-sources {
  margin-top: 48px;
  padding: 28px 30px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.article-sources__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  margin: 0 0 8px;
  color: var(--text-primary);
}
.article-sources__intro {
  margin: 0 0 18px;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.55;
}
.article-sources__list {
  margin: 0;
  padding-left: 0;
  list-style: none;
  counter-reset: src;
}
.article-sources__item {
  counter-increment: src;
  position: relative;
  padding: 12px 0 12px 36px;
  border-top: 1px solid var(--border);
  font-size: 14px;
  line-height: 1.5;
}
.article-sources__item:first-child { border-top: 0; }
.article-sources__item::before {
  content: counter(src);
  position: absolute;
  left: 0;
  top: 12px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--bg-elevated);
  color: var(--text-tertiary);
  font-size: 11px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.article-sources__type {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 3px;
  margin-right: 6px;
  background: var(--bg-elevated);
  color: var(--text-secondary);
}
.article-sources__type--reglementation { background: rgba(127, 119, 221, 0.18); color: var(--cat-juridique); }
.article-sources__type--jurisprudence  { background: rgba(127, 119, 221, 0.18); color: var(--cat-juridique); }
.article-sources__type--officiel       { background: rgba(55, 138, 221, 0.18);  color: var(--cat-demarches); }
.article-sources__type--data           { background: rgba(93, 202, 165, 0.18);  color: var(--cat-financement); }
.article-sources__type--etude          { background: rgba(93, 202, 165, 0.18);  color: var(--cat-financement); }
.article-sources__type--presse         { background: rgba(239, 159, 39, 0.18);  color: var(--cat-examen); }

.article-sources__link {
  color: var(--text-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--border-strong);
  transition: color .15s ease, text-decoration-color .15s ease;
}
.article-sources__link:hover {
  color: var(--cat-reconversion);
  text-decoration-color: var(--cat-reconversion);
}
.article-sources__date {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-tertiary);
  font-style: italic;
}

/* ---------- Page FAQ --------------------------------------- */
.faq-page { max-width: 820px; margin: 0 auto; }
.faq-section { margin-bottom: 36px; }
.faq-section__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.faq-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin-bottom: 10px;
  transition: border-color .15s ease;
}
.faq-item[open] { border-color: var(--cat-reconversion); }
.faq-item__q {
  cursor: pointer;
  font-weight: 500;
  font-size: 15px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  list-style: none;
  color: var(--text-primary);
}
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__q::after {
  content: '+';
  margin-left: auto;
  color: var(--text-tertiary);
  font-size: 18px;
  font-weight: 400;
  transition: transform .15s ease;
}
.faq-item[open] .faq-item__q::after { content: '−'; }
.faq-item__num {
  flex-shrink: 0;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cat-reconversion);
  background: rgba(216, 90, 48, 0.10);
  padding: 3px 7px;
  border-radius: 4px;
  font-weight: 600;
}
.faq-item__a {
  margin-top: 12px;
  padding-left: 36px;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.65;
}
.faq-item__a a { color: var(--cat-reconversion); }
.faq-item__a a:hover { text-decoration: underline; }

/* ---------- Mode lecture ----------------------------------- */
.reader-toggle {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 50;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  box-shadow: 0 6px 24px -8px rgba(0, 0, 0, 0.5);
  transition: border-color .15s ease, background .15s ease, transform .15s ease;
}
.reader-toggle:hover { border-color: var(--cat-reconversion); transform: translateY(-1px); }
.reader-toggle[aria-pressed="true"] {
  background: var(--cat-reconversion);
  border-color: var(--cat-reconversion);
  color: #fff;
}
@media (max-width: 640px) {
  .reader-toggle__lbl { display: none; }
  .reader-toggle { padding: 10px; }
}

/* État activé : passage en sépia + serif large */
body.reader-on {
  --bg-primary:   #f3ede2;
  --bg-secondary: #ede5d4;
  --bg-card:      #f6f0e3;
  --bg-elevated:  #ebe2cf;
  --text-primary:   #2a261d;
  --text-secondary: #4f4737;
  --text-tertiary:  #807a6c;
  --border:        rgba(0, 0, 0, 0.10);
  --border-strong: rgba(0, 0, 0, 0.20);
}
body.reader-on .site-header,
body.reader-on .site-footer,
body.reader-on .reseau-block,
body.reader-on #other-articles-title,
body.reader-on .article + section,
body.reader-on .tour-launch,
body.reader-on #tour-relaunch { display: none !important; }
body.reader-on .article__container,
body.reader-on .article__cover-wrap { max-width: 720px; }
body.reader-on .article__title { font-size: 38px; line-height: 1.15; }
body.reader-on .prose {
  font-family: 'Iowan Old Style', 'Apple Garamond', Georgia, 'Source Serif Pro', serif;
  font-size: 19px;
  line-height: 1.7;
}
body.reader-on .prose h2, body.reader-on .prose h3 {
  font-family: var(--font-serif);
  margin-top: 1.6em;
}

/* ---------- Search autocomplete ---------------------------- */
.search-bar--with-ac { position: relative; }
.search-ac {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 30;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
  max-height: min(70vh, 420px);
  overflow-y: auto;
  padding: 6px;
}
.search-ac__item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--text-primary);
  font-size: 14px;
  transition: background .12s ease;
}
.search-ac__item + .search-ac__item { margin-top: 1px; }
.search-ac__item:hover,
.search-ac__item.is-active {
  background: var(--bg-elevated);
}
.search-ac__badge {
  flex-shrink: 0;
  font-size: 10px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 3px 8px;
  background: var(--bg-elevated);
  border-radius: 999px;
  min-width: 60px;
  text-align: center;
}
.search-ac__item.is-active .search-ac__badge,
.search-ac__item:hover .search-ac__badge {
  background: var(--bg-secondary);
  color: var(--text-secondary);
}
.search-ac__label {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.search-ac__empty {
  margin: 0;
  padding: 12px;
  text-align: center;
  color: var(--text-tertiary);
  font-size: 13px;
}

/* ---------- Stats bar (fiche ville / département) ---------- */
.stats-bar {
  list-style: none;
  margin: 0 0 28px;
  padding: 18px 22px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
@media (min-width: 700px) {
  .stats-bar { grid-template-columns: repeat(5, 1fr); }
}
.stats-bar__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2px;
}
.stats-bar__num {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 26px;
  line-height: 1;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.stats-bar__lbl {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-tertiary);
  text-transform: uppercase;
}

/* ---------- Filtres centres -------------------------------- */
.centres-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  margin-bottom: 18px;
  padding: 12px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.centres-filters__group {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.centres-filters__group--end {
  margin-left: auto;
  gap: 8px;
}
.centres-filters__search {
  width: 260px;
  max-width: 100%;
  padding: 7px 10px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font: inherit;
}
.centres-filters__search:focus-visible {
  border-color: var(--cat-reconversion);
  outline: none;
}
.centres-filters__check {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-secondary);
  cursor: pointer;
}
.centres-filters__check input { accent-color: var(--cat-reconversion); }
.centres-filters__select {
  padding: 7px 10px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font: inherit;
}
.centres-filters__count {
  font-size: 12px;
  color: var(--text-tertiary);
  font-variant-numeric: tabular-nums;
}
.centres-filters__reset {
  width: 28px; height: 28px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 50%;
  cursor: pointer;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1;
}
.centres-filters__reset:hover { border-color: var(--border-strong); color: var(--text-primary); }
.cards-grid.is-filtered-empty::before {
  content: 'Aucun centre ne correspond à ces filtres.';
  display: block;
  text-align: center;
  padding: 24px;
  color: var(--text-tertiary);
  font-style: italic;
}

/* ---------- Réseaux dominants (fiche département) ---------- */
.reseaux-dominants {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.reseaux-dominants__item {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  padding: 8px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 14px;
  color: var(--text-primary);
}
.reseaux-dominants__count {
  font-size: 12px;
  color: var(--text-tertiary);
}

/* ---------- Carte de France (page départements) ------------ */
.fr-map {
  margin: 0 auto 32px;
  max-width: 720px;
}
.fr-map__svg-wrap {
  position: relative;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  overflow: hidden;
}
.fr-map__svg-wrap svg {
  display: block;
  width: 100%;
  height: auto;
}
/* Chaque chemin : stroke fin foncé pour séparer les départements */
.fr-map__dep {
  stroke: var(--bg-primary);
  stroke-width: 0.6;
  fill: var(--bg-elevated);
  transition: fill .15s ease, filter .15s ease;
}
/* Palette heatmap : gris → teal → orange */
.fr-map__dep--tier-0 { fill: var(--bg-elevated); }
.fr-map__dep--tier-1 { fill: rgba(93,202,165,0.28); }
.fr-map__dep--tier-2 { fill: rgba(93,202,165,0.55); }
.fr-map__dep--tier-3 { fill: rgba(216,90,48,0.60); }
.fr-map__dep--tier-4 { fill: rgba(216,90,48,0.88); }

/* Département mis en évidence (fiche ville → son département) */
.fr-map__dep--highlight {
  stroke: var(--text-primary);
  stroke-width: 1.6;
  fill: var(--cat-reconversion);
  filter: drop-shadow(0 0 4px rgba(216, 90, 48, 0.6));
}

/* Variante compacte (fiche ville) : pas de légende, taille réduite */
.fr-map--compact { max-width: 480px; }
.fr-map--compact .fr-map__svg-wrap { padding: 14px; }

/* Points de villes sur la carte */
.fr-map__point {
  fill: var(--text-primary);
  stroke: rgba(0, 0, 0, 0.45);
  stroke-width: 0.6;
  cursor: pointer;
  transition: transform .12s ease, fill .12s ease, r .12s ease;
  transform-box: fill-box;
  transform-origin: center;
}
.fr-map__points a:hover .fr-map__point,
.fr-map__points a:focus-visible .fr-map__point {
  fill: var(--cat-reconversion);
  stroke: var(--text-primary);
  stroke-width: 1;
  transform: scale(1.6);
  outline: none;
}
/* Sur les départements en heatmap "tier-3/4" (oranges), on rend les points blancs et plus visibles */
.fr-map__points a .fr-map__point { filter: drop-shadow(0 0 1.5px rgba(0,0,0,0.55)); }

.fr-map a:hover .fr-map__dep,
.fr-map a:focus-visible .fr-map__dep {
  filter: brightness(1.25);
  stroke: var(--text-primary);
  stroke-width: 1;
  cursor: pointer;
  outline: none;
}

/* Légende */
.fr-map__legend {
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  font-size: 12px;
  color: var(--text-secondary);
}
.fr-map__legend li { display: inline-flex; align-items: center; gap: 8px; }
.fr-map__swatch {
  display: inline-block;
  width: 14px; height: 14px;
  border-radius: 3px;
  border: 1px solid var(--border);
}
.fr-map__swatch--tier-0 { background: #2A2F36; }
.fr-map__swatch--tier-1 { background: rgba(93,202,165,0.28); }
.fr-map__swatch--tier-2 { background: rgba(93,202,165,0.55); }
.fr-map__swatch--tier-3 { background: rgba(216,90,48,0.60); }
.fr-map__swatch--tier-4 { background: rgba(216,90,48,0.88); }

/* Aside : départements non présents sur la carte (Tarn-et-Garonne + DROM) */
.fr-map__aside {
  margin-top: 24px;
  padding: 16px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.fr-map__aside-title {
  margin: 0 0 10px;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 500;
}
.fr-map__aside-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .fr-map__aside-list { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .fr-map__aside-list { grid-template-columns: repeat(3, 1fr); } }
.fr-map__aside-list a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 10px;
  padding: 8px 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--text-primary);
  font-size: 14px;
  transition: border-color .15s ease;
}
.fr-map__aside-list a:hover { border-color: var(--border-strong); }
.fr-map__aside-code {
  font-weight: 600;
  font-size: 11px;
  color: var(--cat-reconversion);
  background: rgba(216,90,48,0.14);
  padding: 3px 6px;
  border-radius: 4px;
  font-variant-numeric: tabular-nums;
}
.fr-map__aside-count {
  font-size: 12px;
  color: var(--text-tertiary);
}

/* ---------- Visite guidée (tour) --------------------------- */
.tour-launch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 20px;
  padding: 8px 14px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.01em;
  cursor: pointer;
  text-decoration: none;
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.tour-launch:hover,
.tour-launch:focus-visible {
  color: var(--text-primary);
  border-color: var(--border-strong);
  background: var(--bg-elevated);
  outline: none;
}
.tour-launch::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cat-reconversion);
  box-shadow: 0 0 0 3px rgba(216, 90, 48, 0.22);
}

.site-tour-overlay {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: auto;
  animation: tour-fade-in .2s ease;
}
@keyframes tour-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.site-tour-overlay__cutout {
  position: fixed;
  top: 0; left: 0;
  width: 0; height: 0;
  border-radius: 12px;
  box-shadow: 0 0 0 9999px rgba(12, 14, 18, 0.78);
  transition: top .25s ease, left .25s ease, width .25s ease, height .25s ease;
  pointer-events: none;
}
.site-tour-tip {
  position: fixed;
  z-index: 9999;
  width: min(360px, calc(100vw - 32px));
  padding: 20px 22px 18px;
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.45);
  font-family: var(--font-sans);
  animation: tour-pop .18s ease;
}
@keyframes tour-pop {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.site-tour-tip__progress {
  width: 100%;
  height: 3px;
  background: var(--bg-elevated);
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 14px;
}
.site-tour-tip__progress-bar {
  display: block;
  height: 100%;
  background: var(--cat-reconversion);
  transition: width .25s ease;
}
.site-tour-tip__step {
  margin: 0 0 4px;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  font-weight: 500;
}
.site-tour-tip__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.25;
  margin: 0 0 8px;
  color: var(--text-primary);
}
.site-tour-tip__body {
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-secondary);
}
.site-tour-tip__actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.site-tour-tip__nav {
  display: inline-flex;
  gap: 8px;
  margin-left: auto;
}
.site-tour-tip__btn {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  padding: 9px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.site-tour-tip__btn:focus-visible {
  outline: 2px solid var(--cat-reconversion);
  outline-offset: 2px;
}
.site-tour-tip__btn--link {
  background: transparent;
  color: var(--text-tertiary);
  border: 0;
  padding-left: 0;
  padding-right: 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.site-tour-tip__btn--link:hover { color: var(--text-secondary); }
.site-tour-tip__btn--ghost {
  background: transparent;
  border-color: var(--border-strong);
  color: var(--text-primary);
}
.site-tour-tip__btn--ghost:hover { background: var(--bg-elevated); }
.site-tour-tip__btn--primary {
  background: var(--cat-reconversion);
  color: #fff;
  border-color: var(--cat-reconversion);
}
.site-tour-tip__btn--primary:hover { filter: brightness(1.08); }

@media (max-width: 520px) {
  .site-tour-tip { padding: 16px 16px 14px; }
  .site-tour-tip__title { font-size: 17px; }
  .site-tour-tip__body  { font-size: 13px; }
}

/* ---------- Bloc "Départements d'agrément" ----------------- */
.zones-block {
  margin-top: 40px;
  padding: 24px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.zones-block__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 20px;
  line-height: 1.3;
  margin: 0 0 6px;
  color: var(--text-primary);
}
.zones-block__lead {
  margin: 0 0 16px;
  color: var(--text-secondary);
  font-size: 14px;
}
.zones-block__list {
  list-style: none;
  margin: 0 0 14px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.zones-block__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 8px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 13px;
  line-height: 1;
}
.zones-block__code {
  font-weight: 600;
  color: var(--cat-reconversion);
  background: rgba(216, 90, 48, 0.12);
  padding: 4px 7px;
  border-radius: 5px;
  letter-spacing: 0.02em;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}
.zones-block__name { color: var(--text-primary); }
.zones-block__note {
  margin: 0;
  font-size: 12px;
  color: var(--text-tertiary);
  font-style: italic;
}

/* ---------- Bloc "Autres antennes du réseau" -------------- */
.reseau-block {
  margin-top: 48px;
  padding: 28px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}
.reseau-block__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.3;
  margin: 0 0 8px;
  color: var(--text-primary);
}
.reseau-block__lead {
  margin: 0 0 20px;
  color: var(--text-secondary);
  font-size: 14px;
}
.reseau-block__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .reseau-block__list { grid-template-columns: 1fr 1fr; }
}
.reseau-block__item { margin: 0; }
.reseau-block__link {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px 14px;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--text-primary);
  transition: border-color .15s ease, transform .15s ease;
}
.reseau-block__link:hover {
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.reseau-block__name {
  font-weight: 500;
  font-size: 15px;
  line-height: 1.35;
}
.reseau-block__ville {
  font-size: 12px;
  color: var(--text-tertiary);
  letter-spacing: 0.02em;
}

/* ---------- Article (guide + article détail) -------------- */
.article__header { padding: 48px 0 24px; }
.article__container { max-width: 780px; margin-left: auto; margin-right: auto; }
.article__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 32px;
  line-height: 1.15;
  margin-top: 12px;
  letter-spacing: -0.01em;
}
@media (min-width: 1024px) { .article__title { font-size: 44px; } }
.article__chapo {
  color: var(--text-secondary);
  font-size: 19px;
  line-height: 1.5;
  margin-top: 18px;
}
.article__meta {
  color: var(--text-tertiary);
  font-size: 14px;
  margin-top: 16px;
}
.article__cover-wrap { margin: 24px auto 32px; max-width: 980px; }
.article__cover {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.article__body { margin-top: 0; }

/* ---------- 404 ------------------------------------------- */
.page-404 { padding: 60px 0; max-width: 720px; }
.page-404__actions {
  margin-top: 24px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ---------- Empty / listing count ------------------------- */
.empty-state {
  padding: 40px;
  background: var(--bg-card);
  border: 1px dashed var(--border-strong);
  border-radius: var(--radius-md);
  color: var(--text-tertiary);
  text-align: center;
}
.listing-count {
  color: var(--text-tertiary);
  font-size: 14px;
  margin-bottom: 20px;
}

/* ---------- Search page ----------------------------------- */
.search-bar--page { margin-top: 24px; max-width: 640px; }
.search-results {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.search-result {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--t) var(--ease), transform var(--t) var(--ease);
}
.search-result:hover {
  border-color: var(--border-strong);
  transform: translateX(2px);
}
.search-result__link {
  display: block;
  padding: 20px 24px;
  color: inherit;
}
.search-result__badge {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-tertiary);
  margin: 0 0 6px;
}
.search-result__title {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  margin: 0;
  line-height: 1.3;
}
.search-result__excerpt {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.5;
  margin: 8px 0 0;
}

/* ---------- Contact form --------------------------------- */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 720px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 28px;
}
.contact-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 768px) { .contact-form__row { grid-template-columns: 1fr 1fr; } }
.contact-form__field { display: flex; flex-direction: column; gap: 6px; }
.contact-form__label {
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 500;
}
.contact-form__input,
.contact-form__textarea {
  width: 100%;
  background: var(--bg-primary);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  font: inherit;
  font-size: 15px;
}
.contact-form__input:focus,
.contact-form__textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: 1px;
  border-color: transparent;
}
.contact-form__textarea { min-height: 160px; resize: vertical; }
.contact-form__err { font-style: normal; color: #ffb2b0; font-size: 13px; }
.contact-form__actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
@media (min-width: 768px) {
  .contact-form__actions {
    flex-direction: row;
    align-items: center;
    gap: 24px;
  }
}
.contact-form__legal { color: var(--text-tertiary); font-size: 13px; margin: 0; }
.contact-form__legal a { color: var(--text-secondary); text-decoration: underline; }

.contact-success {
  max-width: 720px;
  background: var(--bg-card);
  border: 1px solid rgba(93, 202, 165, 0.4);
  border-radius: var(--radius-md);
  padding: 32px;
}
.contact-success h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 24px;
  margin: 0 0 12px;
  color: #9be3c8;
}
.contact-success p { color: var(--text-secondary); margin-bottom: 12px; }

/* ---------- Nav active state ------------------------------ */
.site-nav__link.is-active { color: var(--text-primary); }

/* ---------- Annuaire : groupement par département -------- */
.annuaire-dep {
  margin-bottom: 56px;
}
.annuaire-dep:last-child { margin-bottom: 0; }
.annuaire-dep__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.annuaire-dep__title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 26px;
  margin: 0;
  line-height: 1.2;
}
.annuaire-dep__code {
  color: var(--text-tertiary);
  font-size: 20px;
  font-weight: 400;
  margin-left: 6px;
}
.annuaire-dep__count {
  color: var(--text-tertiary);
  font-size: 14px;
}

/* ---------- Filters bar (annuaire) ----------------------- */
.filters-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
  align-items: center;
  padding: 14px 0 20px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.filters-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.filters-group__label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-tertiary);
  margin-right: 2px;
  font-weight: 500;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
  border: 1px solid transparent;
  transition: background var(--t) var(--ease), color var(--t) var(--ease), border-color var(--t) var(--ease);
}
.filter-chip:hover {
  color: var(--text-primary);
  background: var(--bg-card);
}
.filter-chip.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.filter-chip--reset {
  background: transparent;
  color: var(--text-tertiary);
  font-weight: 400;
  border: 1px dashed var(--border-strong);
}
.filter-chip--reset:hover {
  background: var(--bg-card);
  color: var(--text-primary);
  border-style: solid;
}

/* ---------- Dictionnaire ---------------------------------- */
.dict-nav-section { padding-top: 0; padding-bottom: 16px; }
.dict-alphabet {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 12px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  position: sticky;
  top: 0;
  z-index: 10;
  backdrop-filter: blur(6px);
}
.dict-alphabet__letter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 6px;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  color: var(--text-secondary);
  transition: background 160ms ease, color 160ms ease;
}
a.dict-alphabet__letter:hover {
  background: var(--bg-elevated);
  color: var(--text-primary);
}
.dict-alphabet__letter.is-disabled {
  color: var(--text-tertiary);
  opacity: 0.35;
  cursor: default;
}

.dict-list-section { padding-top: 0; }
.dict-group { margin-bottom: 56px; scroll-margin-top: 80px; }
.dict-group:last-child { margin-bottom: 0; }
.dict-group__letter {
  font-family: var(--font-serif);
  font-size: 56px;
  font-weight: 500;
  color: var(--cat-reconversion, #D85A30);
  margin: 0 0 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
  line-height: 1;
  letter-spacing: -0.02em;
}
@media (max-width: 767px) {
  .dict-group__letter { font-size: 40px; margin-bottom: 16px; }
}

.dict-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 768px) {
  .dict-list { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}
.dict-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color 160ms ease, transform 160ms ease, background 160ms ease;
}
.dict-item:hover {
  border-color: var(--border-strong);
  background: var(--bg-elevated);
  transform: translateY(-1px);
}
.dict-item__link {
  display: block;
  padding: 20px 22px;
  color: inherit;
}

/* Catégorie : pastille discrète en haut */
.dict-item__cat {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-tertiary);
  padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: 999px;
  margin: 0 0 12px;
  line-height: 1;
}

/* Terme : grand, serif, visuellement dominant */
.dict-item__term {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  margin: 0;
  line-height: 1.25;
  color: var(--text-primary);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}
.dict-item__acronym {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-tertiary);
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  line-height: 1;
  position: relative;
  top: -2px;
}

/* Séparation forte terme / résumé */
.dict-item__def {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.6;
  margin: 10px 0 0;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}

/* Single term page */
.dict-term__title { display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px; }
.dict-term__acronym {
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--text-tertiary);
  text-transform: uppercase;
  padding: 5px 12px;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  line-height: 1;
}
.eyebrow-sep { color: var(--text-tertiary); margin: 0 4px; }
