@import url('https://fonts.googleapis.com/css2?family=Saira:wght@500;600;700;800&family=Hanken+Grotesk:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* =====================================================================
   SimRacer — design system « atelier technique »
   Titres : Saira (registre automobile) | Corps : Hanken Grotesk
   Palette : anthracite + ambre signalisation + sarcelle (data)
   ===================================================================== */

:root {
  --encre:        #1b1d22;   /* texte principal, presque noir */
  --acier:        #5b6168;   /* texte secondaire gris acier */
  --acier-clair:  #8a9098;
  --ambre:        #f2a900;   /* accent principal, signalisation */
  --ambre-fonce:  #b97e00;   /* liens, hover */
  --sarcelle:     #2f6f6a;   /* second accent, data/graph */
  --sarcelle-pale:#e4efed;
  --bg:           #fbfaf7;   /* blanc cassé, papier d'atelier */
  --bg-alt:       #f1ede5;   /* fond alterné chaud */
  --carte:        #ffffff;
  --trait:        #e2ddd2;   /* bordures */
  --trait-fort:   #1b1d22;
  --ok:           #1f7a4d;
  --alerte:       #c0392b;
  --rayon:        4px;       /* coins stricts, technique */
  --rayon-lg:     8px;
  --ombre:        0 1px 0 var(--trait), 0 6px 18px rgba(27,29,34,.05);
  --largeur:      1180px;
  --largeur-art:  760px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.75;
  color: var(--encre);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ambre-fonce); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--encre); }

h1, h2, h3, h4 { font-family: 'Saira', sans-serif; line-height: 1.15; color: var(--encre); }
h1 { font-size: clamp(2rem, 5vw, 3rem); font-weight: 800; letter-spacing: -.5px; margin: 0 0 .4em; }
h2 { font-size: 1.7rem; font-weight: 700; margin: 2.2em 0 .6em; }
h3 { font-size: 1.25rem; font-weight: 700; margin: 1.8em 0 .5em; }
h4 { font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }

.container { width: 100%; max-width: var(--largeur); margin: 0 auto; padding: 0 22px; }

/* ---------- En-tête / navigation ---------- */
.site-entete {
  position: sticky; top: 0; z-index: 50;
  background: var(--encre);
  border-bottom: 3px solid var(--ambre);
}
.site-entete-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.site-marque {
  font-family: 'Saira', sans-serif; font-weight: 800; font-size: 1.5rem;
  color: #fff; text-decoration: none; letter-spacing: -.5px; display: flex; align-items: center; gap: 8px;
}
.site-marque b { color: var(--ambre); }
.site-marque img { height: 50px; width: auto; display: block; }
.site-marque-puce { width: 12px; height: 12px; background: var(--ambre); border-radius: 50%; box-shadow: 0 0 0 3px rgba(242,169,0,.25); }
.site-nav { display: flex; gap: 4px; }
.site-nav a {
  color: #d7dade; text-decoration: none; font-weight: 600; font-size: .92rem;
  padding: 8px 12px; border-radius: var(--rayon); transition: .15s;
}
.site-nav a:hover, .site-nav a.actif { color: var(--encre); background: var(--ambre); }
.site-burger { display: none; background: none; border: 0; color: #fff; font-size: 1.6rem; cursor: pointer; }

/* Barre de recherche dans la nav */
.site-search { display: flex; align-items: center; margin-left: 14px; background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.18); border-radius: 999px; overflow: hidden; }
.site-search input { background: none; border: 0; color: #fff; padding: 7px 6px 7px 14px; font-family: inherit; font-size: .88rem; width: 150px; outline: none; }
.site-search input::placeholder { color: #9aa0a6; }
.site-search button { background: var(--ambre); border: 0; color: var(--encre); padding: 0 12px; height: 34px; display: flex; align-items: center; cursor: pointer; }
.site-search button:hover { background: #fff; }

/* ---------- Fil d'Ariane ---------- */
.guide-fil { font-size: .82rem; color: var(--acier); padding: 16px 0 0; }
.guide-fil a { color: var(--acier); text-decoration: none; }
.guide-fil a:hover { color: var(--ambre-fonce); }
.guide-fil .sep { margin: 0 6px; color: var(--acier-clair); }

/* ---------- Tête de page guide (pas de "hero") ---------- */
.guide-tete { padding: 14px 0 26px; border-bottom: 1px solid var(--trait); margin-bottom: 30px; }
.guide-tag {
  display: inline-block; font-family: 'Saira', sans-serif; font-weight: 700; font-size: .78rem;
  text-transform: uppercase; letter-spacing: .1em; color: #fff;
  background: var(--sarcelle); padding: 4px 10px; border-radius: var(--rayon); margin-bottom: 14px;
}
.guide-accroche { font-size: 1.2rem; color: var(--acier); max-width: 720px; margin: .2em 0 0; line-height: 1.6; }
.guide-meta { font-size: .82rem; color: var(--acier-clair); margin-top: 14px; display: flex; gap: 16px; flex-wrap: wrap; }

/* ---------- Layout article + sommaire latéral ---------- */
.guide-grille { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: start; }
@media (min-width: 1000px) { .guide-grille { grid-template-columns: 220px minmax(0,1fr); } }
.guide-sommaire { position: sticky; top: 84px; font-size: .9rem; }
.guide-sommaire h4 { color: var(--acier); margin: 0 0 10px; font-size: .72rem; }
.guide-sommaire ol { list-style: none; margin: 0; padding: 0; border-left: 2px solid var(--trait); }
.guide-sommaire li { margin: 0; }
.guide-sommaire a { display: block; padding: 6px 0 6px 14px; margin-left: -2px; border-left: 2px solid transparent; color: var(--acier); text-decoration: none; }
.guide-sommaire a:hover, .guide-sommaire a.actif { color: var(--encre); border-left-color: var(--ambre); font-weight: 600; }
@media (max-width: 999px) { .guide-sommaire { display: none; } }

.guide-corps { max-width: var(--largeur-art); }
.guide-corps p { margin: 0 0 1.1em; }
.guide-corps ul, .guide-corps ol { margin: 0 0 1.2em; padding-left: 1.3em; }
.guide-corps li { margin-bottom: .5em; }
.guide-corps strong { font-weight: 700; }
.guide-corps figure { margin: 1.8em 0; }
.guide-corps figure img { border-radius: var(--rayon-lg); border: 1px solid var(--trait); }
.guide-corps figure img[src$=".svg"] { max-height: none; object-fit: initial; border: 0; }
.guide-corps figcaption { font-size: .82rem; color: var(--acier); margin-top: 8px; text-align: center; }

/* lien ancre sous H2 visible au survol */
.guide-corps h2 { scroll-margin-top: 80px; }

/* image principale de l'article */
.guide-lead { margin: 0 0 30px; }
.guide-lead img { width: 100%; max-height: 420px; object-fit: cover; border-radius: var(--rayon-lg); border: 1px solid var(--trait); }

/* image en haut + texte dessous, dans les cartes de liste (hub + accueil) */
.hub-vignette { width: 100%; height: 180px; object-fit: cover; display: block; border-bottom: 3px solid var(--ambre); }
.hub-texte { display: block; padding: 16px 18px; }
.hub-texte small { color: var(--acier); font-size: .88rem; display: block; margin-top: 7px; line-height: 1.5; }

/* ---------- Encadré "à retenir" ---------- */
.guide-resume {
  background: var(--encre); color: #f3f1ec; border-radius: var(--rayon-lg);
  padding: 22px 26px; margin: 0 0 34px; border-left: 5px solid var(--ambre);
}
.guide-resume h2 { color: #fff; font-size: 1.05rem; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 12px; }
.guide-resume ul { margin: 0; padding-left: 1.1em; }
.guide-resume li { margin-bottom: 7px; color: #d9d6cf; }
.guide-resume li::marker { color: var(--ambre); }

/* ---------- Encadrés contextuels ---------- */
.encadre {
  border: 1px solid var(--trait); border-left: 4px solid var(--sarcelle);
  background: var(--carte); border-radius: var(--rayon); padding: 16px 20px; margin: 1.6em 0;
}
.encadre-titre { font-family: 'Saira', sans-serif; font-weight: 700; font-size: .95rem; margin: 0 0 6px; display: flex; align-items: center; gap: 8px; }
.encadre p:last-child { margin-bottom: 0; }
.encadre.astuce  { border-left-color: var(--ambre); background: #fdf6e6; }
.encadre.attention { border-left-color: var(--alerte); background: #fcebe9; }
.encadre.chiffre  { border-left-color: var(--sarcelle); background: var(--sarcelle-pale); }

/* ---------- Bloc chiffres-clés ---------- */
.guide-chiffres { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px,1fr)); gap: 1px; background: var(--trait); border: 1px solid var(--trait); border-radius: var(--rayon-lg); overflow: hidden; margin: 1.8em 0; }
.guide-chiffres div { background: var(--carte); padding: 16px 18px; }
.guide-chiffres dt { font-size: .78rem; color: var(--acier); text-transform: uppercase; letter-spacing: .05em; }
.guide-chiffres dd { margin: 4px 0 0; font-family: 'Saira', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--encre); }

/* ---------- Tableaux ---------- */
.tableau-auto { width: 100%; border-collapse: collapse; margin: 1.6em 0; font-size: .95rem; }
.tableau-auto th, .tableau-auto td { padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--trait); }
.tableau-auto thead th { background: var(--encre); color: #fff; font-family: 'Saira', sans-serif; font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }
.tableau-auto tbody tr:nth-child(even) { background: var(--bg-alt); }
.tableau-auto .oui { color: var(--ok); font-weight: 700; }
.tableau-auto .non { color: var(--alerte); font-weight: 700; }
.tableau-scroll { overflow-x: auto; }

/* ---------- Jauge / barre de score ---------- */
.jauge { margin: 1.4em 0; }
.jauge-ligne { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.jauge-label { flex: 0 0 150px; font-size: .9rem; font-weight: 600; }
.jauge-piste { flex: 1; height: 12px; background: var(--bg-alt); border-radius: 999px; overflow: hidden; border: 1px solid var(--trait); }
.jauge-rempli { height: 100%; background: linear-gradient(90deg, var(--ambre), var(--ambre-fonce)); border-radius: 999px; }
.jauge-val { flex: 0 0 48px; text-align: right; font-family: 'Saira', sans-serif; font-weight: 700; }

/* ---------- Comparateur 2 colonnes ---------- */
.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 1.8em 0; }
@media (max-width: 600px) { .compare { grid-template-columns: 1fr; } }
.compare-col { border: 1px solid var(--trait); border-radius: var(--rayon-lg); padding: 18px 20px; background: var(--carte); }
.compare-col h4 { margin: 0 0 12px; font-size: 1.05rem; text-transform: none; letter-spacing: 0; }
.compare-col ul { list-style: none; padding: 0; margin: 0; font-size: .92rem; }
.compare-col li { padding: 6px 0 6px 22px; position: relative; border-bottom: 1px solid var(--bg-alt); }
.compare-col li.plus::before { content: "+"; position: absolute; left: 0; color: var(--ok); font-weight: 800; }
.compare-col li.moins::before { content: "–"; position: absolute; left: 0; color: var(--alerte); font-weight: 800; }

/* ---------- Outils / simulateurs ---------- */
.sr-outil {
  border: 2px solid var(--encre); border-radius: var(--rayon-lg); margin: 2em 0; overflow: hidden;
  background: var(--carte);
}
.sr-outil-tete { background: var(--encre); color: #fff; padding: 14px 20px; font-family: 'Saira', sans-serif; font-weight: 700; font-size: 1.05rem; display: flex; align-items: center; gap: 10px; }
.sr-outil-tete::before { content: ""; width: 10px; height: 10px; border-radius: 50%; background: var(--ambre); }
.sr-outil-corps { padding: 20px; }
.sr-champ { margin-bottom: 16px; }
.sr-champ label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: 6px; }
.sr-champ input[type="number"], .sr-champ input[type="range"], .sr-champ select {
  width: 100%; padding: 10px 12px; border: 1px solid var(--trait); border-radius: var(--rayon);
  font-family: inherit; font-size: 1rem; background: var(--bg);
}
.sr-champ input[type="range"] { padding: 0; accent-color: var(--ambre); }
.sr-grille2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 520px) { .sr-grille2 { grid-template-columns: 1fr; } }
.sr-resultat {
  margin-top: 8px; background: var(--bg-alt); border-radius: var(--rayon-lg); padding: 18px 20px;
  border-left: 5px solid var(--ambre);
}
.sr-resultat-val { font-family: 'Saira', sans-serif; font-weight: 800; font-size: 2.2rem; color: var(--encre); line-height: 1; }
.sr-resultat-leg { font-size: .85rem; color: var(--acier); margin-top: 4px; }

/* ---------- FAQ accordéon ---------- */
.guide-faq { margin: 2.4em 0; }
.guide-faq h2 { margin-bottom: .4em; }
.faq-item { border-bottom: 1px solid var(--trait); }
.faq-q { width: 100%; text-align: left; background: none; border: 0; padding: 16px 30px 16px 0; font-family: 'Saira', sans-serif; font-weight: 600; font-size: 1.05rem; color: var(--encre); cursor: pointer; position: relative; }
.faq-q::after { content: "+"; position: absolute; right: 4px; top: 50%; transform: translateY(-50%); font-size: 1.4rem; color: var(--ambre-fonce); }
.faq-q[aria-expanded="true"]::after { content: "–"; }
.faq-r { display: none; padding: 0 0 18px; color: var(--encre); }
.faq-r.ouvert { display: block; }

/* Grand champ de recherche (page /recherche/) */
.recherche-grand { display: flex; gap: 10px; max-width: 560px; margin-top: 18px; }
.recherche-grand input { flex: 1; padding: 12px 16px; border: 1px solid var(--trait); border-radius: var(--rayon); font-family: inherit; font-size: 1rem; background: var(--carte); }
.recherche-grand button { background: var(--ambre); border: 0; color: var(--encre); font-family: 'Saira', sans-serif; font-weight: 700; padding: 0 22px; border-radius: var(--rayon); cursor: pointer; }
.recherche-grand button:hover { background: var(--encre); color: #fff; }

/* ---------- Sources ---------- */
.guide-sources { margin: 2.4em 0 0; padding-top: 18px; border-top: 1px solid var(--trait); font-size: .85rem; color: var(--acier); }
.guide-sources h4 { color: var(--acier); margin: 0 0 8px; }
.guide-sources ul { list-style: none; padding: 0; margin: 0; }
.guide-sources li { margin-bottom: 5px; word-break: break-word; }

/* ---------- Pages liées ---------- */
.guide-relies { margin: 2.6em 0; }
.guide-relies h2 { font-size: 1.3rem; }
.relies-grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 14px; }
.relie {
  display: block; border: 1px solid var(--trait); border-radius: var(--rayon-lg); padding: 16px 18px;
  background: var(--carte); text-decoration: none; color: var(--encre); transition: .15s;
}
.relie:hover { border-color: var(--encre); transform: translateY(-2px); box-shadow: var(--ombre); }
.relie span { font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--sarcelle); font-weight: 700; }
.relie strong { display: block; font-family: 'Saira', sans-serif; font-size: 1.05rem; margin-top: 4px; }

/* =====================================================================
   ACCUEIL
   ===================================================================== */
/* Bandeau d'accueil avec image de fond */
.accueil-une {
  position: relative; color: #fff; padding: 70px 0 0;
  background: linear-gradient(90deg, rgba(20,22,27,.97) 0%, rgba(20,22,27,.82) 34%, rgba(20,22,27,.35) 66%, rgba(20,22,27,.6) 100%), #14161b url('/img/home/fond.jpg') center right / cover no-repeat;
}
.accueil-une-inner { max-width: 620px; padding-bottom: 50px; }
.accueil-une h1 { color: #fff; font-size: clamp(2.3rem, 5.5vw, 3.6rem); }
.accueil-une h1 b { color: var(--ambre); }
.accueil-une p { font-size: 1.18rem; color: #d4d7db; max-width: 540px; line-height: 1.6; }
.accueil-atouts { list-style: none; padding: 0; margin: 24px 0 28px; display: flex; flex-wrap: wrap; gap: 10px 26px; }
.accueil-atouts li { display: flex; align-items: center; gap: 9px; font-weight: 600; font-size: .95rem; color: #e7e9ec; }
.accueil-cta { display: inline-block; background: var(--ambre); color: var(--encre); font-family: 'Saira', sans-serif; font-weight: 700; font-size: 1.05rem; text-decoration: none; padding: 13px 30px; border-radius: var(--rayon); transition: .15s; }
.accueil-cta:hover { background: #fff; color: var(--encre); }
.accueil-statsbar {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--rayon-lg); overflow: hidden; transform: translateY(28px); box-shadow: 0 14px 40px rgba(0,0,0,.35);
}
.accueil-statsbar div { background: #1b1d22; padding: 20px 22px; }
.accueil-statsbar b { font-family: 'Saira', sans-serif; font-weight: 800; font-size: 2rem; color: var(--ambre); display: block; line-height: 1; }
.accueil-statsbar span { font-size: .85rem; color: #9aa0a6; }
@media (max-width: 680px) { .accueil-statsbar { grid-template-columns: 1fr 1fr; } .accueil-une { background-position: center; } }

/* En-tête de section avec lien à droite */
.bloc-section { padding: 54px 0; }
.bloc-section:first-of-type { padding-top: 60px; }
.bloc-section.alt { background: var(--bg-alt); }
.bloc-entete { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 8px; }
.bloc-titre { font-size: 2rem; margin: 0 0 6px; }
.bloc-sous { color: var(--acier); font-size: 1.05rem; margin: 0; }
.bloc-lien { font-family: 'Saira', sans-serif; font-weight: 700; font-size: .9rem; color: var(--ambre-fonce); text-decoration: none; white-space: nowrap; }
.bloc-lien:hover { color: var(--encre); }

/* Cartes de rubrique (accueil) */
.rubrique-grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px,1fr)); gap: 20px; margin: 26px 0 0; }
.rubrique-fiche {
  display: flex; flex-direction: column; text-decoration: none; color: var(--encre); background: var(--carte);
  border: 1px solid var(--trait); border-radius: var(--rayon-lg); overflow: hidden; transition: transform .15s, box-shadow .15s, border-color .15s;
}
.rubrique-fiche:hover { transform: translateY(-4px); box-shadow: var(--ombre); border-color: var(--encre); }
.rubrique-visuel { position: relative; display: block; }
.rubrique-img { width: 100%; height: 160px; object-fit: cover; display: block; }
.rubrique-badge { position: absolute; right: 16px; bottom: -18px; width: 40px; height: 40px; border-radius: 50%; background: var(--accent, var(--ambre)); display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(0,0,0,.25); border: 3px solid var(--carte); }
.rubrique-fiche-corps { padding: 24px 22px 22px; display: flex; flex-direction: column; flex: 1; }
.rubrique-fiche-corps strong { font-family: 'Saira', sans-serif; font-size: 1.22rem; line-height: 1.2; }
.rubrique-desc { color: var(--acier); font-size: .92rem; margin: 7px 0 14px; flex: 1; }
.rubrique-fiche .compte { font-family: 'Saira', sans-serif; font-weight: 700; font-size: .85rem; color: var(--accent, var(--ambre-fonce)); }

/* Derniers guides : cartes horizontales */
.recent-grille { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px,1fr)); gap: 18px; margin-top: 26px; }
.recent-carte { display: flex; align-items: stretch; text-decoration: none; color: var(--encre); background: var(--carte); border: 1px solid var(--trait); border-radius: var(--rayon-lg); overflow: hidden; transition: transform .15s, box-shadow .15s, border-color .15s; }
.recent-carte:hover { transform: translateY(-3px); box-shadow: var(--ombre); border-color: var(--encre); }
.recent-carte img { flex: 0 0 130px; width: 130px; object-fit: cover; }
.recent-corps { padding: 14px 16px; display: flex; flex-direction: column; justify-content: center; }
.recent-rub { font-family: 'Saira', sans-serif; font-weight: 700; font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; }
.recent-corps strong { font-family: 'Saira', sans-serif; font-size: 1.05rem; line-height: 1.22; margin-top: 4px; }

/* Section confiance */
.confiance { padding: 60px 0; background-size: cover; background-position: center; color: #fff; }
.confiance-titre { text-align: center; color: #fff; font-size: 2rem; margin: 0 0 36px; }
.confiance-grille { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 24px; }
.confiance-item { text-align: center; padding: 0 10px; }
.confiance-ico { display: inline-flex; align-items: center; justify-content: center; width: 58px; height: 58px; border-radius: 50%; background: rgba(242,169,0,.12); border: 1px solid rgba(242,169,0,.35); margin-bottom: 14px; }
.confiance-item h3 { color: #fff; font-size: 1.12rem; margin: 0 0 8px; }
.confiance-item p { color: #b7bcc2; font-size: .92rem; line-height: 1.6; margin: 0; }

/* liste de guides (hub + accueil) : cartes verticales image en haut */
.hub-liste { list-style: none; padding: 0; margin: 28px 0; display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 22px; }
.hub-liste a { display: flex; flex-direction: column; text-decoration: none; color: var(--encre); border: 1px solid var(--trait); border-radius: var(--rayon-lg); overflow: hidden; background: var(--carte); transition: transform .15s, box-shadow .15s, border-color .15s; }
.hub-liste a:hover { border-color: var(--encre); box-shadow: var(--ombre); transform: translateY(-3px); }
.hub-liste a strong { font-family: 'Saira', sans-serif; font-size: 1.18rem; line-height: 1.22; display: block; }

/* =====================================================================
   PIED DE PAGE
   ===================================================================== */
.site-pied { background: var(--encre); color: #b7bcc2; margin-top: 0; }
.site-pied-haut { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr 1.6fr; gap: 34px; padding: 50px 0 34px; }
@media (max-width: 900px) { .site-pied-haut { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .site-pied-haut { grid-template-columns: 1fr; } }
.site-pied h4 { color: #fff; font-size: .82rem; margin: 0 0 14px; text-transform: uppercase; letter-spacing: .06em; }
.site-pied a { color: #b7bcc2; text-decoration: none; display: block; padding: 4px 0; font-size: .92rem; }
.site-pied a:hover { color: var(--ambre); }
.site-pied-marque { font-family: 'Saira', sans-serif; font-weight: 800; font-size: 1.6rem; color: #fff; }
.site-pied-marque b { color: var(--ambre); }
.site-pied-marque img { height: 60px; width: auto; display: block; }
.site-pied-marque-bloc p { font-size: .9rem; margin: 12px 0 16px; max-width: 280px; line-height: 1.6; }
.site-pied-reseaux { display: flex; gap: 10px; }
.site-pied-reseaux a { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; padding: 0; border-radius: 50%; background: rgba(255,255,255,.08); color: #d7dade; transition: .15s; }
.site-pied-reseaux a:hover { background: var(--ambre); color: var(--encre); }
.site-pied-news p { font-size: .88rem; margin: 0 0 12px; line-height: 1.55; }
.site-pied-news form { display: flex; flex-direction: column; gap: 8px; }
.site-pied-news input { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); border-radius: var(--rayon); padding: 10px 12px; color: #fff; font-family: inherit; font-size: .9rem; }
.site-pied-news input::placeholder { color: #80868d; }
.site-pied-news button { background: var(--ambre); border: 0; color: var(--encre); font-family: 'Saira', sans-serif; font-weight: 700; padding: 10px; border-radius: var(--rayon); cursor: pointer; }
.site-pied-news button:hover { background: #fff; }
.site-pied-bas { border-top: 1px solid rgba(255,255,255,.1); padding: 18px 0; font-size: .82rem; color: #80868d; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.site-pied-bas a { display: inline; color: #80868d; }

/* =====================================================================
   404
   ===================================================================== */
.erreur-404 { padding: 80px 20px; text-align: center; }
.erreur-404-inner { max-width: 560px; margin: 0 auto; }
.erreur-code { display: block; font-family: 'Saira', sans-serif; font-size: 6rem; font-weight: 800; color: var(--ambre); line-height: 1; }
.btn-accueil { display: inline-block; padding: 12px 28px; background: var(--ambre); color: var(--encre); border-radius: var(--rayon); text-decoration: none; font-weight: 700; margin: 20px 0 40px; }

/* =====================================================================
   PAGES SIMPLES (légales, contact)
   ===================================================================== */
.page-simple { max-width: var(--largeur-art); margin: 30px auto; }
.page-simple p, .page-simple li { color: var(--encre); }

/* =====================================================================
   RESPONSIVE NAV
   ===================================================================== */
@media (max-width: 860px) {
  .site-burger { display: block; }
  .site-nav { position: absolute; top: 72px; left: 0; right: 0; background: var(--encre); flex-direction: column; padding: 10px 16px 18px; gap: 2px; display: none; border-bottom: 3px solid var(--ambre); }
  .site-nav.ouvert { display: flex; }
  .site-nav a { padding: 12px; }
  .site-search { margin: 10px 0 0; width: 100%; }
  .site-search input { flex: 1; width: auto; }
}

/* =====================================================================
   ADMIN (thème sombre, vocabulaire admin-*)
   ===================================================================== */
.admin-corps { background: #14161b; color: #e7e9ec; font-family: 'Hanken Grotesk', sans-serif; }
.admin-nav { display: flex; align-items: center; justify-content: space-between; background: #1c1f26; border-bottom: 1px solid #2a2e37; padding: 0 24px; height: 58px; }
.admin-marque { color: #fff; text-decoration: none; font-family: 'Saira', sans-serif; font-weight: 800; font-size: 1.2rem; }
.admin-marque span { color: var(--ambre); }
.admin-nav-actions { display: flex; gap: 6px; }
.admin-nav-lien { color: #aeb3bd; text-decoration: none; font-size: .9rem; font-weight: 600; padding: 8px 12px; border-radius: 4px; }
.admin-nav-lien:hover, .admin-nav-lien.actif { color: #14161b; background: var(--ambre); }
.admin-zone { max-width: 1000px; margin: 0 auto; padding: 28px 24px; }
.admin-titre { font-family: 'Saira', sans-serif; font-size: 1.8rem; margin: 0 0 20px; color: #fff; }
.admin-auth-bloc { max-width: 380px; margin: 60px auto; background: #1c1f26; border: 1px solid #2a2e37; border-radius: 8px; padding: 30px; }
.admin-auth-bloc h1 { font-family: 'Saira', sans-serif; color: #fff; margin: 0 0 8px; font-size: 1.5rem; }
.admin-auth-bloc p { color: #8b919c; margin: 0 0 20px; }
.admin-champ { margin-bottom: 16px; }
.admin-champ-label { display: block; font-size: .82rem; color: #aeb3bd; margin-bottom: 6px; font-weight: 600; }
.admin-input, .admin-textarea, .admin-select { width: 100%; background: #14161b; border: 1px solid #2a2e37; border-radius: 4px; padding: 10px 12px; color: #e7e9ec; font-family: inherit; font-size: .95rem; }
.admin-textarea { min-height: 120px; resize: vertical; line-height: 1.5; }
.admin-textarea.code { font-family: ui-monospace, 'Cascadia Code', monospace; font-size: .85rem; }
.admin-input:focus, .admin-textarea:focus, .admin-select:focus { outline: 2px solid var(--ambre); border-color: var(--ambre); }
.admin-grille-champs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .admin-grille-champs { grid-template-columns: 1fr; } }
.admin-btn { display: inline-block; border: 0; border-radius: 4px; padding: 9px 16px; font-weight: 700; font-size: .88rem; text-decoration: none; cursor: pointer; font-family: inherit; }
.admin-btn-ambre { background: var(--ambre); color: #14161b; }
.admin-btn-bleu { background: #3b6ef0; color: #fff; }
.admin-btn-gris { background: #2a2e37; color: #d7dade; }
.admin-btn-or { background: var(--sarcelle); color: #fff; }
.admin-btn:hover { opacity: .9; }
.admin-carte { background: #1c1f26; border: 1px solid #2a2e37; border-radius: 8px; margin-bottom: 20px; overflow: hidden; }
.admin-carte-entete { background: #232730; padding: 12px 18px; font-family: 'Saira', sans-serif; font-weight: 700; font-size: .92rem; color: #fff; }
.admin-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.admin-table th, .admin-table td { padding: 10px 14px; text-align: left; border-bottom: 1px solid #2a2e37; }
.admin-table th { color: #8b919c; font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.admin-flash { padding: 12px 16px; border-radius: 4px; margin-bottom: 18px; font-size: .9rem; }
.admin-flash-ok { background: rgba(31,122,77,.18); border: 1px solid #1f7a4d; color: #7ee0a8; }
.admin-flash-err { background: rgba(192,57,43,.18); border: 1px solid #c0392b; color: #f0a39b; }
.badge-rub { display: inline-block; font-size: .68rem; font-weight: 800; padding: 3px 7px; border-radius: 3px; background: var(--ambre); color: #14161b; text-transform: uppercase; letter-spacing: .03em; }
