/* ============================================================
   Talents Chez Moi — feuille de style
   Ambiance : atelier maison chaleureux, naturel, éditorial
   Titres : Bricolage Grotesque · Corps : Manrope
   ============================================================ */

:root {
  --vert-fonce:  #2f4739;
  --vert:        #3f5d49;
  --vert-doux:   #5c7a64;
  --vert-pale:   #e9efe8;
  --vert-brume:  #f2f5ef;
  --or:          #bb9658;
  --or-fonce:    #a07e44;
  --or-pale:     #efe4cf;
  --creme:       #f8f3ea;
  --creme-alt:   #fdfaf3;
  --blanc:       #ffffff;
  --encre:       #2a261f;
  --encre-doux:  #6b6358;
  --bordure:     rgba(47,71,57,0.14);
  --bordure-or:  rgba(187,150,88,0.30);
  --ombre:       0 14px 38px -22px rgba(47,71,57,0.45);
  --ombre-douce: 0 4px 16px -10px rgba(47,71,57,0.35);
  --rayon:       7px;
  --rayon-grand: 16px;
  --large:       1220px;
  --etroit:      760px;
  --titre: "Bricolage Grotesque", "Segoe UI", sans-serif;
  --corps: "Manrope", "Segoe UI", system-ui, sans-serif;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--corps);
  font-size: 18px;
  line-height: 1.75;
  color: var(--encre);
  background: var(--creme);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: var(--titre); line-height: 1.15; color: var(--vert-fonce); margin: 0 0 .5em; font-weight: 700; letter-spacing: -0.01em; }

a { color: var(--vert); }
img { max-width: 100%; height: auto; display: block; }

.enveloppe { max-width: var(--large); margin: 0 auto; padding: 0 26px; }
.enveloppe-etroite { max-width: var(--etroit); }

.lien-evitement {
  position: absolute; left: -9999px; top: 0; background: var(--vert-fonce); color: #fff;
  padding: 10px 16px; z-index: 200; border-radius: 0 0 6px 0;
}
.lien-evitement:focus { left: 0; }

:focus-visible { outline: 3px solid var(--or); outline-offset: 2px; }

/* ---------- En-tête ---------- */
.barre-entete {
  background: var(--creme-alt);
  border-bottom: 1px solid var(--bordure);
  position: sticky; top: 0; z-index: 100;
}
.barre-entete-inner { display: flex; align-items: center; gap: 28px; min-height: 84px; }
.enseigne { flex: 0 0 auto; display: flex; align-items: center; }
.enseigne-logo { height: 64px; width: auto; }

.menu-atelier { margin-left: auto; }
.menu-atelier ul { display: flex; gap: 4px; list-style: none; margin: 0; padding: 0; }
.menu-atelier a {
  display: block; padding: 9px 14px; text-decoration: none; color: var(--encre);
  font-weight: 600; font-size: .96rem; border-radius: 5px; transition: background .15s, color .15s;
}
.menu-atelier a:hover { background: var(--vert-pale); color: var(--vert-fonce); }

.outils-entete { display: flex; align-items: center; gap: 6px; }
.bouton-loupe, .bouton-burger {
  background: none; border: 1px solid var(--bordure); border-radius: 6px; cursor: pointer;
  width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; color: var(--vert-fonce);
}
.bouton-loupe svg { width: 20px; height: 20px; }
.bouton-burger { flex-direction: column; gap: 4px; }
.bouton-burger span { width: 20px; height: 2px; background: var(--vert-fonce); border-radius: 2px; transition: .2s; }
.bouton-burger { display: none; }

.volet-recherche { background: var(--vert-fonce); padding: 18px 0; }
.volet-recherche .enveloppe { display: flex; gap: 10px; }
.volet-recherche input {
  flex: 1; padding: 13px 16px; border: none; border-radius: var(--rayon); font: inherit; font-size: 1rem;
}
.volet-recherche button {
  padding: 0 22px; background: var(--or); color: #2a2113; border: none; border-radius: var(--rayon);
  font-family: var(--titre); font-weight: 700; cursor: pointer; font-size: 1rem;
}

.menu-mobile { background: var(--creme-alt); border-bottom: 1px solid var(--bordure); }
.menu-mobile ul { list-style: none; margin: 0; padding: 8px 26px 16px; }
.menu-mobile a { display: block; padding: 12px 6px; text-decoration: none; color: var(--encre); font-weight: 600; border-bottom: 1px solid var(--bordure); }

/* ---------- Boutons ---------- */
.bouton-vert, .bouton-fil, .bouton-clair {
  display: inline-block; text-decoration: none; font-family: var(--titre); font-weight: 700;
  padding: 13px 26px; border-radius: var(--rayon); font-size: 1rem; cursor: pointer; border: 2px solid transparent; transition: .18s;
}
.bouton-vert { background: var(--vert-fonce); color: #fff; }
.bouton-vert:hover { background: var(--vert); }
.bouton-fil { background: transparent; color: var(--vert-fonce); border-color: var(--vert-fonce); }
.bouton-fil:hover { background: var(--vert-fonce); color: #fff; }
.bouton-clair { background: var(--or); color: #2a2113; }
.bouton-clair:hover { background: var(--or-fonce); color: #fff; }

/* ---------- Accroche accueil ---------- */
.accroche-maison { background: linear-gradient(180deg, var(--creme-alt), var(--creme)); padding: 56px 0 64px; }
.accroche-grille { display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: center; }
.accroche-eyebrow {
  display: inline-block; font-family: var(--titre); font-weight: 600; font-size: .82rem; letter-spacing: .08em;
  text-transform: uppercase; color: var(--or-fonce); margin-bottom: 16px;
}
.accroche-texte h1 { font-size: clamp(2.1rem, 4.4vw, 3.3rem); font-weight: 800; }
.accroche-intro { font-size: 1.16rem; color: var(--encre-doux); max-width: 46ch; margin: 18px 0 28px; }
.accroche-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.accroche-visuel { position: relative; }
.accroche-visuel img { border-radius: var(--rayon-grand); box-shadow: var(--ombre); width: 100%; object-fit: cover; aspect-ratio: 12/7; }
.vignette-flottante {
  position: absolute; left: 24px; bottom: -22px; right: auto; max-width: 320px;
  background: var(--blanc); border-radius: var(--rayon); padding: 16px 20px; box-shadow: var(--ombre);
  text-decoration: none; border-left: 4px solid var(--or);
}
.vignette-flottante-label { display: block; font-family: var(--titre); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--or-fonce); margin-bottom: 4px; }
.vignette-flottante-titre { display: block; font-family: var(--titre); font-weight: 700; color: var(--vert-fonce); line-height: 1.25; }

/* ---------- Rubriques (établi) ---------- */
.rubriques-etabli { padding: 46px 0 8px; }
.liste-tuiles { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.tuile-rubrique {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 8px;
  padding: 22px 14px; background: var(--creme-alt); border: 1px solid var(--bordure); border-radius: var(--rayon);
  text-decoration: none; transition: .18s; height: 100%;
}
.tuile-rubrique:hover { border-color: var(--bordure-or); box-shadow: var(--ombre-douce); transform: translateY(-3px); }
.tuile-icone { width: 42px; height: 42px; color: var(--vert); }
.tuile-icone svg { width: 100%; height: 100%; }
.tuile-nom { font-family: var(--titre); font-weight: 700; color: var(--vert-fonce); font-size: 1.02rem; }
.tuile-compte { color: var(--or-fonce); font-size: .85rem; }
.tuile-accroche { font-size: .82rem; color: var(--encre-doux); line-height: 1.4; }

/* ---------- Titre de rang ---------- */
.titre-rang { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin: 0 0 26px; padding-bottom: 12px; border-bottom: 2px solid var(--vert-fonce); }
.titre-rang h2 { font-size: 1.7rem; margin: 0; }
.lien-rang { font-family: var(--titre); font-weight: 600; font-size: .92rem; text-decoration: none; color: var(--or-fonce); white-space: nowrap; }
.lien-rang:hover { text-decoration: underline; }

/* ---------- Sélection à la une ---------- */
.selection-une { padding: 56px 0; }
.selection-grille { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: start; }
.une-projet-photo { display: block; border-radius: var(--rayon-grand); overflow: hidden; }
.une-projet-photo img { width: 100%; aspect-ratio: 16/10; object-fit: cover; transition: transform .4s; }
.une-projet-photo:hover img { transform: scale(1.03); }
.une-projet-corps { padding-top: 18px; }
.une-projet-corps h3 { font-size: 1.6rem; margin: 12px 0 10px; }
.une-projet-corps h3 a { text-decoration: none; color: var(--vert-fonce); }
.une-projet-corps h3 a:hover { color: var(--or-fonce); }
.une-projet-corps p { color: var(--encre-doux); margin: 0 0 14px; }

.etiquette-rubrique {
  display: inline-block; font-family: var(--titre); font-weight: 600; font-size: .74rem; letter-spacing: .07em;
  text-transform: uppercase; color: var(--vert-fonce); background: var(--vert-pale); padding: 5px 12px;
  border-radius: 40px; text-decoration: none;
}
.etiquette-rubrique:hover { background: var(--or-pale); color: var(--or-fonce); }
.lien-lire { font-family: var(--titre); font-weight: 700; color: var(--vert); text-decoration: none; border-bottom: 2px solid var(--or); padding-bottom: 2px; }
.lien-lire:hover { color: var(--or-fonce); }

.liste-une { list-style: none; margin: 0; padding: 0; }
.liste-une li { display: flex; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--bordure); }
.liste-une li:first-child { padding-top: 0; }
.liste-une-rang { font-family: var(--titre); font-weight: 800; font-size: 1.5rem; color: var(--or-pale); line-height: 1; flex: 0 0 auto; }
.liste-une-cat { font-size: .76rem; text-transform: uppercase; letter-spacing: .06em; color: var(--or-fonce); font-weight: 600; }
.liste-une-corps h3 { font-size: 1.06rem; margin: 4px 0 0; line-height: 1.3; }
.liste-une-corps h3 a { text-decoration: none; color: var(--vert-fonce); }
.liste-une-corps h3 a:hover { color: var(--or-fonce); }

/* ---------- Grille de feuillets (cards) ---------- */
.derniers-projets { padding: 24px 0 60px; }
.grille-projets { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 26px; }
.feuillet-projet { display: flex; flex-direction: column; }
.feuillet-photo { display: block; border-radius: var(--rayon); overflow: hidden; }
.feuillet-photo img { width: 100%; aspect-ratio: 3/2; object-fit: cover; transition: transform .4s; }
.feuillet-photo:hover img { transform: scale(1.04); }
.feuillet-corps { padding-top: 14px; }
.feuillet-cat { display: block; font-family: var(--titre); font-weight: 600; font-size: .74rem; letter-spacing: .06em; text-transform: uppercase; color: var(--or-fonce); margin-bottom: 6px; }
.feuillet-corps h2, .feuillet-corps h3 { font-size: 1.12rem; margin: 0; line-height: 1.3; }
.feuillet-corps h2 a, .feuillet-corps h3 a { text-decoration: none; color: var(--vert-fonce); }
.feuillet-corps h2 a:hover, .feuillet-corps h3 a:hover { color: var(--or-fonce); }
.feuillet-extrait { color: var(--encre-doux); font-size: .94rem; margin: 8px 0 0; }

/* ---------- Galerie inspiration ---------- */
.galerie-inspiration { padding: 8px 0 64px; }
.bande-galerie { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
.vignette-inspiration { position: relative; display: block; border-radius: var(--rayon); overflow: hidden; aspect-ratio: 1/1; }
.vignette-inspiration img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.vignette-inspiration:hover img { transform: scale(1.06); }
.vignette-legende {
  position: absolute; inset: auto 0 0 0; padding: 26px 12px 10px; color: #fff; font-size: .78rem; font-weight: 600;
  font-family: var(--titre); line-height: 1.2;
  background: linear-gradient(transparent, rgba(30,42,33,.88)); opacity: 0; transition: opacity .2s;
}
.vignette-inspiration:hover .vignette-legende { opacity: 1; }

/* ---------- Bandeau explorer (CTA) ---------- */
.bandeau-explorer { background: var(--vert-fonce); color: #fff; }
.bandeau-explorer-inner { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 48px 0; }
.bandeau-explorer h2 { color: #fff; font-size: 1.7rem; margin: 0 0 8px; }
.bandeau-explorer p { color: rgba(255,255,255,.82); margin: 0; max-width: 52ch; }

/* ---------- Fil d'Ariane ---------- */
.fil-ariane { background: var(--creme-alt); border-bottom: 1px solid var(--bordure); }
.fil-ariane ol { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; margin: 0; padding: 12px 0; font-size: .86rem; }
.fil-ariane li { color: var(--encre-doux); }
.fil-ariane li:not(:last-child)::after { content: "›"; margin-left: 8px; color: var(--or); }
.fil-ariane a { color: var(--vert); text-decoration: none; }
.fil-ariane a:hover { text-decoration: underline; }
.fil-ariane li[aria-current] { color: var(--encre); font-weight: 600; }

/* ---------- Page article ---------- */
.page-projet { padding: 40px 0 60px; }
.page-projet-grille { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 52px; align-items: start; }
.corps-projet { min-width: 0; max-width: 820px; }
.projet-entete h1 { font-size: clamp(1.9rem, 3.6vw, 2.7rem); font-weight: 800; margin-top: 10px; }
.projet-meta { color: var(--encre-doux); font-size: .92rem; display: flex; gap: 10px; align-items: center; margin: 0 0 6px; }
.projet-meta-sep { color: var(--or); }
.projet-photo-une { margin: 22px 0 30px; border-radius: var(--rayon-grand); overflow: hidden; }
.projet-photo-une img { width: 100%; max-height: 480px; object-fit: cover; }

.projet-contenu { font-size: 1.08rem; overflow-wrap: break-word; }
.tableau-defilant { overflow-x: auto; margin: 1.6em 0; }
.tableau-defilant table { margin: 0; }
.projet-contenu p { margin: 0 0 1.3em; }
.projet-contenu h2 { font-size: 1.62rem; margin: 1.9em 0 .6em; padding-top: .3em; }
.projet-contenu h2::before { content: ""; display: block; width: 46px; height: 3px; background: var(--or); border-radius: 2px; margin-bottom: 16px; }
.projet-contenu h3 { font-size: 1.28rem; margin: 1.5em 0 .5em; }
.projet-contenu a { color: var(--vert); text-decoration: underline; text-decoration-color: var(--or-pale); text-underline-offset: 2px; }
.projet-contenu a:hover { text-decoration-color: var(--or); }
.projet-contenu img { border-radius: var(--rayon); margin: 1.4em 0; }
.projet-contenu figure { margin: 1.6em 0; }
.projet-contenu figcaption { font-size: .85rem; color: var(--encre-doux); text-align: center; margin-top: 8px; font-style: italic; }
.projet-contenu ul, .projet-contenu ol { margin: 0 0 1.3em; padding-left: 1.3em; }
.projet-contenu li { margin-bottom: .5em; }
.projet-contenu ul li::marker { color: var(--or); }
.projet-contenu blockquote {
  margin: 1.6em 0; padding: 18px 24px; background: var(--vert-brume); border-left: 4px solid var(--vert);
  border-radius: 0 var(--rayon) var(--rayon) 0; font-size: 1.05rem; color: var(--vert-fonce);
}
.projet-contenu table { width: 100%; border-collapse: collapse; margin: 1.6em 0; font-size: .96rem; }
.projet-contenu th, .projet-contenu td { padding: 11px 14px; border: 1px solid var(--bordure); text-align: left; }
.projet-contenu th { background: var(--vert-pale); font-family: var(--titre); color: var(--vert-fonce); }

/* ---------- Composants éditoriaux (contenu d'article) ---------- */
/* Encadrés */
.encadre { position: relative; margin: 1.9em 0; padding: 20px 24px; border-radius: var(--rayon); border: 1px solid var(--bordure); border-left: 5px solid var(--vert); background: var(--vert-brume); box-shadow: var(--ombre-douce); }
.encadre p:last-child { margin-bottom: 0; }
.encadre-titre { display: inline-flex; align-items: center; gap: 9px; font-family: var(--titre); font-weight: 700; font-size: .82rem; text-transform: uppercase; letter-spacing: .09em; margin-bottom: 10px; }
.encadre-titre::before { content: ""; width: 10px; height: 10px; border-radius: 2px; background: currentColor; flex-shrink: 0; }
.encadre-retenir { border-left-color: var(--vert); background: var(--vert-pale); }
.encadre-retenir .encadre-titre { color: var(--vert-fonce); }
.encadre-savoir { border-left-color: var(--or); background: var(--or-pale); }
.encadre-savoir .encadre-titre { color: var(--or-fonce); }
.encadre-attention { border-left-color: #c0683b; background: #f7e9e0; }
.encadre-attention .encadre-titre { color: #9d4f29; }

/* Cellules de tableau évaluatives */
.eval-bon { background: rgba(63,93,73,.14); color: var(--vert-fonce); font-weight: 600; }
.eval-moyen { background: rgba(187,150,88,.18); color: var(--or-fonce); font-weight: 600; }
.eval-faible { background: rgba(192,104,59,.15); color: #9d4f29; font-weight: 600; }

/* Graphe SVG inline */
.graphe { margin: 1.8em 0; text-align: center; }
.graphe svg { max-width: 100%; height: auto; }
.graphe-legende { font-size: .85rem; color: var(--encre-doux); margin-top: 8px; font-style: italic; }

/* Simulateur / calculateur */
.simulateur { margin: 2em 0; padding: 24px 24px 26px; border: 1px solid var(--bordure-or); border-top: 4px solid var(--or); border-radius: var(--rayon-grand); background: var(--creme-alt); box-shadow: var(--ombre-douce); }
.simulateur-titre { font-family: var(--titre); font-weight: 700; font-size: 1.2rem; color: var(--vert-fonce); margin: 0 0 4px; }
.simulateur-intro { font-size: .94rem; color: var(--encre-doux); margin: 0 0 18px; }
.simulateur-champ { margin-bottom: 16px; }
.simulateur-champ label { display: block; font-weight: 600; font-size: .92rem; margin-bottom: 6px; color: var(--vert-fonce); }
.simulateur-champ input[type="number"], .simulateur-champ input[type="text"], .simulateur-champ select { width: 100%; padding: 11px 13px; font-family: var(--corps); font-size: 1rem; border: 1px solid var(--bordure); border-radius: var(--rayon); background: var(--blanc); color: var(--encre); }
.simulateur-champ input[type="range"] { width: 100%; accent-color: var(--vert); }
.simulateur-champ .valeur-curseur { font-weight: 700; color: var(--or-fonce); }
.simulateur-grille { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 18px; }
.simulateur-resultat { margin-top: 18px; padding: 18px 20px; border-radius: var(--rayon); background: var(--vert-fonce); color: #fff; }
.simulateur-resultat .res-valeur { display: block; font-family: var(--titre); font-weight: 800; font-size: 1.9rem; line-height: 1.2; color: #fff; }
.simulateur-resultat .res-detail { display: block; font-size: .9rem; color: rgba(255,255,255,.82); margin-top: 6px; }
.simulateur-note { font-size: .8rem; color: var(--encre-doux); margin-top: 12px; font-style: italic; }
@media (max-width: 560px) { .simulateur-grille { grid-template-columns: 1fr; } }

/* Checklist interactive */
.check-liste { display: flex; flex-direction: column; gap: 10px; margin: 4px 0; }
.check-liste label { display: flex; gap: 11px; align-items: flex-start; font-size: .97rem; cursor: pointer; line-height: 1.5; }
.check-liste input[type="checkbox"] { margin: 4px 0 0; width: 18px; height: 18px; flex-shrink: 0; accent-color: var(--vert); }

/* Étapes numérotées enrichies */
.etapes { list-style: none; counter-reset: et; padding-left: 0; margin: 1.6em 0; }
.etapes > li { counter-increment: et; position: relative; padding-left: 52px; margin-bottom: 1.1em; }
.etapes > li::before { content: counter(et); position: absolute; left: 0; top: -2px; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--vert); color: #fff; font-family: var(--titre); font-weight: 700; border-radius: 50%; }
.cadre-video { display: block; position: relative; padding-bottom: 56.25%; height: 0; margin: 1.6em 0; border-radius: var(--rayon); overflow: hidden; }
.cadre-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.projet-retour { margin-top: 36px; padding-top: 20px; border-top: 1px solid var(--bordure); }
.projet-retour a { font-family: var(--titre); font-weight: 600; text-decoration: none; color: var(--vert); }
.projet-retour a:hover { color: var(--or-fonce); }

/* ---------- Colonne latérale ---------- */
.colonne-laterale { position: sticky; top: 104px; display: flex; flex-direction: column; gap: 28px; }
.bloc-lateral { background: var(--creme-alt); border: 1px solid var(--bordure); border-radius: var(--rayon); padding: 22px; }
.bloc-lateral h2 { font-size: 1.06rem; margin: 0 0 16px; padding-bottom: 10px; border-bottom: 2px solid var(--or-pale); }
.bloc-meme-rubrique ul { list-style: none; margin: 0; padding: 0; }
.bloc-meme-rubrique li { margin-bottom: 14px; }
.bloc-meme-rubrique a { display: flex; gap: 12px; align-items: center; text-decoration: none; color: var(--encre); font-weight: 600; font-size: .92rem; line-height: 1.3; }
.bloc-meme-rubrique img { width: 64px; height: 50px; object-fit: cover; border-radius: 5px; flex: 0 0 auto; }
.bloc-meme-rubrique a:hover span { color: var(--or-fonce); }
.liste-rubriques-laterale { list-style: none; margin: 0; padding: 0; }
.liste-rubriques-laterale a { display: flex; justify-content: space-between; padding: 9px 0; text-decoration: none; color: var(--vert-fonce); font-weight: 600; border-bottom: 1px solid var(--bordure); }
.liste-rubriques-laterale a span { color: var(--or-fonce); font-size: .85rem; }
.liste-rubriques-laterale a:hover { color: var(--or-fonce); }

/* ---------- À lire aussi ---------- */
.a-lire-aussi { background: var(--vert-brume); padding: 56px 0; }
.a-lire-aussi h2 { font-size: 1.5rem; margin-bottom: 26px; }

/* ---------- En-têtes simples / rubrique ---------- */
.entete-simple { padding: 48px 0 8px; }
.entete-simple h1 { font-size: clamp(2rem, 4vw, 2.8rem); font-weight: 800; }
.entete-simple p { color: var(--encre-doux); font-size: 1.1rem; max-width: 60ch; }
.entete-rubrique { background: var(--vert-pale); padding: 46px 0; text-align: center; }
.entete-rubrique-icone { display: inline-flex; width: 56px; height: 56px; color: var(--vert); margin-bottom: 8px; }
.entete-rubrique-icone svg { width: 100%; height: 100%; }
.entete-rubrique h1 { font-size: clamp(2rem, 4vw, 2.9rem); font-weight: 800; }
.entete-rubrique-accroche { color: var(--encre-doux); font-size: 1.1rem; max-width: 56ch; margin: 6px auto 0; }
.entete-rubrique-compte { font-family: var(--titre); color: var(--or-fonce); font-weight: 600; margin-top: 12px; }

.liste-rubrique { padding: 44px 0 60px; }
.grille-rubrique { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* ---------- Pagination ---------- */
.pagination { display: flex; gap: 8px; justify-content: center; margin-top: 44px; flex-wrap: wrap; }
.pagination a, .pagination-actuel { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px; padding: 0 12px; border-radius: var(--rayon); font-family: var(--titre); font-weight: 700; text-decoration: none; }
.pagination a { background: var(--creme-alt); border: 1px solid var(--bordure); color: var(--vert-fonce); }
.pagination a:hover { background: var(--vert-pale); }
.pagination-actuel { background: var(--vert-fonce); color: #fff; }

/* ---------- Rubriques page ---------- */
.grille-rubriques-page { padding: 40px 0 64px; }
.liste-tuiles-page { grid-template-columns: repeat(3, 1fr); gap: 18px; }
.liste-tuiles-page .tuile-rubrique { padding: 28px 22px; }

/* ---------- Recherche ---------- */
.recherche-page { display: flex; gap: 10px; max-width: 560px; margin: 18px 0 8px; }
.recherche-page input { flex: 1; padding: 13px 16px; border: 1px solid var(--bordure); border-radius: var(--rayon); font: inherit; }
.recherche-page button { padding: 0 24px; background: var(--vert-fonce); color: #fff; border: none; border-radius: var(--rayon); font-family: var(--titre); font-weight: 700; cursor: pointer; }
.recherche-compte { color: var(--encre-doux); }
.liste-recherche { padding: 24px 0 64px; }
.recherche-vide { color: var(--encre-doux); font-size: 1.05rem; }

/* ---------- Pages libres ---------- */
.page-libre { padding: 48px 0 64px; }
.page-libre h1 { font-size: clamp(2rem, 4vw, 2.7rem); font-weight: 800; margin-bottom: 22px; }
.page-libre-contenu { font-size: 1.06rem; }
.page-libre-contenu p { margin: 0 0 1.3em; }
.page-libre-contenu h2 { font-size: 1.5rem; margin: 1.7em 0 .5em; }
.page-libre-contenu h3 { font-size: 1.2rem; margin: 1.4em 0 .4em; }
.page-libre-contenu a { color: var(--vert); }
.page-libre-contenu ul, .page-libre-contenu ol { padding-left: 1.3em; margin-bottom: 1.3em; }

/* ---------- Contact ---------- */
.contact-intro { color: var(--encre-doux); font-size: 1.08rem; margin-bottom: 28px; }
.formulaire-contact { display: flex; flex-direction: column; gap: 18px; }
.formulaire-contact label { font-family: var(--titre); font-weight: 600; color: var(--vert-fonce); display: flex; flex-direction: column; gap: 7px; }
.formulaire-contact input, .formulaire-contact textarea { padding: 13px 15px; border: 1px solid var(--bordure); border-radius: var(--rayon); font: inherit; font-weight: 400; color: var(--encre); background: var(--creme-alt); }
.formulaire-contact input:focus, .formulaire-contact textarea:focus { border-color: var(--vert); background: #fff; }
.champ-piege { position: absolute; left: -9999px; }
.message-succes { background: var(--vert-pale); border-left: 4px solid var(--vert); padding: 18px 22px; border-radius: 0 var(--rayon) var(--rayon) 0; color: var(--vert-fonce); }
.message-erreur { background: #f7e7e1; border-left: 4px solid #b5573a; padding: 16px 20px; border-radius: 0 var(--rayon) var(--rayon) 0; margin-bottom: 20px; color: #7a3520; }

/* ---------- Plan du site ---------- */
.plan-site { padding: 36px 0 64px; }
.plan-rubrique { margin-bottom: 40px; }
.plan-rubrique h2 { font-size: 1.4rem; border-bottom: 2px solid var(--or-pale); padding-bottom: 10px; }
.plan-rubrique h2 a { text-decoration: none; }
.plan-rubrique h2 span { color: var(--or-fonce); font-size: .9rem; }
.plan-rubrique ul { columns: 2; column-gap: 40px; list-style: none; padding: 0; margin: 18px 0 0; }
.plan-rubrique li { margin-bottom: 9px; break-inside: avoid; }
.plan-rubrique a { color: var(--encre); text-decoration: none; }
.plan-rubrique a:hover { color: var(--or-fonce); }

/* ---------- 404 ---------- */
.zone-introuvable { padding: 72px 0; text-align: center; }
.code-introuvable { font-family: var(--titre); font-weight: 800; font-size: 5.5rem; color: var(--or-pale); line-height: 1; display: block; }
.zone-introuvable h1 { font-size: 2rem; margin: 8px 0 14px; }
.zone-introuvable p { color: var(--encre-doux); max-width: 46ch; margin: 0 auto 28px; }
.suggestions-introuvable { margin-top: 48px; }
.suggestions-introuvable h2 { font-size: 1.1rem; color: var(--encre-doux); }
.suggestions-introuvable ul { list-style: none; padding: 0; margin: 0 0 18px; }
.suggestions-introuvable li { margin-bottom: 8px; }
.suggestions-introuvable a { color: var(--vert); }

/* ---------- Pied de page ---------- */
.pied-atelier { background: var(--vert-fonce); color: rgba(255,255,255,.82); }
.pied-grille { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; padding: 56px 0 44px; }
.pied-enseigne { font-family: var(--titre); font-weight: 800; font-size: 1.5rem; color: #fff; }
.pied-tagline { color: var(--or); font-weight: 600; margin: 6px 0 14px; font-family: var(--titre); }
.pied-mot { font-size: .95rem; max-width: 38ch; }
.pied-colonne h2 { font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; color: var(--or); margin-bottom: 16px; }
.pied-colonne ul { list-style: none; margin: 0; padding: 0; }
.pied-colonne li { margin-bottom: 10px; }
.pied-colonne a { color: rgba(255,255,255,.82); text-decoration: none; font-size: .95rem; }
.pied-colonne a:hover { color: #fff; }
.pied-bas { border-top: 1px solid rgba(255,255,255,.14); }
.pied-bas-inner { display: flex; justify-content: space-between; gap: 16px; padding: 20px 0; font-size: .84rem; color: rgba(255,255,255,.6); flex-wrap: wrap; }
.pied-bas-inner p { margin: 0; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1080px) {
  .accroche-grille { gap: 36px; }
  .grille-projets { grid-template-columns: repeat(3, minmax(0,1fr)); }
  .liste-tuiles { grid-template-columns: repeat(3, 1fr); }
  .bande-galerie { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 900px) {
  .menu-atelier { display: none; }
  .bouton-burger { display: inline-flex; }
  .menu-atelier.ouvert { display: block; }
  .page-projet-grille { grid-template-columns: 1fr; }
  .colonne-laterale { position: static; flex-direction: row; flex-wrap: wrap; }
  .bloc-lateral { flex: 1 1 280px; }
  .accroche-grille { grid-template-columns: 1fr; }
  .accroche-visuel { order: -1; }
  .selection-grille { grid-template-columns: 1fr; gap: 32px; }
  .grille-rubrique { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .liste-tuiles-page { grid-template-columns: repeat(2, 1fr); }
  .pied-grille { grid-template-columns: 1fr 1fr; gap: 30px; }
}

@media (max-width: 620px) {
  body { font-size: 17px; }
  .enveloppe { padding: 0 18px; }
  .barre-entete-inner { min-height: 70px; gap: 12px; }
  .enseigne-logo { height: 50px; }
  .grille-projets, .grille-rubrique { grid-template-columns: 1fr 1fr; gap: 16px; }
  .liste-tuiles, .liste-tuiles-page { grid-template-columns: 1fr 1fr; }
  .bande-galerie { grid-template-columns: repeat(2, 1fr); }
  .accroche-maison { padding: 36px 0 48px; }
  .vignette-flottante { left: 12px; right: 12px; max-width: none; bottom: -16px; }
  .titre-rang { flex-direction: column; gap: 4px; align-items: flex-start; }
  .bandeau-explorer-inner { flex-direction: column; align-items: flex-start; text-align: left; }
  .feuillet-corps h2, .feuillet-corps h3 { font-size: 1rem; }
  .pied-grille { grid-template-columns: 1fr; }
  .colonne-laterale { flex-direction: column; }
  .plan-rubrique ul { columns: 1; }
}

@media (max-width: 380px) {
  .grille-projets, .grille-rubrique, .liste-tuiles, .bande-galerie { grid-template-columns: 1fr; }
}
