/* ==========================================================================
   JARDIN MARSEILLE — Design System
   Palette : vert apaisant, accent doré provençal, fond crème
   Typo : DM Serif Display (titres) + Plus Jakarta Sans (corps)
   ========================================================================== */

/* ---------- Variables ---------- */
:root {
  --vert-profond: #2D5F2D;
  --vert-sauge: #7BAE7F;
  --vert-clair: #A8CFA9;
  --dore: #C8A962;
  --dore-clair: #D4BC82;
  --fond-creme: #F5F2EB;
  --fond-sable: #EAE6DC;
  --texte: #2A2A2A;
  --texte-clair: #5A5A5A;
  --blanc: #FFFFFF;
  --erreur: #C44D4D;
  --succes: #3D8B40;
  --ombre-douce: 0 2px 16px rgba(45,95,45,.08);
  --ombre-elevee: 0 8px 32px rgba(45,95,45,.12);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --transition: .25s ease;
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:17px;
  line-height:1.7;
  color:var(--texte);
  background:var(--fond-creme);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--vert-profond);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--dore)}
ul,ol{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none;background:none}
button{cursor:pointer}

/* ---------- Typographie ---------- */
h1,h2,h3,h4{
  font-family:'DM Serif Display',serif;
  color:var(--vert-profond);
  line-height:1.2;
  font-weight:400;
}
h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:.6em}
h2{font-size:clamp(1.6rem,3.5vw,2.25rem);margin-bottom:.5em}
h3{font-size:clamp(1.2rem,2.5vw,1.5rem);margin-bottom:.4em}
h4{font-size:1.15rem;margin-bottom:.3em}
p{margin-bottom:1em}
p:last-child{margin-bottom:0}
strong{font-weight:600}
small,.text-sm{font-size:.82rem}

/* ---------- Conteneur ---------- */
.container{
  width:100%;
  max-width:1140px;
  margin:0 auto;
  padding:0 24px;
}
.container--narrow{max-width:800px}
.container--wide{max-width:1320px}

/* ---------- Header / Navigation ---------- */
.header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--blanc);
  border-bottom:1px solid rgba(45,95,45,.08);
  transition:box-shadow var(--transition);
}
.header.scrolled{box-shadow:var(--ombre-douce)}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:72px;
}
.header__logo{
  font-family:'DM Serif Display',serif;
  font-size:1.4rem;
  color:var(--vert-profond);
  display:flex;
  align-items:center;
  gap:8px;
}
.header__logo span{color:var(--dore)}

/* Navigation desktop */
.nav{display:flex;align-items:center;gap:4px}
.nav__item{position:relative}
.nav__link{
  display:block;
  padding:8px 14px;
  font-size:.95rem;
  font-weight:600;
  color:var(--texte);
  border-radius:var(--radius-sm);
  transition:background var(--transition),color var(--transition);
}
.nav__link:hover,
.nav__link[aria-current="page"]{
  color:var(--vert-profond);
  background:rgba(45,95,45,.06);
}

/* Dropdown */
.nav__dropdown{
  position:absolute;
  top:100%;
  left:0;
  min-width:260px;
  background:var(--blanc);
  border-radius:var(--radius-md);
  box-shadow:var(--ombre-elevee);
  padding:8px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:all .2s ease;
  z-index:110;
}
.nav__item:hover .nav__dropdown,
.nav__item:focus-within .nav__dropdown{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.nav__dropdown a{
  display:block;
  padding:10px 20px;
  font-size:.9rem;
  color:var(--texte);
  transition:background var(--transition);
}
.nav__dropdown a:hover{background:var(--fond-creme);color:var(--vert-profond)}
.nav__dropdown a small{display:block;color:var(--texte-clair);font-size:.78rem;margin-top:2px}

/* CTA header */
.nav__cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 22px;
  background:var(--vert-profond);
  color:var(--blanc);
  font-weight:600;
  font-size:.9rem;
  border-radius:var(--radius-sm);
  margin-left:12px;
  transition:background var(--transition),transform var(--transition);
}
.nav__cta:hover{background:#245024;color:var(--blanc);transform:translateY(-1px)}

/* Burger mobile */
.burger{
  display:none;
  flex-direction:column;
  gap:5px;
  width:28px;
  padding:4px 0;
  background:none;
  border:none;
}
.burger span{
  display:block;
  height:2.5px;
  background:var(--vert-profond);
  border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:1024px){
  .burger{display:flex}
  .nav{
    position:fixed;
    inset:72px 0 0 0;
    flex-direction:column;
    align-items:stretch;
    background:var(--blanc);
    padding:24px;
    gap:0;
    overflow-y:auto;
    transform:translateX(100%);
    transition:transform .3s ease;
  }
  .nav.open{transform:translateX(0)}
  .nav__link{padding:14px 0;font-size:1.05rem;border-bottom:1px solid var(--fond-sable)}
  .nav__dropdown{
    position:static;
    box-shadow:none;
    opacity:1;
    visibility:visible;
    transform:none;
    padding:0 0 0 16px;
    display:none;
  }
  .nav__item.open .nav__dropdown{display:block}
  .nav__cta{margin:20px 0 0;text-align:center;justify-content:center}
}

/* ---------- Breadcrumb ---------- */
.breadcrumb{
  padding:16px 0;
  font-size:.85rem;
  color:var(--texte-clair);
}
.breadcrumb a{color:var(--texte-clair)}
.breadcrumb a:hover{color:var(--vert-profond)}
.breadcrumb span{margin:0 6px;opacity:.5}

/* ---------- Hero ---------- */
.hero{
  padding:80px 0 60px;
  position:relative;
  overflow:hidden;
}
.hero--home{padding:100px 0 80px}
.hero__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.hero__content{position:relative;z-index:2}
.hero__badge{
  display:inline-block;
  padding:6px 16px;
  background:rgba(200,169,98,.15);
  color:var(--dore);
  font-size:.82rem;
  font-weight:600;
  border-radius:20px;
  margin-bottom:20px;
  letter-spacing:.02em;
}
.hero__title{margin-bottom:20px}
.hero__subtitle{
  font-size:1.15rem;
  color:var(--texte-clair);
  line-height:1.6;
  max-width:520px;
  margin-bottom:32px;
}
.hero__visual{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:4/3;
  background:var(--fond-sable);
}
.hero__visual::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  border:3px solid rgba(200,169,98,.25);
  pointer-events:none;
}
.hero__visual img{width:100%;height:100%;object-fit:cover}
.hero__deco{
  position:absolute;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(123,174,127,.15),transparent 70%);
  border-radius:50%;
  z-index:0;
  pointer-events:none;
}
.hero__deco--1{top:-60px;right:-40px}
.hero__deco--2{bottom:-80px;left:-60px}

@media(max-width:768px){
  .hero{padding:48px 0 40px}
  .hero--home{padding:60px 0 48px}
  .hero__grid{grid-template-columns:1fr;gap:32px}
  .hero__visual{max-width:400px}
}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 32px;
  font-weight:600;
  font-size:1rem;
  border-radius:var(--radius-sm);
  transition:all var(--transition);
  text-align:center;
  line-height:1.3;
}
.btn--primary{
  background:var(--vert-profond);
  color:var(--blanc);
}
.btn--primary:hover{background:#245024;color:var(--blanc);transform:translateY(-2px);box-shadow:0 4px 16px rgba(45,95,45,.2)}
.btn--secondary{
  background:var(--blanc);
  color:var(--vert-profond);
  border:2px solid var(--vert-profond);
}
.btn--secondary:hover{background:var(--vert-profond);color:var(--blanc)}
.btn--dore{
  background:var(--dore);
  color:var(--blanc);
}
.btn--dore:hover{background:#B89A55;color:var(--blanc);transform:translateY(-2px)}
.btn--ghost{
  background:transparent;
  color:var(--vert-profond);
  padding:14px 16px;
}
.btn--ghost:hover{background:rgba(45,95,45,.06)}
.btn--sm{padding:10px 20px;font-size:.9rem}
.btn--lg{padding:18px 40px;font-size:1.1rem}
.btn--full{width:100%}

/* ---------- Sections ---------- */
.section{padding:80px 0}
.section--sable{background:var(--fond-sable)}
.section--blanc{background:var(--blanc)}
.section--vert{background:var(--vert-profond);color:var(--blanc)}
.section--vert h2,.section--vert h3{color:var(--blanc)}
.section--vert p{color:rgba(255,255,255,.85)}
.section--vert .btn--primary{background:var(--dore);color:var(--blanc)}
.section--vert .btn--primary:hover{background:#B89A55}

.section__header{
  text-align:center;
  max-width:680px;
  margin:0 auto 48px;
}
.section__header p{color:var(--texte-clair);font-size:1.05rem}
.section__label{
  display:inline-block;
  font-size:.8rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--dore);
  margin-bottom:12px;
}

@media(max-width:768px){
  .section{padding:56px 0}
}

/* ---------- Cards prestations ---------- */
.prestations-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
}
.presta-card{
  position:relative;
  background:var(--blanc);
  border-radius:var(--radius-md);
  padding:36px 28px 28px;
  box-shadow:var(--ombre-douce);
  transition:transform var(--transition),box-shadow var(--transition);
  overflow:hidden;
}
.presta-card:hover{transform:translateY(-4px);box-shadow:var(--ombre-elevee)}
.presta-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--vert-profond),var(--vert-sauge));
}
.presta-card__icon{
  width:52px;height:52px;
  background:rgba(45,95,45,.08);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
  font-size:1.5rem;
}
.presta-card__icon img{width:28px;height:28px}
.presta-card__title{font-size:1.25rem;margin-bottom:10px}
.presta-card__desc{
  color:var(--texte-clair);
  font-size:.92rem;
  line-height:1.6;
  margin-bottom:16px;
}
.presta-card__price{
  display:inline-block;
  font-size:.85rem;
  font-weight:600;
  color:var(--dore);
  padding:4px 12px;
  background:rgba(200,169,98,.1);
  border-radius:20px;
  margin-bottom:16px;
}
.presta-card__link{
  font-weight:600;
  font-size:.92rem;
  color:var(--vert-profond);
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.presta-card__link::after{content:'→';transition:transform var(--transition)}
.presta-card__link:hover::after{transform:translateX(4px)}

/* ---------- Grille villes ---------- */
.villes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
}
.ville-card{
  display:flex;
  align-items:center;
  gap:12px;
  padding:20px;
  background:var(--blanc);
  border-radius:var(--radius-md);
  box-shadow:var(--ombre-douce);
  transition:all var(--transition);
}
.ville-card:hover{transform:translateY(-2px);box-shadow:var(--ombre-elevee);color:var(--vert-profond)}
.ville-card__icon{font-size:1.3rem;width:28px;height:28px;flex-shrink:0}
.ville-card__icon img{width:28px;height:28px}
.ville-card__name{font-weight:600;font-size:1rem}
.ville-card__cp{font-size:.82rem;color:var(--texte-clair)}

/* ---------- Valeurs / features ---------- */
.valeurs-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:32px;
}
.valeur-item{
  text-align:center;
  padding:32px 20px;
}
.valeur-item__icon{
  width:64px;height:64px;
  margin:0 auto 20px;
  background:rgba(200,169,98,.12);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
}
.valeur-item__icon img{width:32px;height:32px}
.valeur-item__title{font-size:1.15rem;margin-bottom:8px}
.valeur-item__desc{color:var(--texte-clair);font-size:.92rem}

/* ---------- Chiffres / stats ---------- */
.stats-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:48px;
  padding:40px 0;
}
.stat{text-align:center}
.stat__number{
  font-family:'DM Serif Display',serif;
  font-size:clamp(2rem,4vw,3rem);
  color:var(--dore);
  line-height:1.1;
}
.stat__label{
  font-size:.9rem;
  color:var(--texte-clair);
  margin-top:4px;
}

/* ---------- Tableau de tarifs (Position 0) ---------- */
.tarif-table-wrap{
  overflow-x:auto;
  margin:24px 0;
  border-radius:var(--radius-md);
  box-shadow:var(--ombre-douce);
}
.tarif-table{
  width:100%;
  border-collapse:collapse;
  background:var(--blanc);
}
.tarif-table thead{background:var(--vert-profond);color:var(--blanc)}
.tarif-table th{
  padding:16px 20px;
  text-align:left;
  font-weight:600;
  font-size:.92rem;
  letter-spacing:.02em;
}
.tarif-table td{
  padding:14px 20px;
  border-bottom:1px solid var(--fond-sable);
  font-size:.95rem;
}
.tarif-table tbody tr:last-child td{border-bottom:none}
.tarif-table tbody tr:hover{background:rgba(45,95,45,.03)}
.tarif-table .prix{
  font-weight:600;
  color:var(--vert-profond);
  white-space:nowrap;
}
.tarif-note{
  font-size:.85rem;
  color:var(--texte-clair);
  margin-top:12px;
  font-style:italic;
}

/* ---------- Simulateur ---------- */
.simulateur{
  background:var(--blanc);
  border-radius:var(--radius-lg);
  padding:40px;
  box-shadow:var(--ombre-elevee);
  border:2px solid rgba(200,169,98,.2);
  position:relative;
  overflow:hidden;
}
.simulateur::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:5px;
  background:linear-gradient(90deg,var(--dore),var(--vert-sauge));
}
.simulateur__title{
  font-size:1.5rem;
  margin-bottom:8px;
}
.simulateur__subtitle{
  color:var(--texte-clair);
  margin-bottom:32px;
}
.simulateur__steps{
  display:flex;
  gap:8px;
  margin-bottom:32px;
}
.simulateur__step-indicator{
  flex:1;
  height:4px;
  background:var(--fond-sable);
  border-radius:2px;
  transition:background var(--transition);
}
.simulateur__step-indicator.active{background:var(--vert-profond)}
.simulateur__step-indicator.done{background:var(--vert-sauge)}

.simulateur__panel{display:none}
.simulateur__panel.active{display:block}

.simulateur__question{
  font-size:1.1rem;
  font-weight:600;
  margin-bottom:20px;
}

/* Options du simulateur */
.sim-options{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:12px;
  margin-bottom:24px;
}
.sim-option{
  position:relative;
  padding:16px 20px;
  background:var(--fond-creme);
  border:2px solid transparent;
  border-radius:var(--radius-md);
  cursor:pointer;
  transition:all var(--transition);
}
.sim-option:hover{border-color:var(--vert-sauge);background:var(--blanc)}
.sim-option.selected{
  border-color:var(--vert-profond);
  background:var(--blanc);
  box-shadow:0 0 0 3px rgba(45,95,45,.1);
}
.sim-option input{position:absolute;opacity:0;pointer-events:none}
.sim-option__label{font-weight:600;font-size:.95rem;display:block;margin-bottom:2px}
.sim-option__note{font-size:.82rem;color:var(--texte-clair)}

/* Resultat simulateur */
.sim-result{
  text-align:center;
  padding:32px;
  background:var(--fond-creme);
  border-radius:var(--radius-md);
  margin-bottom:24px;
}
.sim-result__label{font-size:.9rem;color:var(--texte-clair);margin-bottom:8px}
.sim-result__price{
  font-family:'DM Serif Display',serif;
  font-size:2.5rem;
  color:var(--vert-profond);
  line-height:1.2;
}
.sim-result__detail{font-size:.85rem;color:var(--texte-clair);margin-top:8px}

/* ---------- Formulaires ---------- */
.form-group{margin-bottom:20px}
.form-group label{
  display:block;
  font-size:.9rem;
  font-weight:600;
  margin-bottom:6px;
  color:var(--texte);
}
.form-group label .required{color:var(--erreur);margin-left:2px}
.form-input,
.form-select,
.form-textarea{
  width:100%;
  padding:12px 16px;
  border:2px solid var(--fond-sable);
  border-radius:var(--radius-sm);
  background:var(--blanc);
  transition:border-color var(--transition),box-shadow var(--transition);
  font-size:.95rem;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus{
  border-color:var(--vert-sauge);
  box-shadow:0 0 0 3px rgba(123,174,127,.15);
}
.form-textarea{resize:vertical;min-height:100px}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235A5A5A' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

.form-honeypot{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- FAQ / Accordion ---------- */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--fond-sable);
}
.faq-item__question{
  width:100%;
  padding:20px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  font-weight:600;
  font-size:1.05rem;
  text-align:left;
  color:var(--texte);
  cursor:pointer;
  transition:color var(--transition);
}
.faq-item__question:hover{color:var(--vert-profond)}
.faq-item__icon{
  flex-shrink:0;
  width:28px;height:28px;
  border-radius:50%;
  background:var(--fond-creme);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;
  transition:transform .3s,background .3s;
}
.faq-item.open .faq-item__icon{transform:rotate(45deg);background:var(--vert-profond);color:var(--blanc)}
.faq-item__answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
}
.faq-item__answer__inner{
  padding:0 0 20px;
  color:var(--texte-clair);
  line-height:1.7;
}

/* ---------- Contenu article / guide ---------- */
.article-content{
  max-width:760px;
  margin:0 auto;
}
.article-content h2{
  margin-top:48px;
  padding-top:32px;
  border-top:1px solid var(--fond-sable);
}
.article-content h2:first-child{margin-top:0;padding-top:0;border-top:none}
.article-content h3{
  margin-top:32px;
  color:var(--texte);
}
.article-content ul,.article-content ol{
  margin:0 0 1em 24px;
  color:var(--texte);
}
.article-content ul{list-style:disc}
.article-content ol{list-style:decimal}
.article-content li{margin-bottom:6px;line-height:1.6}
.article-content blockquote{
  margin:24px 0;
  padding:20px 24px;
  border-left:4px solid var(--dore);
  background:rgba(200,169,98,.06);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  font-style:italic;
  color:var(--texte-clair);
}

/* Info box */
.info-box{
  padding:24px;
  border-radius:var(--radius-md);
  margin:24px 0;
}
.info-box--vert{background:rgba(45,95,45,.06);border-left:4px solid var(--vert-profond)}
.info-box--dore{background:rgba(200,169,98,.08);border-left:4px solid var(--dore)}
.info-box__title{font-weight:600;margin-bottom:6px}

/* Calendrier / tableau mois */
.calendrier-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:12px;
  margin:24px 0;
}
.mois-card{
  padding:16px;
  background:var(--blanc);
  border-radius:var(--radius-md);
  text-align:center;
  box-shadow:var(--ombre-douce);
  transition:all var(--transition);
}
.mois-card:hover{transform:translateY(-2px);box-shadow:var(--ombre-elevee)}
.mois-card__nom{
  font-family:'DM Serif Display',serif;
  font-size:1rem;
  color:var(--vert-profond);
  margin-bottom:4px;
}
.mois-card__saison{font-size:.78rem;color:var(--dore);font-weight:600}
.mois-card--actif{border:2px solid var(--vert-profond);background:rgba(45,95,45,.04)}

/* ---------- CTA bandeau ---------- */
.cta-bandeau{
  padding:60px 0;
  text-align:center;
}
.cta-bandeau h2{color:var(--blanc);margin-bottom:12px}
.cta-bandeau p{color:rgba(255,255,255,.85);margin-bottom:28px;font-size:1.1rem}

/* ---------- Maillage interne ---------- */
.liens-internes{
  padding:32px;
  background:var(--fond-creme);
  border-radius:var(--radius-md);
  margin:40px 0;
}
.liens-internes__title{
  font-size:1.1rem;
  margin-bottom:16px;
}
.liens-internes__list{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.liens-internes__list a{
  display:inline-block;
  padding:8px 16px;
  background:var(--blanc);
  border-radius:20px;
  font-size:.88rem;
  font-weight:600;
  color:var(--vert-profond);
  transition:all var(--transition);
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.liens-internes__list a:hover{background:var(--vert-profond);color:var(--blanc)}

/* Navigation guides (prev/next) */
.guide-nav{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin:48px 0 0;
  padding-top:32px;
  border-top:1px solid var(--fond-sable);
}
.guide-nav__link{
  padding:20px;
  background:var(--blanc);
  border-radius:var(--radius-md);
  box-shadow:var(--ombre-douce);
  transition:all var(--transition);
}
.guide-nav__link:hover{box-shadow:var(--ombre-elevee);transform:translateY(-2px)}
.guide-nav__link--next{text-align:right}
.guide-nav__dir{font-size:.8rem;color:var(--texte-clair);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.guide-nav__title{font-weight:600;color:var(--vert-profond)}

/* ---------- Footer ---------- */
.footer{
  background:var(--vert-profond);
  color:rgba(255,255,255,.8);
  padding:64px 0 0;
}
.footer a{color:rgba(255,255,255,.8);transition:color var(--transition)}
.footer a:hover{color:var(--dore)}
.footer__grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:40px;
  padding-bottom:48px;
}
.footer__brand{
  font-family:'DM Serif Display',serif;
  font-size:1.3rem;
  color:var(--blanc);
  margin-bottom:16px;
}
.footer__brand span{color:var(--dore)}
.footer__desc{font-size:.9rem;line-height:1.6;margin-bottom:16px}
.footer__col-title{
  font-weight:600;
  color:var(--blanc);
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:16px;
}
.footer__links li{margin-bottom:10px}
.footer__links a{font-size:.9rem}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.12);
  padding:20px 0;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.82rem;
  flex-wrap:wrap;
  gap:12px;
}
@media(max-width:768px){
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:480px){
  .footer__grid{grid-template-columns:1fr}
}

/* ---------- Sticky bar mobile ---------- */
.sticky-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--blanc);
  padding:12px 20px;
  box-shadow:0 -4px 20px rgba(0,0,0,.1);
  z-index:90;
}
.sticky-bar .btn{width:100%}
@media(max-width:768px){
  .sticky-bar{display:block}
  body{padding-bottom:72px}
}

/* ---------- Page merci ---------- */
.merci-content{
  text-align:center;
  padding:100px 0;
  max-width:560px;
  margin:0 auto;
}
.merci-content__icon{
  font-size:4rem;
  margin-bottom:24px;
  width:80px;height:80px;
  margin-left:auto;margin-right:auto;
  background:var(--succes);
  color:var(--blanc);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}

/* ---------- Contact page ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:48px;
  align-items:start;
}
@media(max-width:768px){
  .contact-grid{grid-template-columns:1fr;gap:32px}
}

/* ---------- Mentions legales ---------- */
.legal-content{max-width:760px;margin:0 auto}
.legal-content h2{margin-top:40px}
.legal-content p,.legal-content li{font-size:.95rem}

/* ---------- Sitemap page ---------- */
.sitemap-content{max-width:900px;margin:0 auto}
.sitemap-section{margin-bottom:40px}
.sitemap-section h3{margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--fond-sable)}
.sitemap-section ul{margin-left:20px;list-style:disc}
.sitemap-section li{margin-bottom:6px}
.sitemap-section a{font-size:.95rem}

/* ---------- Utilitaires ---------- */
.text-center{text-align:center}
.text-left{text-align:left}
.mb-0{margin-bottom:0}
.mb-1{margin-bottom:8px}
.mb-2{margin-bottom:16px}
.mb-3{margin-bottom:24px}
.mb-4{margin-bottom:32px}
.mb-6{margin-bottom:48px}
.mt-4{margin-top:32px}
.mt-6{margin-top:48px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- Animations legeres ---------- */
.fade-in{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease;
}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ---------- Print ---------- */
@media print{
  .header,.footer,.sticky-bar,.nav__cta,.simulateur{display:none!important}
  body{background:#fff;color:#000;font-size:12pt}
  a{color:#000;text-decoration:underline}
}
