/* ==========================================================================
   Décmobois — feuille de style principale
   Identité « atelier bois » : Fraunces + Inter, vert forêt + miel + noyer.
   ========================================================================== */

:root{
  --bois:#2f5a48;        /* vert forêt, signature */
  --bois-fonce:#234538;
  --bois-clair:#eaf0ea;
  --miel:#b07a2e;        /* miel/chêne, accent chaud */
  --miel-clair:#f2e3c8;
  --noyer:#2c241c;       /* encre noyer */
  --creme:#f4ecdd;       /* fond papier chaud */
  --creme-fonce:#ece1cd;
  --blanc:#fcf8f1;
  --doux:#766a59;        /* texte secondaire */
  --bord:#e2d6c2;
  --bord-fonce:#d2c3a9;
  --rouge:#b5573a;
  --ombre:0 18px 40px -24px rgba(44,36,28,.5);
  --ombre-douce:0 10px 26px -20px rgba(44,36,28,.45);
  --rayon:14px;
  --rayon-s:9px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Inter","Segoe UI",system-ui,sans-serif;
  --largeur:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--noyer);
  background:var(--creme);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--bois);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.15;color:var(--noyer);margin:0 0 .5em}
em{font-style:italic}

.contenant{max-width:var(--largeur);margin:0 auto;padding:0 24px}

.saut-contenu{position:absolute;left:-999px;top:0;background:var(--bois);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:2000}
.saut-contenu:focus{left:0}

.surtitre{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--miel);margin-bottom:14px;
}
.surtitre::before{content:"";width:26px;height:2px;background:var(--miel);display:inline-block}

/* ---------- Boutons ---------- */
.bouton{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);
  font-weight:600;font-size:.96rem;padding:13px 24px;border-radius:40px;
  border:1.5px solid transparent;cursor:pointer;transition:transform .15s,background .2s,color .2s;
}
.bouton:hover{text-decoration:none;transform:translateY(-2px)}
.bouton-bois{background:var(--bois);color:#fff}
.bouton-bois:hover{background:var(--bois-fonce);color:#fff}
.bouton-ligne{border-color:var(--bord-fonce);color:var(--noyer);background:transparent}
.bouton-ligne:hover{border-color:var(--bois);color:var(--bois)}

.lien-fleche{
  display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--bois);
  font-family:var(--sans);font-size:.95rem;
}
.lien-fleche::after{content:"›";font-size:1.3em;line-height:1;transition:transform .15s}
.lien-fleche:hover{text-decoration:none}
.lien-fleche:hover::after{transform:translateX(4px)}

.etiquette{
  display:inline-block;font-family:var(--sans);font-weight:700;font-size:.72rem;
  letter-spacing:.07em;text-transform:uppercase;color:var(--bois);
  background:var(--bois-clair);padding:5px 12px;border-radius:30px;
}
a.etiquette:hover{background:var(--bois);color:#fff;text-decoration:none}

/* ==========================================================================
   En-tête
   ========================================================================== */
.entete{
  position:sticky;top:0;z-index:900;background:rgba(252,248,241,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--bord);
}
.entete-rang{display:flex;align-items:center;gap:24px;min-height:90px}
.enseigne{display:flex;align-items:center}
.enseigne-image{height:80px;width:auto}
.navigation{margin-left:auto}
.navigation ul{display:flex;gap:4px;list-style:none;margin:0;padding:0}
.navigation a{
  font-family:var(--sans);font-weight:600;font-size:.95rem;color:var(--noyer);
  padding:9px 14px;border-radius:30px;transition:color .15s,background .15s;
}
.navigation a:hover{color:var(--bois);background:var(--bois-clair);text-decoration:none}

.outils-entete{display:flex;align-items:center;gap:6px}
.declencheur-recherche,.declencheur-menu{
  background:none;border:1px solid var(--bord);border-radius:50%;width:42px;height:42px;
  display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--noyer);
}
.declencheur-recherche svg{width:20px;height:20px}
.declencheur-recherche:hover,.declencheur-menu:hover{border-color:var(--bois);color:var(--bois)}
.declencheur-menu{flex-direction:column;gap:4px;display:none}
.declencheur-menu span{width:18px;height:2px;background:currentColor;border-radius:2px}

.voile-recherche{border-top:1px solid var(--bord);background:var(--blanc);padding:16px 0}
.voile-recherche[hidden]{display:none}
.voile-recherche .contenant{display:flex;gap:10px}
.voile-recherche input{
  flex:1;padding:13px 16px;border:1px solid var(--bord);border-radius:30px;font:inherit;background:var(--creme);
}
.voile-recherche input:focus{outline:none;border-color:var(--bois)}
.voile-recherche button{
  padding:13px 24px;border:none;border-radius:30px;background:var(--bois);color:#fff;font:inherit;font-weight:600;cursor:pointer;
}

.menu-mobile{border-top:1px solid var(--bord);background:var(--blanc)}
.menu-mobile[hidden]{display:none}
.menu-mobile ul{list-style:none;margin:0;padding:10px 24px 18px}
.menu-mobile a{display:block;padding:12px 4px;border-bottom:1px solid var(--bord);font-weight:600;color:var(--noyer)}

/* ==========================================================================
   Accueil — bandeau
   ========================================================================== */
.bandeau{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 80% at 85% -10%, rgba(176,122,46,.10), transparent 60%),
    linear-gradient(180deg, #f7f0e3 0%, var(--creme) 100%);
  border-bottom:1px solid var(--bord);
}
.bandeau::before{
  /* fines stries verticales évoquant le veinage du bois */
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:repeating-linear-gradient(90deg, rgba(44,36,28,.025) 0 2px, transparent 2px 7px);
}
.bandeau-rang{
  position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center;
  padding:64px 24px 70px;
}
.bandeau-texte h1{font-size:clamp(2.3rem,5vw,3.5rem);letter-spacing:-.01em}
.bandeau-texte h1 em{color:var(--bois);font-style:italic}
.bandeau-intro{font-size:1.12rem;color:var(--doux);max-width:38ch;margin:0 0 26px}
.bandeau-actions{display:flex;flex-wrap:wrap;gap:12px}
.bandeau-reperes{
  display:flex;gap:30px;list-style:none;margin:32px 0 0;padding:24px 0 0;border-top:1px solid var(--bord);
  font-size:.92rem;color:var(--doux);
}
.bandeau-reperes strong{display:block;font-family:var(--serif);font-size:1.5rem;color:var(--bois);font-weight:600}

.bandeau-visuel{position:relative}
.bandeau-image{
  width:100%;aspect-ratio:8/7;object-fit:cover;border-radius:20px;
  box-shadow:var(--ombre);border:6px solid var(--blanc);
}
.badge-une{
  position:absolute;left:-18px;bottom:26px;max-width:74%;
  background:var(--blanc);border:1px solid var(--bord);border-left:4px solid var(--miel);
  border-radius:12px;padding:14px 18px;box-shadow:var(--ombre-douce);
}
.badge-une:hover{text-decoration:none;transform:translateY(-2px);transition:transform .15s}
.badge-une-sur{display:block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--miel);margin-bottom:4px}
.badge-une-titre{display:block;font-family:var(--serif);font-size:1.06rem;color:var(--noyer);line-height:1.3}

/* ---------- Repères (promesses) ---------- */
.reperes{padding:40px 0;border-bottom:1px solid var(--bord)}
.reperes-grille{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.repere{display:flex;gap:14px;align-items:flex-start}
.repere-icone{
  flex:none;width:46px;height:46px;border-radius:12px;background:var(--bois-clair);color:var(--bois);
  display:inline-flex;align-items:center;justify-content:center;
}
.repere-icone svg{width:24px;height:24px}
.repere-titre{font-family:var(--serif);font-weight:600;font-size:1.05rem;margin:0 0 2px}
.repere-texte{margin:0;font-size:.9rem;color:var(--doux);line-height:1.5}

/* ==========================================================================
   Rangées d'articles
   ========================================================================== */
.rang-articles{padding:54px 0}
.titre-rang{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px}
.titre-rang h2{font-size:1.9rem;margin:0}

/* Carte vedette */
.vedette{
  display:grid;grid-template-columns:1.15fr 1fr;gap:0;background:var(--blanc);
  border:1px solid var(--bord);border-radius:var(--rayon);overflow:hidden;box-shadow:var(--ombre-douce);
}
.vedette-photo{display:block;overflow:hidden}
.vedette-photo img{width:100%;height:100%;min-height:300px;object-fit:cover;transition:transform .5s}
.vedette:hover .vedette-photo img{transform:scale(1.04)}
.vedette-corps{padding:38px 40px;display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.vedette-corps .carte-titre{font-size:1.9rem;margin:0}
.vedette-corps .carte-extrait{color:var(--doux);margin:0}

/* Grille de cartes */
.grille-articles{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.carte{
  background:var(--blanc);border:1px solid var(--bord);border-radius:var(--rayon);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s;
}
.carte:hover{transform:translateY(-4px);box-shadow:var(--ombre)}
.carte-photo{display:block;overflow:hidden;aspect-ratio:3/2}
.carte-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.carte:hover .carte-photo img{transform:scale(1.05)}
.carte-corps{padding:20px 22px 24px;display:flex;flex-direction:column;align-items:flex-start;gap:11px;flex:1}
.carte-titre{font-size:1.22rem;margin:0;line-height:1.25}
.carte-titre a{color:var(--noyer)}
.carte-titre a:hover{color:var(--bois);text-decoration:none}
.carte-extrait{font-size:.94rem;color:var(--doux);margin:0}
.carte-meta{font-size:.82rem;color:var(--doux);margin:0 0 0;font-family:var(--sans)}

/* ---------- Univers ---------- */
.univers{padding:54px 0;background:linear-gradient(180deg,var(--creme-fonce),var(--creme))}
.grille-univers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tuile-univers{
  display:flex;flex-direction:column;gap:10px;padding:26px 24px;background:var(--blanc);
  border:1px solid var(--bord);border-radius:var(--rayon);transition:transform .18s,box-shadow .18s,border-color .18s;
}
.tuile-univers:hover{text-decoration:none;transform:translateY(-4px);box-shadow:var(--ombre);border-color:var(--bord-fonce)}
.tuile-univers-icone{
  width:52px;height:52px;border-radius:14px;background:var(--bois-clair);color:var(--bois);
  display:inline-flex;align-items:center;justify-content:center;
}
.tuile-univers-icone svg{width:28px;height:28px}
.tuile-univers-nom{font-family:var(--serif);font-weight:600;font-size:1.35rem;color:var(--noyer)}
.tuile-univers-texte{font-size:.92rem;color:var(--doux);flex:1}
.tuile-univers-compte{font-size:.8rem;font-weight:700;color:var(--miel);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Invitation ---------- */
.invitation{padding:0 0 64px}
.invitation-rang{
  display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
  background:var(--bois);color:#fff;border-radius:20px;padding:44px 48px;
  background-image:radial-gradient(120% 120% at 100% 0, rgba(176,122,46,.35), transparent 55%);
}
.invitation-rang h2{color:#fff;font-size:1.9rem;margin:.2em 0}
.invitation-rang .surtitre{color:var(--miel-clair)}
.invitation-rang .surtitre::before{background:var(--miel-clair)}
.invitation-rang p{margin:0;color:rgba(255,255,255,.85);max-width:46ch}
.invitation-rang .bouton-bois{background:var(--miel);color:#fff;flex:none}
.invitation-rang .bouton-bois:hover{background:#9a6a26}

/* ==========================================================================
   Fil d'Ariane
   ========================================================================== */
.fil{background:var(--creme-fonce);border-bottom:1px solid var(--bord);font-family:var(--sans)}
.fil ol{display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin:0;padding:12px 0;font-size:.85rem;color:var(--doux)}
.fil li{display:flex;align-items:center;gap:6px}
.fil li:not(:last-child)::after{content:"›";color:var(--bord-fonce)}
.fil a{color:var(--doux)}
.fil a:hover{color:var(--bois)}
.fil [aria-current="page"]{color:var(--noyer);font-weight:600}

/* ==========================================================================
   En-tête de rubrique / recherche
   ========================================================================== */
.entete-rubrique{background:linear-gradient(180deg,#f7f0e3,var(--creme));border-bottom:1px solid var(--bord);padding:46px 0}
.entete-rubrique-rang{display:flex;align-items:center;gap:22px}
.entete-rubrique-icone{
  flex:none;width:66px;height:66px;border-radius:18px;background:var(--bois);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.entete-rubrique-icone svg{width:34px;height:34px}
.entete-rubrique-titre{font-size:clamp(2rem,4vw,2.7rem);margin:.1em 0}
.entete-rubrique-titre em{color:var(--bois);font-style:italic}
.entete-rubrique-intro{margin:0;color:var(--doux);font-size:1.05rem;max-width:60ch}

.entete-recherche{background:linear-gradient(180deg,#f7f0e3,var(--creme));border-bottom:1px solid var(--bord);padding:44px 0}
.entete-recherche h1{font-size:2rem;margin:0 0 .2em}
.entete-recherche p{color:var(--doux);margin:0 0 18px}
.recherche-champ{display:flex;gap:10px;max-width:560px}
.recherche-champ input{flex:1;padding:13px 16px;border:1px solid var(--bord);border-radius:30px;font:inherit;background:var(--blanc)}
.recherche-champ input:focus{outline:none;border-color:var(--bois)}
.recherche-champ button{padding:13px 24px;border:none;border-radius:30px;background:var(--bois);color:#fff;font:inherit;font-weight:600;cursor:pointer}

/* Grille rubriques (page /rubriques/) */
.grille-rubriques-page{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.carte-rubrique{
  display:flex;flex-direction:column;gap:8px;padding:30px 28px;background:var(--blanc);
  border:1px solid var(--bord);border-radius:var(--rayon);transition:transform .18s,box-shadow .18s;
}
.carte-rubrique:hover{text-decoration:none;transform:translateY(-4px);box-shadow:var(--ombre)}
.carte-rubrique-icone{width:56px;height:56px;border-radius:15px;background:var(--bois-clair);color:var(--bois);display:inline-flex;align-items:center;justify-content:center}
.carte-rubrique-icone svg{width:30px;height:30px}
.carte-rubrique h2{margin:6px 0 0;font-size:1.4rem}
.carte-rubrique p{margin:0;color:var(--doux);font-size:.94rem;flex:1}
.carte-rubrique-compte{font-size:.8rem;font-weight:700;color:var(--miel);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Pagination ---------- */
.pagination{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:44px}
.lien-page{
  min-width:44px;text-align:center;padding:10px 14px;border:1px solid var(--bord);border-radius:10px;
  background:var(--blanc);color:var(--noyer);font-weight:600;font-family:var(--sans);
}
.lien-page:hover{border-color:var(--bois);color:var(--bois);text-decoration:none}
.lien-page[aria-current="page"]{background:var(--bois);color:#fff;border-color:var(--bois)}

.message-vide{color:var(--doux);background:var(--blanc);border:1px dashed var(--bord-fonce);border-radius:var(--rayon);padding:30px;text-align:center}

/* ==========================================================================
   Article
   ========================================================================== */
.article{padding:42px 0 10px}
.article-rang{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:52px;align-items:start}
.article-entete{margin-bottom:24px}
.article-entete h1{font-size:clamp(2rem,4.2vw,2.9rem);margin:.25em 0 .2em;letter-spacing:-.01em}
.article-meta{font-family:var(--sans);font-size:.9rem;color:var(--doux);margin:0}
.article-image{margin:0 0 30px}
.article-image img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:18px;border:5px solid var(--blanc);box-shadow:var(--ombre-douce)}

/* Typographie du contenu */
.article-contenu{font-size:1.08rem}
.article-contenu > p{margin:0 0 1.3em}
.article-contenu > p:first-of-type{font-size:1.16rem;color:#473c30}
.article-contenu h2{font-size:1.7rem;margin:1.7em 0 .5em;padding-top:.2em}
.article-contenu h2::before{content:"";display:block;width:46px;height:3px;background:var(--miel);border-radius:3px;margin-bottom:.5em}
.article-contenu h3{font-size:1.3rem;margin:1.5em 0 .4em}
.article-contenu a{color:var(--bois);text-decoration:underline;text-decoration-color:var(--bord-fonce);text-underline-offset:3px}
.article-contenu a:hover{text-decoration-color:var(--bois)}
.article-contenu ul,.article-contenu ol{margin:0 0 1.4em;padding-left:1.3em}
.article-contenu li{margin-bottom:.5em}
.article-contenu ul li::marker{color:var(--miel)}
.article-contenu img{border-radius:12px;margin:1.5em 0}
.article-contenu img.img-petite{max-width:300px}
.article-contenu img.img-moyenne{max-width:500px}
.article-contenu img.img-grande{max-width:100%}
.article-contenu img.img-centre{margin-left:auto;margin-right:auto}
.article-contenu img.img-gauche{float:left;margin:.4em 1.6em 1em 0;max-width:46%}
.article-contenu img.img-droite{float:right;margin:.4em 0 1em 1.6em;max-width:46%}
.article-contenu figcaption{font-size:.85rem;color:var(--doux);text-align:center;margin-top:-.6em;margin-bottom:1.6em;font-style:italic}
.article-contenu blockquote{
  margin:1.6em 0;padding:6px 0 6px 24px;border-left:4px solid var(--miel);
  font-family:var(--serif);font-size:1.25rem;font-style:italic;color:var(--bois-fonce);
}
.article-contenu hr{border:none;border-top:1px solid var(--bord);margin:2.4em 0}

.article-retour{margin:34px 0 10px;padding-top:22px;border-top:1px solid var(--bord)}

/* ---------- Colonne latérale ---------- */
.colonne-laterale{position:sticky;top:96px;display:flex;flex-direction:column;gap:24px}
.bloc-lateral{background:var(--blanc);border:1px solid var(--bord);border-radius:var(--rayon);padding:22px}
.bloc-lateral h2{font-size:1.05rem;margin:0 0 14px;padding-bottom:12px;border-bottom:1px solid var(--bord)}
.liste-laterale{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.liste-laterale a{display:flex;gap:12px;align-items:center;color:var(--noyer)}
.liste-laterale a:hover{color:var(--bois);text-decoration:none}
.liste-laterale img{width:72px;height:56px;object-fit:cover;border-radius:8px;flex:none}
.liste-laterale span{font-size:.92rem;font-weight:500;line-height:1.3}
.liste-rubriques-laterale{list-style:none;margin:0;padding:0}
.liste-rubriques-laterale a{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--bord);color:var(--noyer);font-weight:500}
.liste-rubriques-laterale a:hover{color:var(--bois);text-decoration:none}
.liste-rub-icone{width:24px;height:24px;color:var(--miel);flex:none}
.liste-rub-icone svg{width:24px;height:24px}
.liste-rub-compte{margin-left:auto;font-size:.78rem;font-weight:700;color:var(--doux);background:var(--creme);border-radius:20px;padding:2px 9px}

/* ---------- À lire aussi ---------- */
.a-lire-aussi{padding:54px 0 70px;border-top:1px solid var(--bord);background:var(--creme-fonce);margin-top:30px}
.a-lire-aussi h2{font-size:1.7rem;margin:0 0 26px}

/* ==========================================================================
   Composants éditoriaux réutilisables (dans le contenu)
   ========================================================================== */
/* Encadrés */
.encadre{
  margin:1.8em 0;padding:22px 26px;border-radius:var(--rayon);background:var(--blanc);
  border:1px solid var(--bord);border-left:5px solid var(--bois);
}
.encadre-titre{display:block;font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bois);margin-bottom:8px}
.encadre p:last-child{margin-bottom:0}
.encadre-astuce{background:var(--bois-clair);border-left-color:var(--bois)}
.encadre-astuce .encadre-titre{color:var(--bois-fonce)}
.encadre-attention{background:#fbeee6;border-left-color:var(--rouge)}
.encadre-attention .encadre-titre{color:var(--rouge)}
.encadre-savoir{background:var(--miel-clair);border-left-color:var(--miel)}
.encadre-savoir .encadre-titre{color:#8a5e1f}

/* Chiffres clés */
.cles{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:1.8em 0;padding:0;list-style:none}
.cle{background:var(--blanc);border:1px solid var(--bord);border-top:3px solid var(--miel);border-radius:12px;padding:18px 20px;text-align:center}
.cle-nombre{display:block;font-family:var(--serif);font-size:2rem;font-weight:600;color:var(--bois);line-height:1}
.cle-label{display:block;font-size:.85rem;color:var(--doux);margin-top:6px}

/* Tableaux */
.tableau-defilant{overflow-x:auto;margin:1.8em 0;border-radius:var(--rayon);border:1px solid var(--bord)}
.article-contenu table,.page-edito-contenu table{width:100%;border-collapse:collapse;background:var(--blanc);font-size:.96rem}
.article-contenu th,.article-contenu td,.page-edito-contenu th,.page-edito-contenu td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--bord)}
.article-contenu thead th,.page-edito-contenu thead th{background:var(--bois);color:#fff;font-family:var(--sans);font-weight:600;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;border-bottom:none}
.article-contenu tbody tr:nth-child(even),.page-edito-contenu tbody tr:nth-child(even){background:var(--creme)}
.article-contenu tbody tr:hover,.page-edito-contenu tbody tr:hover{background:var(--miel-clair)}

/* Étapes numérotées */
.etapes{list-style:none;counter-reset:etape;margin:1.8em 0;padding:0;display:flex;flex-direction:column;gap:16px}
.etapes li{position:relative;counter-increment:etape;background:var(--blanc);border:1px solid var(--bord);border-radius:12px;padding:18px 22px 18px 64px}
.etapes li::before{
  content:counter(etape);position:absolute;left:16px;top:16px;width:34px;height:34px;border-radius:50%;
  background:var(--bois);color:#fff;font-family:var(--serif);font-weight:600;
  display:flex;align-items:center;justify-content:center;
}
.etapes strong{display:block;margin-bottom:2px}

/* FAQ accordéon */
.faq{margin:1.8em 0;border:1px solid var(--bord);border-radius:var(--rayon);overflow:hidden;background:var(--blanc)}
.faq-item+.faq-item{border-top:1px solid var(--bord)}
.faq-question{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;font:inherit;font-weight:600;
  color:var(--noyer);padding:18px 50px 18px 22px;position:relative;font-family:var(--serif);font-size:1.12rem;
}
.faq-question::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--miel);transition:transform .2s}
.faq-question[aria-expanded="true"]::after{transform:translateY(-50%) rotate(45deg)}
.faq-reponse{padding:0 22px 20px;color:var(--doux)}
.faq-reponse[hidden]{display:none}
.faq-reponse p{margin:0}

/* Comparateur / verdict simple */
.comparateur{margin:1.8em 0;padding:24px 26px;background:var(--bois);color:#fff;border-radius:var(--rayon)}
.comparateur h3,.comparateur strong{color:#fff}
.comparateur .surtitre{color:var(--miel-clair)}
.comparateur .surtitre::before{background:var(--miel-clair)}

/* Sources */
.sources{margin:2.4em 0 0;padding:22px 24px;background:var(--creme-fonce);border-radius:var(--rayon);font-size:.9rem}
.sources .encadre-titre{color:var(--doux)}
.sources ul{margin:0;padding-left:1.2em}
.sources li{margin-bottom:.4em;color:var(--doux);word-break:break-word}
.sources a{color:var(--bois)}

/* Outil interactif (calculateurs) */
.outil{margin:1.8em 0;padding:26px;background:var(--blanc);border:1px solid var(--bord-fonce);border-radius:var(--rayon);box-shadow:var(--ombre-douce)}
.outil-titre{font-family:var(--serif);font-size:1.35rem;margin:0 0 6px}
.outil-intro{color:var(--doux);margin:0 0 18px;font-size:.95rem}
.outil-champs{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:18px}
.outil-champ{display:flex;flex-direction:column;gap:6px;font-weight:600;font-size:.88rem;color:var(--bois-fonce)}
.outil-champ input,.outil-champ select{padding:11px 13px;border:1px solid var(--bord);border-radius:var(--rayon-s);font:inherit;background:var(--creme)}
.outil-champ input:focus,.outil-champ select:focus{outline:none;border-color:var(--bois)}
.outil-resultat{
  background:var(--bois);color:#fff;border-radius:var(--rayon-s);padding:18px 22px;font-size:1.05rem;
}
.outil-resultat strong{font-family:var(--serif);font-size:1.6rem;color:#fff}
.outil-note{font-size:.82rem;color:var(--doux);margin:12px 0 0}

/* ==========================================================================
   Pages éditoriales (à propos, mentions, etc.)
   ========================================================================== */
.page-edito{padding:46px 0 70px}
.page-edito-cadre{max-width:820px}
.page-edito-titre{font-size:clamp(2rem,4vw,2.7rem);margin:0 0 .5em}
.page-edito-contenu{font-size:1.07rem}
.page-edito-contenu p{margin:0 0 1.3em}
.page-edito-contenu h2{font-size:1.6rem;margin:1.6em 0 .5em}
.page-edito-contenu a{color:var(--bois);text-decoration:underline;text-underline-offset:3px}

/* Plan du site */
.plan-rang{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;max-width:980px}
.plan-bloc h2{display:flex;align-items:center;gap:10px;font-size:1.3rem;border-bottom:2px solid var(--bois-clair);padding-bottom:8px}
.plan-icone{width:26px;height:26px;color:var(--miel)}
.plan-icone svg{width:26px;height:26px}
.plan-bloc ul{list-style:none;margin:14px 0 0;padding:0}
.plan-bloc li{margin-bottom:8px}

/* Contact */
.page-contact{max-width:680px}
.form-contact{display:flex;flex-direction:column;gap:18px;margin-top:26px}
.form-contact label{display:flex;flex-direction:column;gap:7px;font-weight:600;color:var(--bois-fonce)}
.form-contact input,.form-contact textarea{padding:13px 15px;border:1px solid var(--bord);border-radius:var(--rayon-s);font:inherit;background:var(--blanc)}
.form-contact input:focus,.form-contact textarea:focus{outline:none;border-color:var(--bois)}
.form-contact .bouton{align-self:flex-start}
.pot-de-miel{position:absolute;left:-9999px}
.message-ok{background:var(--bois-clair);border-left:4px solid var(--bois);padding:16px 20px;border-radius:0 var(--rayon-s) var(--rayon-s) 0;margin-top:20px}
.message-erreur{background:#fbeee6;border-left:4px solid var(--rouge);padding:16px 20px;border-radius:0 var(--rayon-s) var(--rayon-s) 0;margin-top:20px}

/* ---------- Écrans d'erreur ---------- */
.ecran-erreur{text-align:center;padding:80px 24px 100px;max-width:640px}
.erreur-code{font-family:var(--serif);font-size:5rem;font-weight:700;color:var(--bois);line-height:1}
.ecran-erreur h1{font-size:2rem;margin:.2em 0 .4em}
.ecran-erreur p{color:var(--doux);margin:0 auto 26px;max-width:46ch}
.erreur-liens ul{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;list-style:none;margin:30px 0 0;padding:0}
.erreur-liens a{padding:8px 16px;border:1px solid var(--bord);border-radius:30px;font-weight:600;font-size:.9rem}

/* ==========================================================================
   Pied de page
   ========================================================================== */
.pied{background:var(--noyer);color:#cfc4b4;margin-top:0}
.pied-rang{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding:58px 24px 44px}
.pied-nom{font-family:var(--serif);font-size:1.6rem;font-weight:600;color:#fff}
.pied-baseline{color:var(--miel);font-weight:600;margin:.3em 0 1em;font-size:.95rem}
.pied-mot{font-size:.92rem;line-height:1.6;color:#a99d8b;max-width:42ch}
.pied-bloc h2{font-family:var(--sans);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.pied-bloc ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.pied-bloc a{color:#cfc4b4;font-size:.94rem}
.pied-bloc a:hover{color:#fff}
.pied-socle{border-top:1px solid rgba(255,255,255,.1)}
.pied-socle-rang{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:20px 24px;font-size:.85rem;color:#8d8273}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media(max-width:980px){
  .article-rang{grid-template-columns:1fr;gap:36px}
  .colonne-laterale{position:static}
  .bandeau-rang{grid-template-columns:1fr;gap:34px;padding:44px 24px 50px}
  .bandeau-visuel{order:-1}
  .reperes-grille{grid-template-columns:repeat(2,1fr);gap:20px}
  .grille-articles,.grille-univers,.grille-rubriques-page{grid-template-columns:repeat(2,1fr)}
  .vedette{grid-template-columns:1fr}
  .vedette-photo img{min-height:240px}
  .plan-rang{grid-template-columns:1fr}
  .pied-rang{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:680px){
  body{font-size:16px}
  .navigation{display:none}
  .declencheur-menu{display:inline-flex}
  .grille-articles,.grille-univers,.grille-rubriques-page,.reperes-grille{grid-template-columns:1fr}
  .titre-rang{flex-direction:column;align-items:flex-start;gap:10px}
  .vedette-corps{padding:26px 24px}
  .invitation-rang{padding:32px 26px}
  .entete-rubrique-rang{flex-direction:column;text-align:center;align-items:center}
  .pied-rang{grid-template-columns:1fr}
  .article-contenu img.img-gauche,.article-contenu img.img-droite{float:none;max-width:100%;margin:1.5em 0}
}
