/* =========================================================
   Mlle L Photographie — feuille de style principale
   Palette : noir & gris clair, touches discrètes de doré
   (les noms de variables sont conservés pour la compatibilité
   avec generate.py / components.py — seules les valeurs changent)
   ========================================================= */

:root{
  /* Couleurs */
  --ivoire:        #FFFFFF;  /* blanc — fond de page */
  --lin:           #EAEAE7;  /* gris clair — sections alternées */
  --lin-deep:      #D8D7D2;  /* gris moyen — bordures, pointillés */
  --rose:          #C9A961;  /* doré clair — touches décoratives */
  --rose-deep:     #7C5F2A;  /* doré profond — liens, prix, focus (contraste AA) */
  --sapin:         #1B1B1A;  /* noir — bandeaux forts, CTA */
  --sapin-deep:    #0E0E0D;  /* noir profond — pied de page */
  --cacao:         #1A1A19;  /* noir — texte courant */
  --brun-doux:     #5C5C58;  /* gris — texte secondaire (lisible, sobre) */
  --blanc:         #FFFFFF;
  --ligne:         rgba(0,0,0,0.12);
  --ombre:         rgba(0,0,0,0.16);

  /* Typo */
  --police-titre: "Fraunces", "Iowan Old Style", Georgia, serif;
  --police-texte: "Albert Sans", "Segoe UI", system-ui, -apple-system, sans-serif;

  /* Echelle */
  --r-sm: 0;
  --r-md: 0;
  --r-lg: 0;
  --container: 1180px;

  color-scheme: light;
}

/* ---------- Reset léger ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; overflow-x:hidden; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}
body{
  margin:0;
  overflow-x:hidden;
  background:var(--ivoire);
  color:var(--cacao);
  font-family:var(--police-texte);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; height:auto; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{
  font-family:var(--police-titre);
  font-weight:600;
  line-height:1.12;
  margin:0 0 .5em;
  color:var(--cacao);
  letter-spacing:-0.01em;
}
h1{ font-size:clamp(2.3rem,5vw,3.6rem); font-weight:560; }
h2{ font-size:clamp(1.7rem,3.4vw,2.5rem); }
h3{ font-size:clamp(1.2rem,2.2vw,1.5rem); }
p{ margin:0 0 1em; }
.lead{ font-size:1.18rem; color:var(--brun-doux); }
strong{ color:var(--cacao); }

:focus-visible{ outline:3px solid var(--rose-deep); outline-offset:3px; border-radius:0; }

.visually-hidden{
  position:absolute !important; width:1px; height:1px; overflow:hidden;
  clip:rect(0 0 0 0); white-space:nowrap;
}
.skip-link{
  position:absolute; left:-999px; top:0; background:var(--sapin); color:var(--ivoire);
  padding:.6em 1em; z-index:200; border-radius:0;
}
.skip-link:focus{ left:0; }

/* ---------- Layout ---------- */
.container{
  width:100%; max-width:var(--container); margin-inline:auto; padding-inline:22px;
}
.section{ padding:clamp(56px,9vw,108px) 0; }
.section--lin{ background:var(--lin); }
.section--sapin{ background:var(--sapin); color:var(--ivoire); }
.section--sapin h2,.section--sapin h3{ color:var(--ivoire); }
.section--tight{ padding-block:clamp(40px,6vw,72px); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--police-texte); font-weight:600; letter-spacing:.16em; text-transform:uppercase;
  font-size:.74rem; color:var(--rose-deep); margin-bottom:.9em;
}
.section--sapin .eyebrow{ color:var(--lin-deep); }
.eyebrow::before{
  content:""; width:22px; height:1px; background:currentColor; display:inline-block;
}

.grid{ display:grid; gap:28px; }
@media (min-width:700px){ .grid--2{ grid-template-columns:1fr 1fr; } }
@media (min-width:760px){ .grid--4{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1080px){ .grid--4{ grid-template-columns:repeat(4,1fr); } }
@media (min-width:760px){ .grid--3{ grid-template-columns:repeat(3,1fr); } }

.center{ text-align:center; }
.intro{ max-width:660px; margin-inline:auto; }
.intro.left{ margin-inline:0; }

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55em;
  font-weight:600; font-size:.95rem; padding:.95em 1.7em; border-radius:0;
  border:1.5px solid transparent; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--cacao); color:var(--ivoire); box-shadow:0 10px 26px -10px rgba(124,95,42,.55); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 30px -10px rgba(124,95,42,.65); }
.btn-ghost{ background:transparent; border-color:var(--cacao); color:var(--cacao); }
.btn-ghost:hover{ background:var(--cacao); color:var(--ivoire); transform:translateY(-2px); }
.section--sapin .btn-ghost{ border-color:var(--ivoire); color:var(--ivoire); }
.section--sapin .btn-ghost:hover{ background:var(--ivoire); color:var(--sapin-deep); }
.btn-sm{ padding:.6em 1.2em; font-size:.85rem; }
.btn-block{ width:100%; }

/* ---------- Séparateur fin (entre sections de même fond) ---------- */
.separateur{
  display:block; width:64px; height:1px; margin:0 auto; border:none;
  background:var(--rose); opacity:.55;
}
.separateur.on-sapin{ background:var(--ivoire); opacity:.35; }

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:100; width:100%;
  background:rgba(255,255,255,.0);
  transition:background .35s ease, box-shadow .35s ease, padding .25s ease;
  padding-block:18px;
}
.site-header.is-scrolled{
  background:rgba(255,255,255,.94); backdrop-filter:blur(6px);
  box-shadow:0 4px 22px -10px rgba(0,0,0,.25); padding-block:10px;
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand{ display:flex; align-items:center; gap:.8em; font-family:var(--police-titre); font-size:1.35rem; color:var(--cacao); }
.brand-logo{
  width:48px; height:48px; flex-shrink:0; border-radius:0; overflow:hidden;
  background:var(--blanc); border:1px solid var(--ligne);
  display:flex; align-items:center; justify-content:center;
}
.brand-logo img{ width:100%; height:100%; object-fit:contain; padding:5px; }
.brand .signature{ font-style:italic; }

.nav-principale{ display:none; }
.nav-principale ul{ display:flex; align-items:center; gap:26px; }
.nav-principale a{
  font-weight:600; font-size:.92rem; color:var(--cacao); position:relative; padding:.3em 0;
}
.nav-principale a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--rose-deep);
  transition:right .25s ease;
}
.nav-principale a:hover::after,.nav-principale a[aria-current="page"]::after{ right:0; }
.nav-cta{ display:flex; align-items:center; gap:14px; }
.nav-tel{ display:none; font-weight:600; font-size:.92rem; gap:.4em; align-items:center; }
.nav-cta .btn-primary{ display:none; }

@media (min-width:980px){
  .nav-principale{ display:block; }
  .nav-tel{ display:inline-flex; }
  .nav-cta .btn-primary{ display:inline-flex; }
}

.menu-toggle{
  width:46px; height:46px; border-radius:0; border:1.5px solid var(--cacao); background:transparent;
  display:inline-flex; align-items:center; justify-content:center; flex-direction:column; gap:5px;
}
.menu-toggle span{ width:18px; height:2px; background:var(--cacao); display:block; transition:transform .25s ease, opacity .25s ease; }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (min-width:980px){
  .menu-toggle{ display:none; }
}

.nav-mobile{
  position:fixed; inset:0 0 0 auto; width:min(86vw,360px); height:100vh; background:var(--ivoire);
  box-shadow:-20px 0 50px -20px rgba(0,0,0,.3); transform:translateX(100%); transition:transform .35s ease;
  z-index:150; padding:90px 30px 30px; overflow-y:auto;
}
.nav-mobile.is-open{ transform:translateX(0); }
.nav-mobile ul{ display:flex; flex-direction:column; gap:6px; }
.nav-mobile a{ display:block; padding:.7em 0; font-size:1.15rem; font-family:var(--police-titre); border-bottom:1px solid var(--ligne); }
.nav-mobile .nav-mobile-contact{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.overlay{
  position:fixed; inset:0; background:rgba(0,0,0,.4); opacity:0; pointer-events:none; transition:opacity .35s ease; z-index:140;
}
.overlay.is-open{ opacity:1; pointer-events:auto; }
body.menu-open{ overflow:hidden; }

/* ---------- Fil d'ariane ---------- */
.fil-ariane{ font-size:.82rem; color:var(--brun-doux); padding-top:14px; }
.fil-ariane a{ text-decoration:underline; text-decoration-color:var(--ligne); }
.fil-ariane li{ display:inline; }
.fil-ariane li:not(:last-child)::after{ content:"·"; margin:0 .5em; }

/* ---------- Hero ---------- */
.hero{ padding-top:clamp(20px,4vw,46px); padding-bottom:clamp(50px,7vw,80px); overflow:hidden; }
.hero-grid{ display:grid; gap:42px; align-items:center; }
@media (min-width:920px){ .hero-grid{ grid-template-columns:1.05fr .95fr; } }
.hero-texte h1{ margin-bottom:.55em; }
.hero-stats{ display:flex; gap:28px; margin-top:30px; flex-wrap:wrap; }
.hero-stats div{ display:flex; flex-direction:column; }
.hero-stats strong{ font-family:var(--police-titre); font-size:1.5rem; color:var(--rose-deep); }
.hero-stats span{ font-size:.82rem; color:var(--brun-doux); }
.hero-cta{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }

.hero-visuel{ position:relative; }
.arch-frame{
  position:relative; border-radius:0;
  overflow:hidden; box-shadow:0 30px 60px -24px rgba(0,0,0,.45);
}
.arch-frame img{ display:block; width:100%; height:auto; }
.hero-badge{
  position:absolute; bottom:-22px; left:-22px; background:var(--blanc); border-radius:0;
  padding:16px 20px; box-shadow:0 18px 30px -16px rgba(0,0,0,.35); max-width:230px;
  font-size:.85rem; display:flex; gap:10px; align-items:center;
}
.hero-badge svg{ flex-shrink:0; color:var(--rose-deep); width:26px; height:26px; }
@media (max-width:540px){ .hero-badge{ left:0; bottom:-18px; padding:12px 16px; font-size:.78rem; } }

/* ---------- Cartes services ---------- */
.carte-service{
  background:var(--blanc); border-radius:0; padding:34px 28px; height:100%;
  display:flex; flex-direction:column; box-shadow:0 18px 40px -28px rgba(0,0,0,.35);
  transition:transform .3s ease, box-shadow .3s ease; border:1px solid var(--ligne);
}
.carte-service:hover{ transform:translateY(-6px); box-shadow:0 26px 46px -24px rgba(0,0,0,.4); }
.carte-service .icone{
  width:54px; height:54px; border-radius:0; background:var(--lin); color:var(--rose-deep);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;
}
.carte-service h3{ margin-bottom:.4em; }
.carte-service p{ color:var(--brun-doux); flex:1; }
.carte-service .lien{
  margin-top:14px; font-weight:700; font-size:.88rem; color:var(--rose-deep); display:inline-flex; align-items:center; gap:.4em;
}
.carte-service .lien svg{ width:15px; height:15px; transition:transform .25s ease; }
.carte-service:hover .lien svg{ transform:translateX(4px); }

/* ---------- A propos / split ---------- */
.split{ display:grid; gap:40px; align-items:center; }
@media (min-width:920px){ .split{ grid-template-columns:.85fr 1.15fr; } }
.split.inverse{ direction:rtl; }
.split.inverse > *{ direction:ltr; }
.portrait-cadre{
  border-radius:0; overflow:hidden;
  box-shadow:0 26px 50px -22px rgba(0,0,0,.4);
}
.portrait-cadre img{ display:block; width:100%; height:auto; }
.liste-puces{ display:flex; flex-direction:column; gap:14px; margin-top:22px; }
.liste-puces li{ display:flex; gap:12px; align-items:flex-start; font-size:.97rem; }
.liste-puces svg{ width:20px; height:20px; flex-shrink:0; margin-top:2px; color:var(--rose-deep); }

/* ---------- Étapes (réelle séquence) ---------- */
.etapes{ display:grid; gap:26px; }
@media (min-width:760px){ .etapes{ grid-template-columns:repeat(4,1fr); } }
.etape{ position:relative; padding-left:0; }
.etape .marque{
  display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border-radius:0;
  border:1.5px solid var(--rose-deep); color:var(--rose-deep); font-family:var(--police-titre); margin-bottom:14px;
}
.etapes-ligne{
  display:none;
}
@media (min-width:760px){
  .etape:not(:last-child)::after{
    content:""; position:absolute; top:19px; left:calc(100% - 14px); width:calc(100% - 14px); height:1px;
    background:repeating-linear-gradient(to right,var(--rose) 0 6px, transparent 6px 12px);
  }
}

/* ---------- Tarifs ---------- */
.tarif-carte{
  background:var(--blanc); border-radius:0; padding:32px 28px; border:1px solid var(--ligne);
  display:flex; flex-direction:column; height:100%; position:relative;
}
.tarif-carte.mise-avant{ border-color:var(--rose-deep); box-shadow:0 22px 46px -26px rgba(124,95,42,.55); }
.tarif-carte .ruban{
  position:absolute; top:-14px; right:24px; background:var(--rose-deep); color:var(--ivoire);
  font-size:.74rem; font-weight:700; letter-spacing:.05em; padding:.4em .9em; border-radius:0;
}
.tarif-carte .prix{ font-family:var(--police-titre); font-size:2.2rem; color:var(--cacao); margin:.2em 0 .6em; }
.tarif-carte .prix span{ font-size:.9rem; font-family:var(--police-texte); color:var(--brun-doux); font-weight:600; }
.tarif-carte ul{ display:flex; flex-direction:column; gap:10px; margin:18px 0 24px; flex:1; }
.tarif-carte ul li{ display:flex; gap:10px; font-size:.92rem; align-items:flex-start; }
.tarif-carte ul li svg{ width:17px; height:17px; flex-shrink:0; margin-top:3px; color:var(--sapin); }
.tarif-carte .note{ font-size:.8rem; color:var(--brun-doux); margin-top:10px; }
.tarif-bloc-titre{ margin-bottom:30px; }

/* ---------- Onglets (studio / extérieur) ---------- */
.onglets-nav{ display:inline-flex; background:var(--lin); border-radius:0; padding:5px; margin-bottom:32px; gap:4px; }
.onglets-nav button{
  border:none; background:transparent; padding:.65em 1.4em; border-radius:0; font-weight:600; font-size:.88rem; color:var(--brun-doux);
  transition:background .25s ease, color .25s ease;
}
.onglets-nav button[aria-selected="true"]{ background:var(--blanc); color:var(--rose-deep); box-shadow:0 8px 18px -10px rgba(0,0,0,.3); }
.panneau-onglet{ display:none; }
.panneau-onglet.is-active{ display:block; }

/* ---------- FAQ ---------- */
.faq-item{ border-bottom:1px solid var(--ligne); }
.faq-item button{
  width:100%; display:flex; justify-content:space-between; align-items:center; gap:16px; text-align:left;
  background:none; border:none; padding:22px 0; font-family:var(--police-titre); font-size:1.05rem; color:var(--cacao);
}
.faq-item svg{ flex-shrink:0; width:20px; height:20px; color:var(--rose-deep); transition:transform .3s ease; }
.faq-item button[aria-expanded="true"] svg{ transform:rotate(45deg); }
.faq-reponse{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-reponse p{ padding-bottom:20px; color:var(--brun-doux); max-width:680px; }

/* ---------- Galerie (carrousel) + lightbox ---------- */
.galerie-carrousel{ position:relative; }
.galerie-piste{
  display:flex; gap:14px; overflow-x:auto; padding-bottom:10px; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.galerie-piste::-webkit-scrollbar{ height:6px; }
.galerie-piste::-webkit-scrollbar-thumb{ background:var(--lin-deep); border-radius:0; }
.galerie-piste button{
  flex:0 0 auto; width:min(300px,72vw); scroll-snap-align:start;
  border:none; padding:0; background:none; border-radius:0; overflow:hidden;
  position:relative; display:block;
}
.galerie-piste img{ display:block; width:100%; height:auto; transition:transform .5s ease; }
.galerie-piste button:hover img{ transform:scale(1.04); }
.galerie-controles{
  position:absolute; top:0; bottom:10px; left:0; right:0; display:flex; align-items:center;
  justify-content:space-between; padding:0 8px; margin-top:0; pointer-events:none; gap:0;
}
.galerie-controles button{
  pointer-events:auto; width:46px; height:46px; border-radius:0; border:none; background:rgba(255,255,255,.001);
  color:var(--cacao); opacity:.5; display:flex; align-items:center; justify-content:center;
  transition:opacity .25s ease, background-color .25s ease;
}
.galerie-controles button:hover{ opacity:.9; background:rgba(255,255,255,.55); }
.galerie-controles button[data-galerie="prev"] svg{ transform:scaleX(-1); }
.lightbox{
  position:fixed; inset:0; background:rgba(10,10,10,.92); display:none; align-items:center; justify-content:center;
  z-index:300; padding:30px;
}
.lightbox.is-open{ display:flex; }
.lightbox img{ max-width:min(900px,90vw); max-height:84vh; border-radius:0; box-shadow:0 30px 60px rgba(0,0,0,.5); }
.lightbox button{
  position:absolute; top:24px; right:24px; background:var(--ivoire); border:none; width:44px; height:44px; border-radius:0;
  display:flex; align-items:center; justify-content:center;
}

/* ---------- Témoignages ---------- */
.temoignages-carrousel{ position:relative; }
.temoignages-piste{
  display:flex; gap:22px; overflow-x:auto; padding-bottom:10px; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.temoignages-piste::-webkit-scrollbar{ height:6px; }
.temoignages-piste::-webkit-scrollbar-thumb{ background:var(--lin-deep); border-radius:0; }
.carte-temoignage{
  scroll-snap-align:start; min-width:min(340px,80vw); background:var(--blanc); border-radius:0;
  padding:30px 26px; box-shadow:0 18px 40px -28px rgba(0,0,0,.35); border:1px solid var(--ligne);
}
.carte-temoignage .etoiles{ color:var(--rose-deep); margin-bottom:14px; letter-spacing:.2em; }
.carte-temoignage footer{ margin-top:16px; font-weight:700; font-size:.88rem; }
.temoignages-controles{
  position:absolute; top:0; bottom:10px; left:0; right:0; display:flex; align-items:center;
  justify-content:space-between; padding:0 8px; margin-top:0; pointer-events:none; gap:0;
}
.temoignages-controles button{
  pointer-events:auto; width:46px; height:46px; border-radius:0; border:none; background:rgba(255,255,255,.001);
  color:var(--cacao); opacity:.5; display:flex; align-items:center; justify-content:center;
  transition:opacity .25s ease, background-color .25s ease;
}
.temoignages-controles button:hover{ opacity:.9; background:rgba(255,255,255,.55); }
.temoignages-controles button[data-temoin="prev"] svg{ transform:scaleX(-1); }

/* ---------- Calculateur ---------- */
.calculateur{
  background:var(--blanc); border-radius:0; padding:clamp(26px,4vw,44px); box-shadow:0 26px 60px -30px rgba(0,0,0,.4);
  border:1px solid var(--ligne);
}
.calc-onglets{ display:flex; gap:10px; margin-bottom:24px; flex-wrap:wrap; }
.calc-onglets button{
  flex:1; min-width:160px; border:1.5px solid var(--ligne); background:var(--ivoire); padding:.9em 1em; border-radius:0;
  font-weight:700; font-size:.9rem; color:var(--brun-doux); transition:all .25s ease;
}
.calc-onglets button[aria-selected="true"]{ border-color:var(--rose-deep); color:var(--rose-deep); background:var(--lin); }
.calc-champ{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.calc-champ label{ font-weight:700; font-size:.9rem; }
.calc-champ input{
  padding:.85em 1em; border-radius:0; border:1.5px solid var(--ligne); font-size:1rem; font-family:inherit; background:var(--ivoire);
}
.calc-champ input:focus{ border-color:var(--rose-deep); }
.calc-resultat{
  margin-top:20px; padding:20px 22px; border-radius:0; background:var(--lin); display:none; gap:14px; align-items:flex-start;
}
.calc-resultat.is-visible{ display:flex; }
.calc-resultat svg{ width:26px; height:26px; color:var(--sapin); flex-shrink:0; margin-top:2px; }
.calc-resultat.urgence{ background:#F2E8D3; }
.calc-resultat.urgence svg{ color:var(--rose-deep); }

/* ---------- Formulaire contact ---------- */
.form-champ{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.form-champ label{ font-weight:700; font-size:.9rem; }
.form-champ input,.form-champ select,.form-champ textarea{
  padding:.9em 1em; border-radius:0; border:1.5px solid var(--ligne); font-size:1rem; font-family:inherit; background:var(--blanc);
  width:100%;
}
.form-champ textarea{ resize:vertical; min-height:140px; }
.form-champ input:focus,.form-champ select:focus,.form-champ textarea:focus{ border-color:var(--rose-deep); }
.form-row{ display:grid; gap:18px; }
@media (min-width:680px){ .form-row{ grid-template-columns:1fr 1fr; } }
.form-aide{ font-size:.8rem; color:var(--brun-doux); margin-top:-4px; }
.form-statut{ margin-top:16px; padding:14px 18px; border-radius:0; font-size:.92rem; display:none; }
.form-statut.is-visible{ display:block; }
.form-statut.succes{ background:#E4EBE0; color:#3A4A34; }
.form-statut.erreur{ background:#F6DCD6; color:#8C3A30; }

/* ---------- Infos pratiques (contact/footer) ---------- */
.infos-carte{
  display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid var(--ligne);
}
.infos-carte:last-child{ border-bottom:none; }
.infos-carte svg{ width:22px; height:22px; flex-shrink:0; color:var(--rose-deep); margin-top:2px; }
.section--sapin .infos-carte svg{ color:var(--lin-deep); }
.section--sapin .infos-carte{ border-color:rgba(255,255,255,.18); }

.carte-map{ border-radius:0; overflow:hidden; border:1px solid var(--ligne); }
.carte-map iframe{ width:100%; height:100%; min-height:340px; border:0; display:block; }

/* ---------- Bande CTA finale ---------- */
.bande-cta{ text-align:center; }
.bande-cta h2{ max-width:760px; margin-inline:auto; }
.bande-cta .hero-cta{ justify-content:center; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--sapin-deep); color:var(--ivoire); padding-top:64px; }
.footer-grid{ display:grid; gap:42px; padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,.14); }
@media (min-width:760px){ .footer-grid{ grid-template-columns:1.3fr 1fr 1fr 1fr; } }
.footer-brand .brand{ color:var(--ivoire); margin-bottom:14px; }
.footer-brand .brand-logo{ border-color:rgba(255,255,255,.22); }
.footer-grid p{ color:rgba(255,255,255,.72); font-size:.92rem; }
.footer-col h4{ font-family:var(--police-texte); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--lin-deep); margin-bottom:16px; }
.footer-col ul{ display:flex; flex-direction:column; gap:10px; }
.footer-col a{ font-size:.92rem; color:rgba(255,255,255,.85); }
.footer-col a:hover{ color:var(--rose); }
.footer-social{ display:flex; gap:12px; margin-top:18px; }
.footer-social a{
  width:38px; height:38px; border-radius:0; border:1px solid rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center;
}
.footer-social a:hover{ background:var(--rose); border-color:var(--rose); }
.footer-bas{ display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; padding:24px 0 34px; font-size:.8rem; color:rgba(255,255,255,.55); }
.footer-bas ul{ display:flex; gap:18px; flex-wrap:wrap; }
.footer-bas a:hover{ color:var(--rose); }

.bouton-haut{
  position:fixed; bottom:24px; right:24px; width:48px; height:48px; border-radius:0; background:var(--cacao);
  color:var(--ivoire); display:flex; align-items:center; justify-content:center; box-shadow:0 14px 30px -10px rgba(0,0,0,.4);
  opacity:0; transform:translateY(12px); pointer-events:none; transition:opacity .3s ease, transform .3s ease; z-index:90;
}
.bouton-haut.is-visible{ opacity:1; transform:translateY(0); pointer-events:auto; }

/* ---------- Reveal on scroll ---------- */
[data-reveal]{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
[data-reveal].is-visible{ opacity:1; transform:translateY(0); }

/* ---------- Bandeau partenaires ---------- */
.partenaires-piste{ display:flex; flex-wrap:wrap; gap:14px 28px; align-items:center; justify-content:center; }
.partenaires-piste a{ font-size:.85rem; font-weight:600; color:var(--brun-doux); border-bottom:1px dotted var(--ligne); padding-bottom:2px; }
.partenaires-piste a:hover{ color:var(--rose-deep); border-color:var(--rose-deep); }

/* ---------- Bandeau urgence prise de rdv ---------- */
.bandeau-info{
  background:var(--cacao); color:var(--ivoire); font-size:.84rem; text-align:center; padding:10px 16px;
}
.bandeau-info a{ text-decoration:underline; }

/* ---------- Page 404 ---------- */
.page-404{ text-align:center; padding:120px 0; }
.page-404 h1{ font-size:clamp(3rem,10vw,6rem); }

/* ---------- Petites listes (mentions/cgv) ---------- */
.texte-legal h2{ margin-top:1.6em; }
.texte-legal p, .texte-legal li{ color:var(--brun-doux); }
.texte-legal ul{ list-style:disc; padding-left:1.3em; display:flex; flex-direction:column; gap:8px; }
.encart{
  background:var(--lin); border-radius:0; padding:22px 24px; margin:24px 0; font-size:.92rem;
}
