/* ============================================================
   BENNE DIRECT ALSACE — Thème (Temps B)
   100% piloté par tokens. Flat, radius 0, aucune box-shadow.
   Palette imposée : #15191A / #F2EEE5 / #6BAB45 + jaune sécurité.
   ============================================================ */

:root{
  /* --- Couleurs (paires vérifiées AA) --- */
  --ink:#15191A;          /* charcoal / texte / fonds sombres   */
  --ink-2:#1E2425;        /* surface sombre legerement plus claire */
  --ink-3:#2C3334;        /* bordure sur sombre */
  --cream:#F2EEE5;        /* fond clair chaud */
  --paper:#FFFFFF;        /* fond clair alterne */
  --brand:#6BAB45;        /* vert eco (dominante) */
  --brand-600:#52902F;    /* vert hover */
  --brand-700:#3D6E22;    /* vert profond */
  --accent:#6BAB45;       /* accent = vert (le jaune a ete retire) */
  --accent-600:#52902F;

  --text:#15191A;
  --text-muted:#54595A;   /* >=4.5:1 sur cream & paper */
  --text-on-dark:#F2EEE5;
  --muted-on-dark:#A9B0A6;/* >=4.5:1 sur --ink */

  --line:#E2DBCB;         /* hairline chaud sur clair */
  --line-strong:#15191A;  /* bord net d'emphase */
  --line-dark:#333B3C;    /* bord sur sombre */

  /* --- Espacement (base 8) --- */
  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --s5:64px; --s6:96px;

  /* --- Rythme de section fluide --- */
  --pad-x:clamp(20px,5vw,96px);
  --pad-y:clamp(44px,6vw,92px);
  --maxw:1400px;
  --maxw-text:74ch;

  --radius:0px;           /* industriel net */

  --font-head:"Archivo",system-ui,sans-serif;
  --font-body:"DM Sans",system-ui,sans-serif;
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:clamp(1rem,0.55vw + 0.9rem,1.075rem);
  line-height:1.62;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  font-variant-ligatures:none;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

h1,h2,h3,h4{
  font-family:var(--font-head);
  font-weight:900;
  line-height:1.02;
  letter-spacing:-0.02em;
  margin:0;
  text-wrap:balance;
}
p{margin:0;text-wrap:pretty;}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);}
.section{padding-block:var(--pad-y);}
.bg-cream{background:var(--cream);}
.bg-paper{background:var(--paper);}
.bg-ink{background:var(--ink);color:var(--text-on-dark);}
.bg-brand{background:var(--brand);color:var(--ink);}

/* Kicker — étiquette tamponnée */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-weight:800;
  font-size:0.8rem;letter-spacing:0.16em;text-transform:uppercase;
  padding:0;border:0;background:transparent;color:var(--ink);
  margin-bottom:20px;
}
.bg-ink .kicker{color:var(--cream);}
.bg-brand .kicker{color:var(--ink);}
.kicker .num{font-variant-numeric:tabular-nums;color:var(--brand);}
.bg-brand .kicker .num{color:var(--ink);}

.h2{font-size:clamp(2rem,4.2vw,3.65rem);letter-spacing:-0.03em;}
.lede{
  font-size:clamp(1.1rem,1.4vw,1.4rem);
  line-height:1.5;color:var(--text-muted);max-width:62ch;
}
.bg-ink .lede{color:var(--muted-on-dark);}
.bg-brand .lede{color:var(--brand-700);color:#214012;}

.measure{max-width:var(--maxw-text);}

/* ---------- CTA unique (réutilisé partout) ---------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-head);font-weight:800;
  font-size:1.02rem;letter-spacing:0.01em;
  padding:17px 26px;border:2px solid var(--brand);
  background:var(--brand);
  color:#13230A;               /* texte bake en sombre sur vert (AA) */
  transition:background .18s ease,border-color .18s ease,transform .18s ease;
}
.btn .arw{font-size:1.15em;line-height:0;transform:translateY(1px);}
.btn:hover{background:var(--brand-600);border-color:var(--brand-600);}
.btn:active{transform:translatey(1px);}
.btn--ghost{
  background:transparent;color:var(--ink);border-color:var(--line-strong);
}
.btn--ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.bg-ink .btn--ghost{color:var(--cream);border-color:var(--muted-on-dark);}
.bg-ink .btn--ghost:hover{background:var(--cream);color:var(--ink);border-color:var(--cream);}

.link-arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-weight:800;text-transform:uppercase;
  letter-spacing:0.05em;font-size:0.92rem;
  border-bottom:3px solid var(--accent);padding-bottom:3px;
  transition:gap .18s ease;
}
.link-arrow:hover{gap:16px;}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:color-mix(in srgb,var(--cream) 88%,transparent);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom:2px solid var(--line-strong);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  height:74px;
}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--font-head);}
.brand .mark{
  width:40px;height:40px;border:2px solid var(--ink);
  display:grid;place-items:center;background:var(--brand);flex:none;
}
.brand .mark svg{width:24px;height:24px;}
.brand .name{font-weight:900;font-size:1.18rem;letter-spacing:-0.02em;line-height:1;}
.brand .name small{display:block;font-weight:600;font-size:0.62rem;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--text-muted);font-family:var(--font-body);margin-top:3px;}

.nav{display:flex;align-items:center;gap:30px;}
.nav a{font-family:var(--font-head);font-weight:700;font-size:0.96rem;white-space:nowrap;
  padding:6px 0;border-bottom:2px solid transparent;}
.nav a:hover{border-color:var(--brand);}
.header-cta{display:flex;align-items:center;gap:14px;}
.header-cta .tel{font-family:var(--font-head);font-weight:800;font-size:0.96rem;
  display:inline-flex;align-items:center;gap:8px;}
.header-cta .btn{white-space:nowrap;padding-block:13px;}

.burger{display:none;width:46px;height:46px;border:2px solid var(--ink);
  background:var(--cream);align-items:center;justify-content:center;flex:none;}
.burger span{display:block;width:20px;height:2.5px;background:var(--ink);position:relative;}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:20px;height:2.5px;background:var(--ink);}
.burger span::before{top:-6px;}.burger span::after{top:6px;}

/* ============================================================
   HERO — asymetrie editoriale, image locale + panneau texte
   ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--cream);}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 0.95fr;
  align-items:stretch;min-height:min(82vh,760px);
}
.hero-copy{
  padding-block:clamp(40px,5vw,80px);
  padding-inline:0 clamp(28px,3.5vw,64px);
  display:flex;flex-direction:column;justify-content:center;
  width:100%;
}
.hero-copy h1{
  font-size:clamp(2rem,3.9vw,3.7rem);line-height:1.0;
  text-transform:uppercase;letter-spacing:-0.03em;
}
.hero-copy h1 .hl{color:var(--brand);}
.hero-copy h1 .y{
  background:var(--ink);color:var(--cream);
  padding:0 .12em;box-decoration-break:clone;-webkit-box-decoration-break:clone;
}
.hero-copy .lede{margin-top:26px;}
.hero-eyebrow{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:28px;
  font-family:var(--font-head);font-weight:800;text-transform:uppercase;
  letter-spacing:0.08em;font-size:0.8rem;
}
.hero-eyebrow .dept{
  display:inline-flex;align-items:stretch;line-height:1;white-space:nowrap;
  border:2px solid var(--line-strong);background:var(--paper);color:var(--ink);
}
.hero-eyebrow .dept .d-name{padding:7px 10px;display:inline-flex;align-items:center;}
.hero-eyebrow .dept .d-num{
  padding:7px 10px;display:inline-flex;align-items:center;
  background:var(--brand);color:#13230A;font-variant-numeric:tabular-nums;
}
.hero-eyebrow .dept.alt .d-num{background:var(--ink);color:var(--cream);}
.hero-eyebrow .d-label{
  display:inline-flex;align-items:center;gap:9px;color:var(--text-muted);letter-spacing:0.1em;
}
.hero-eyebrow .d-label::before{content:"";width:20px;height:2px;background:var(--brand);}

/* Recherche code postal */
.cp-search{margin-top:34px;}
.cp-search form{display:flex;flex-wrap:wrap;gap:0;border:2px solid var(--line-strong);}
.cp-search .field{display:flex;align-items:center;flex:1 1 220px;background:var(--paper);}
.cp-search .field svg{width:20px;height:20px;margin-left:16px;flex:none;color:var(--text-muted);}
.cp-search input{
  flex:1;border:0;background:transparent;font-family:var(--font-body);
  font-size:1.05rem;padding:16px 14px;color:var(--ink);min-width:0;outline:none;
}
.cp-search button{
  flex:1 1 auto;border:0;background:var(--brand);color:#13230A;
  font-family:var(--font-head);font-weight:800;font-size:1rem;
  padding:16px 24px;display:inline-flex;align-items:center;gap:10px;justify-content:center;
  border-left:2px solid var(--line-strong);transition:background .18s ease;
}
.cp-search button:hover{background:var(--brand-600);}
.cp-hint{margin-top:12px;font-size:0.86rem;color:var(--text-muted);}

.cp-result{
  margin-top:18px;border:2px solid var(--brand);background:var(--paper);
  padding:16px 18px;font-size:0.95rem;display:none;
}
.cp-result.show{display:block;animation:pop .3s ease;}
.cp-result strong{font-family:var(--font-head);}
@keyframes pop{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

.hero-media{position:relative;border-left:2px solid var(--line-strong);min-height:340px;}
.hero-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.hero-media .tag{
  position:absolute;left:0;bottom:0;z-index:2;
  background:var(--ink);color:var(--cream);
  font-family:var(--font-head);font-weight:800;font-size:0.82rem;
  letter-spacing:0.04em;padding:12px 18px;display:flex;align-items:center;gap:10px;
}
.hero-media .tag b{color:var(--accent);}

/* ============================================================
   Generic section header
   ============================================================ */
.sec-head{max-width:64ch;margin-bottom:clamp(40px,5vw,64px);}
.sec-head .lede{margin-top:20px;}

/* ---------- Bloc "problème" / intro band ---------- */
.split{
  display:grid;grid-template-columns:1fr 1fr;align-items:stretch;
  gap:clamp(28px,4vw,64px);
}
.split .media{position:relative;min-height:300px;border:2px solid var(--line-strong);}
.split .media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.split .body{display:flex;flex-direction:column;justify-content:center;}
.bg-ink .split .media{border-color:var(--line-dark);}

/* ---------- Steps (comment ça aide) — PAS 3 boites identiques ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--line-strong);}
.step{padding:clamp(26px,2.4vw,40px);border-right:2px solid var(--line-strong);position:relative;background:var(--paper);}
.step:last-child{border-right:0;}
.step .n{
  font-family:var(--font-head);font-weight:900;font-size:3.6rem;line-height:1;
  color:var(--brand);letter-spacing:-0.04em;
}
.step:nth-child(2) .n{color:var(--ink);}
.step:nth-child(3) .n{
  -webkit-text-stroke:2px var(--ink);color:transparent;
}
.step h3{font-size:1.4rem;margin:16px 0 12px;text-transform:uppercase;letter-spacing:-0.01em;}
.step p{color:var(--text-muted);font-size:0.98rem;}
.step .link-arrow{margin-top:18px;}

/* ---------- Prix table (section sombre, transition diagonale) ---------- */
.diag-top{}
.price-layout{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.price-media{position:relative;border:2px solid var(--line-dark);min-height:360px;}
.price-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.price-media .stamp{
  position:absolute;top:0;right:0;background:var(--accent);color:var(--ink);
  font-family:var(--font-head);font-weight:900;padding:10px 16px;font-size:0.86rem;
  letter-spacing:0.04em;
}
.ptable{width:100%;border-collapse:collapse;font-size:1.02rem;}
.ptable caption{text-align:left;color:var(--muted-on-dark);font-size:0.9rem;margin-bottom:14px;}
.ptable th,.ptable td{text-align:left;padding:17px 16px;border-bottom:1px solid var(--line-dark);}
.ptable thead th{
  font-family:var(--font-head);text-transform:uppercase;font-size:0.78rem;
  letter-spacing:0.1em;color:var(--accent);border-bottom:2px solid var(--accent);
}
.ptable tbody tr:hover{background:var(--ink-2);}
.ptable .vol{font-family:var(--font-head);font-weight:900;font-size:1.25rem;color:var(--cream);white-space:nowrap;}
.ptable .price{font-family:var(--font-head);font-weight:800;color:var(--brand);white-space:nowrap;text-align:right;}
.ptable td.type{color:var(--muted-on-dark);}
.price-note{margin-top:22px;color:var(--muted-on-dark);font-size:0.92rem;border-top:1px solid var(--line-dark);padding-top:18px;}
.price-note b{color:var(--accent);}

/* ---------- Volume choisir ---------- */
.vol-layout{display:grid;grid-template-columns:1.1fr 0.9fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.vol-media{position:relative;border:2px solid var(--line-strong);min-height:340px;}
.vol-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.vol-list{list-style:none;margin:26px 0 0;padding:0;border-top:2px solid var(--line-strong);}
.vol-list li{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:baseline;
  padding:18px 0;border-bottom:1px solid var(--line);}
.vol-list .cap{font-family:var(--font-head);font-weight:900;font-size:1.5rem;color:var(--brand-700);white-space:nowrap;}
.vol-list .desc{color:var(--text-muted);}
.callout{
  border:2px solid var(--line-strong);background:var(--accent);color:var(--ink);
  padding:18px 22px;margin-top:28px;font-weight:500;
}
.callout b{font-family:var(--font-head);}

/* ---------- Villes ---------- */
.city-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(20px,2.4vw,36px);margin-top:8px;}
.city-block h3{font-size:1.3rem;text-transform:uppercase;letter-spacing:-0.01em;
  padding-bottom:12px;border-bottom:2px solid var(--line-strong);margin-bottom:16px;}
.city-block h3 .ct{color:var(--brand);}
.city-block ul{list-style:none;margin:0;padding:0;}
.city-block li{padding:9px 0;border-bottom:1px solid var(--line);color:var(--text-muted);
  display:flex;gap:10px;align-items:baseline;}
.city-block li b{color:var(--ink);font-weight:600;}
.city-block li::before{content:"";width:7px;height:7px;background:var(--brand);flex:none;transform:translateY(2px);}
.villes-top{display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(28px,4vw,56px);align-items:stretch;margin-bottom:clamp(36px,4vw,56px);}
.villes-media{position:relative;border:2px solid var(--line-strong);min-height:320px;}
.villes-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}

/* ---------- Loueurs (cartes) ---------- */
.loueurs{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(22px,2.6vw,32px);}
.loueur{border:2px solid var(--ink);background:var(--cream);display:flex;flex-direction:column;}
.loueur .ph{position:relative;aspect-ratio:4/3;overflow:hidden;border-bottom:2px solid var(--ink);}
.loueur .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.loueur:hover .ph img{transform:scale(1.04);}
.loueur .ph .badge{position:absolute;left:0;top:0;background:var(--ink);color:var(--cream);
  font-family:var(--font-head);font-weight:800;font-size:0.72rem;letter-spacing:0.08em;
  text-transform:uppercase;padding:7px 12px;display:flex;align-items:center;gap:7px;}
.loueur .ph .badge svg{width:13px;height:13px;color:var(--accent);}
.loueur .body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1;}
.loueur h3{font-size:1.5rem;text-transform:uppercase;}
.loueur .meta{margin-top:8px;color:var(--text-muted);font-size:0.92rem;display:flex;gap:14px;flex-wrap:wrap;}
.loueur .meta .stars{color:var(--accent-600);font-weight:700;font-family:var(--font-head);}
.loueur .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.loueur .tags span{border:1.5px solid var(--line-strong);font-size:0.76rem;font-weight:600;
  padding:4px 9px;font-family:var(--font-head);letter-spacing:0.02em;}
.loueur .foot{margin-top:auto;padding-top:20px;}
.loueur .foot .link-arrow{font-size:0.84rem;}

/* ---------- Pour qui (profils) ---------- */
.profils-layout{display:grid;grid-template-columns:0.95fr 1.05fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.profils-media{position:relative;border:2px solid var(--line-dark);min-height:340px;}
.profils-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.profil-list{list-style:none;margin:0;padding:0;}
.profil-list li{padding:24px 0;border-bottom:1px solid var(--line-dark);}
.profil-list li:first-child{padding-top:0;}
.profil-list h3{font-size:1.35rem;text-transform:uppercase;color:var(--cream);display:flex;align-items:center;gap:14px;}
.profil-list h3 .ic{width:30px;height:30px;border:2px solid var(--brand);display:grid;place-items:center;flex:none;}
.profil-list h3 .ic svg{width:17px;height:17px;color:var(--brand);}
.profil-list p{color:var(--muted-on-dark);margin-top:10px;padding-left:44px;font-size:0.98rem;}

/* ---------- CTA band ---------- */
.cta-band{background:#2F5A18;color:var(--cream);}
.cta-band .inner{display:grid;grid-template-columns:1.3fr auto;gap:clamp(28px,4vw,56px);align-items:center;}
.cta-band h2{font-size:clamp(1.9rem,3.6vw,3rem);text-transform:uppercase;color:var(--cream);}
.cta-band .kicker{color:var(--cream);}
.cta-band .lede{color:rgba(242,238,229,.92);margin-top:14px;}
.cta-band .btn{background:var(--ink);border-color:var(--ink);color:var(--cream);}
.cta-band .btn:hover{background:#000;border-color:#000;}

/* ---------- Devis form ---------- */
.devis-layout{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.devis-media{position:relative;border:2px solid var(--line-strong);min-height:420px;}
.devis-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
.devis-media .overlay{position:absolute;inset:auto 0 0 0;background:var(--ink);color:var(--cream);
  padding:20px 22px;}
.devis-media .overlay b{font-family:var(--font-head);color:var(--accent);display:block;font-size:1.1rem;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-grid .full{grid-column:1/-1;}
.field-group{display:flex;flex-direction:column;gap:7px;}
.field-group label{font-family:var(--font-head);font-weight:700;font-size:0.82rem;
  text-transform:uppercase;letter-spacing:0.06em;}
.field-group input,.field-group select,.field-group textarea{
  font-family:var(--font-body);font-size:1rem;padding:14px 14px;
  border:2px solid var(--line-strong);background:var(--paper);color:var(--ink);
  border-radius:0;outline:none;transition:border-color .15s ease;
}
.field-group textarea{resize:vertical;min-height:96px;}
.field-group input:focus,.field-group select:focus,.field-group textarea:focus{border-color:var(--brand);}
.field-group .err{color:#B42318;font-size:0.8rem;font-weight:600;display:none;}
.field-group.invalid input,.field-group.invalid select{border-color:#B42318;}
.field-group.invalid .err{display:block;}
.form-foot{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:6px;}
.form-foot .note{font-size:0.84rem;color:var(--text-muted);}
.form-success{display:none;border:2px solid var(--brand);background:#EAF4E2;padding:20px;
  font-weight:500;align-items:center;gap:14px;}
.form-success.show{display:flex;}
.form-success svg{width:28px;height:28px;color:var(--brand-700);flex:none;}

/* ---------- FAQ ---------- */
.faq{max-width:980px;margin-inline:auto;}
.faq details{border-bottom:2px solid var(--line-strong);}
.faq details:first-of-type{border-top:2px solid var(--line-strong);}
.faq summary{
  list-style:none;outline:none!important;border:0!important;
  cursor:pointer;padding:24px 56px 24px 0;position:relative;
  font-family:var(--font-head);font-weight:800;font-size:clamp(1.1rem,1.7vw,1.45rem);
  letter-spacing:-0.01em;line-height:1.2;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary:focus,.faq summary:focus-visible{outline:none!important;}
.faq summary::after{
  content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);
  font-size:1.8rem;font-weight:700;color:var(--brand);transition:transform .2s ease;line-height:0;
}
.faq details[open] summary::after{content:"\2212";color:var(--ink);}
.faq .ans{padding:0 56px 26px 0;color:var(--text-muted);max-width:80ch;}
.faq details[open] .ans{animation:fade .28s ease;}
@keyframes fade{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:none;}}

/* ---------- Communes desservies (maillage) ---------- */
.communes{columns:0;}
.commune-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:2px;border:2px solid var(--line-dark);background:var(--line-dark);
}
.commune-grid a{
  background:var(--ink);padding:10px 14px;font-size:0.86rem;color:var(--muted-on-dark);
  font-family:var(--font-body);transition:background .15s ease,color .15s ease;
}
.commune-grid a:hover{background:var(--brand);color:var(--ink);}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:var(--muted-on-dark);border-top:4px solid var(--brand);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:clamp(28px,3vw,48px);padding-block:clamp(48px,6vw,80px);}
.footer-top h4{font-family:var(--font-head);color:var(--cream);font-size:0.82rem;
  letter-spacing:0.12em;text-transform:uppercase;margin-bottom:18px;font-weight:800;}
.footer-top ul{list-style:none;margin:0;padding:0;}
.footer-top li{padding:6px 0;}
.footer-top a:hover{color:var(--brand);}
.footer-brand .brand .name{color:var(--cream);}
.footer-brand p{margin-top:18px;font-size:0.94rem;max-width:38ch;}
.footer-bar{border-top:1px solid var(--line-dark);padding-block:22px;display:flex;
  justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:0.84rem;}
.footer-bar .dept-pills{display:flex;gap:8px;}
.footer-bar .dept-pills span{border:1.5px solid var(--line-dark);padding:3px 10px;font-family:var(--font-head);font-weight:700;color:var(--cream);}

/* ============================================================
   Reveal on load (un seul page-load orchestré)
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(22px);}
  .reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.3,1);}
}

/* ============================================================
   RESPONSIVE — 1440 / 1200 / 768 / 360
   ============================================================ */
@media (min-width:1700px){
  :root{--maxw:1600px;--pad-x:clamp(40px,5vw,120px);}
}
@media (min-width:2200px){
  :root{--maxw:1840px;}
  body{font-size:clamp(1.05rem,0.35vw + 1rem,1.22rem);}
}
@media (max-width:1100px){
  .price-layout,.vol-layout,.villes-top,.profils-layout,.devis-layout,.split{grid-template-columns:1fr;}
  .price-media,.vol-media,.villes-media,.profils-media,.devis-media,.split .media{min-height:300px;aspect-ratio:16/9;}
  .cta-band .inner{grid-template-columns:1fr;}
}
@media (max-width:1024px){
  .nav{display:none;}
  .burger{display:flex;}
}
@media (max-width:880px){
  .header-cta{display:none;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-media{border-left:0;border-top:2px solid var(--line-strong);aspect-ratio:16/10;min-height:0;}
  .steps{grid-template-columns:1fr;}
  .step{border-right:0;border-bottom:2px solid var(--line-strong);}
  .step:last-child{border-bottom:0;}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .form-grid{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .cp-search .field{flex:1 1 100%;}
  .cp-search button{flex:1 1 100%;border-left:0;border-top:2px solid var(--line-strong);}
  .vol-list li{grid-template-columns:1fr;gap:4px;}
  .hero-eyebrow{flex-wrap:wrap;}
}

/* Mobile nav panel */
.mobile-nav{
  position:fixed;inset:74px 0 0 0;z-index:55;background:var(--ink);color:var(--cream);
  transform:translateY(-100%);transition:transform .3s ease;
  display:flex;flex-direction:column;padding:30px var(--pad-x);gap:4px;visibility:hidden;
}
.mobile-nav.open{transform:translateY(0);visibility:visible;}
.mobile-nav a{font-family:var(--font-head);font-weight:800;font-size:1.5rem;text-transform:uppercase;
  padding:16px 0;border-bottom:1px solid var(--line-dark);}
.mobile-nav .btn{margin-top:22px;justify-content:center;}
.mobile-nav .tel{margin-top:14px;font-family:var(--font-head);font-weight:800;font-size:1.1rem;}


/* ============================================================
   PAGES COMMUNES  /location-benne-{ville}/
   ============================================================ */
.hero--commune{background:var(--cream);border-bottom:2px solid var(--line-strong);}
.hero--commune .wrap{padding-block:clamp(40px,6vw,82px);}
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;align-items:center;
  font-family:var(--font-head);font-weight:700;text-transform:uppercase;
  letter-spacing:0.08em;font-size:0.72rem;color:var(--text-muted);margin-bottom:24px;}
.breadcrumb a{color:var(--text-muted);}
.breadcrumb a:hover{color:var(--brand-700);}
.breadcrumb .sep{color:var(--line-strong);}
.breadcrumb .here{color:var(--ink);}
.hero--commune h1{font-size:clamp(1.9rem,3.6vw,3.3rem);text-transform:uppercase;
  letter-spacing:-0.03em;line-height:1.02;max-width:20ch;}
.hero--commune h1 .y{background:var(--accent);color:var(--ink);padding:0 .1em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;}
.hero--commune .lede{margin-top:22px;}
.lstat{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.lstat span{border:2px solid var(--line-strong);background:var(--paper);padding:9px 14px;
  font-family:var(--font-head);font-weight:800;font-size:0.82rem;text-transform:uppercase;
  letter-spacing:0.04em;display:inline-flex;gap:8px;align-items:center;}
.lstat span b{color:var(--brand-700);font-size:1.05rem;}

/* Cartes loueurs (données GMB, sans photo) */
.lcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(20px,2.4vw,30px);}
.lcard{border:2px solid var(--ink);background:var(--cream);display:flex;flex-direction:column;}
.lcard .lc-top{padding:16px 20px;border-bottom:2px solid var(--ink);background:var(--paper);
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.lcard .lc-cat{font-family:var(--font-head);font-weight:800;font-size:0.66rem;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--text-muted);}
.lcard h3{font-size:1.16rem;text-transform:uppercase;line-height:1.06;margin-top:7px;}
.lcard .lc-rate{white-space:nowrap;font-family:var(--font-head);font-weight:800;font-size:0.84rem;
  color:var(--ink);border:2px solid var(--line-strong);padding:5px 9px;display:inline-flex;gap:6px;align-items:center;flex:none;}
.lcard .lc-rate .st{color:var(--accent-600);}
.lcard .lc-rate.empty{color:var(--text-muted);border-color:var(--line);font-weight:600;}
.lcard .lc-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px;flex:1;}
.lcard .lc-row{display:flex;gap:10px;align-items:flex-start;color:var(--text-muted);font-size:0.92rem;}
.lcard .lc-row svg{width:16px;height:16px;flex:none;margin-top:2px;color:var(--brand);}
.lcard .lc-dist{font-family:var(--font-head);font-weight:700;color:var(--brand-700);}
.lcard .lc-foot{margin-top:auto;display:flex;gap:10px;flex-wrap:wrap;padding-top:16px;}
.lcard .lc-tel{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--line-strong);
  padding:11px 15px;font-family:var(--font-head);font-weight:800;font-size:0.84rem;background:var(--paper);color:var(--ink);}
.lcard .lc-tel:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.lcard .lc-tel svg{width:15px;height:15px;}
.lcard .lc-cta{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--brand);
  background:var(--brand);color:#13230A;padding:11px 15px;font-family:var(--font-head);font-weight:800;font-size:0.84rem;}
.lcard .lc-cta:hover{background:var(--brand-600);border-color:var(--brand-600);}

.lcaption{margin-top:18px;color:var(--text-muted);font-size:0.92rem;max-width:70ch;}
.no-loueurs{border:2px solid var(--line-strong);background:var(--accent);color:var(--ink);
  padding:22px 24px;font-weight:500;max-width:70ch;}
.no-loueurs b{font-family:var(--font-head);}

/* Variante éclaircie de la grille communes pour fond sombre déjà gérée par .commune-grid */
.voisins-grid{margin-top:8px;}

/* ---------- Footer : maillage complet des communes ---------- */
.footer-communes{background:var(--ink-2);border-top:1px solid var(--line-dark);
  padding-block:clamp(30px,4vw,54px);}
.footer-communes h4{font-family:var(--font-head);color:var(--cream);font-size:0.82rem;
  letter-spacing:0.12em;text-transform:uppercase;margin:0 0 8px;font-weight:800;}
.footer-communes .fc-intro{color:var(--muted-on-dark);font-size:0.84rem;margin:0 0 18px;max-width:80ch;}
.footer-communes .fc-dep{margin-top:22px;}
.footer-communes .fc-label{display:inline-block;font-family:var(--font-head);font-weight:800;
  font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);
  border-bottom:2px solid var(--accent);padding-bottom:4px;margin-bottom:14px;}
.footer-communes ul{list-style:none;margin:0;padding:0;columns:6 150px;column-gap:26px;}
.footer-communes li{break-inside:avoid;}
.footer-communes a{display:block;color:var(--muted-on-dark);font-size:0.78rem;line-height:1.95;}
.footer-communes a:hover{color:var(--brand);}
@media(max-width:760px){.footer-communes ul{columns:2 110px;}}

/* ---------- Annuaire loueurs : barre de filtre ---------- */
.lfilter{display:flex;flex-wrap:wrap;gap:18px 22px;align-items:flex-end;
  border:2px solid var(--ink);background:var(--cream);padding:22px 24px;margin-bottom:32px;}
.lfilter .lf-group{display:flex;flex-direction:column;gap:9px;flex:1 1 260px;min-width:0;}
.lfilter label{font-family:var(--font-head);font-weight:800;font-size:0.74rem;
  text-transform:uppercase;letter-spacing:0.07em;color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;}
.lfilter label svg{width:15px;height:15px;color:var(--brand-700);flex:none;}
.lf-control{position:relative;display:block;}
.lfilter select{width:100%;font-family:var(--font-head);font-weight:700;font-size:1rem;
  padding:14px 46px 14px 16px;line-height:1.2;cursor:pointer;
  border:2px solid var(--line-strong);background-color:var(--paper);color:var(--ink);
  border-radius:0;outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233D6E22' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:18px;
  transition:border-color .15s ease;}
.lfilter select:hover{border-color:var(--brand);}
.lfilter select:focus-visible{border-color:var(--brand);outline:3px solid var(--accent);outline-offset:2px;}
.lfilter .lf-count{margin-left:auto;align-self:center;display:inline-flex;align-items:baseline;gap:8px;
  font-family:var(--font-head);font-weight:800;font-size:0.82rem;text-transform:uppercase;
  letter-spacing:0.05em;color:var(--ink);border:2px solid var(--line-strong);background:var(--paper);padding:10px 16px;}
.lfilter .lf-count span{color:var(--brand-700);font-size:1.35rem;line-height:1;}
.dep-chip{display:inline-flex;align-items:center;justify-content:center;min-width:28px;
  border:2px solid var(--line-strong);font-family:var(--font-head);font-weight:800;font-size:0.72rem;
  padding:2px 6px;margin-right:6px;}
.lc-deps{display:flex;align-items:center;flex:none;}
@media(max-width:620px){.lfilter{flex-direction:column;align-items:stretch;gap:16px;}
  .lfilter .lf-group{flex:1 1 auto;}
  .lfilter .lf-count{margin-left:0;align-self:flex-start;}}

/* ---------- Bannière pages annuaire (img de fond, texte centré) ---------- */
.hero--banner{position:relative;overflow:hidden;border-bottom:2px solid var(--line-strong);background:var(--ink);}
.hero--banner::before{content:"";position:absolute;inset:0;background-image:var(--banner-img);
  background-size:cover;background-position:center;}
.hero--banner::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(21,25,26,.80),rgba(21,25,26,.64));}
.hero--banner .wrap{position:relative;z-index:2;text-align:center;
  padding-block:clamp(56px,8vw,116px);display:flex;flex-direction:column;align-items:center;}
.hero--banner .breadcrumb{justify-content:center;color:rgba(242,238,229,.7);}
.hero--banner .breadcrumb a{color:rgba(242,238,229,.7);}
.hero--banner .breadcrumb a:hover{color:var(--accent);}
.hero--banner .breadcrumb .sep{color:rgba(242,238,229,.4);}
.hero--banner .breadcrumb .here{color:var(--cream);}
.hero--banner h1{color:var(--cream);font-size:clamp(2rem,4vw,3.5rem);text-transform:uppercase;
  letter-spacing:-0.03em;line-height:1.02;max-width:24ch;margin-inline:auto;}
.hero--banner .lede{color:rgba(242,238,229,.92);margin:22px auto 0;max-width:62ch;}
.hero--banner .lstat{justify-content:center;}
.hero--banner .lstat span{background:rgba(255,255,255,.07);border-color:rgba(242,238,229,.38);color:var(--cream);}
.hero--banner .lstat span b{color:var(--accent);}

/* ---------- Filtre : label générique + département segmenté + icône ville ---------- */
.lf-lab{font-family:var(--font-head);font-weight:800;font-size:0.74rem;text-transform:uppercase;
  letter-spacing:0.07em;color:var(--ink);display:inline-flex;align-items:center;gap:8px;}
.lf-seg{display:inline-flex;border:2px solid var(--line-strong);background:var(--paper);flex-wrap:wrap;}
.lf-seg-btn{font-family:var(--font-head);font-weight:800;font-size:0.82rem;text-transform:uppercase;
  letter-spacing:0.03em;padding:12px 18px;background:transparent;color:var(--ink);border:0;
  border-right:2px solid var(--line-strong);cursor:pointer;transition:background .15s ease,color .15s ease;}
.lf-seg-btn:last-child{border-right:0;}
.lf-seg-btn:hover{background:var(--cream);}
.lf-seg-btn.is-active{background:var(--ink);color:var(--cream);}
.lf-control .lf-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:17px;height:17px;color:var(--brand-700);pointer-events:none;}
.lf-city .lf-control select{padding-left:42px;}
@media(max-width:620px){.lf-seg{width:100%;}.lf-seg-btn{flex:1;}}

/* ---------- Logo header ---------- */
.brand-logo{height:clamp(40px,3.6vw,54px);width:auto;display:block;}
.brand--footer .name{font-size:1.18rem;line-height:1;}

/* ---------- Villes en accordéons ---------- */
.city-acc-wrap{display:grid;gap:14px;margin-top:8px;}
.city-acc{border:2px solid var(--line-strong);background:var(--paper);}
.city-acc>summary{list-style:none;cursor:pointer;padding:18px 54px 18px 20px;position:relative;
  font-family:var(--font-head);font-weight:800;font-size:clamp(1.05rem,1.6vw,1.3rem);
  text-transform:uppercase;letter-spacing:-0.01em;line-height:1.15;
  outline:none!important;border:0!important;}
.city-acc>summary::-webkit-details-marker{display:none;}
.city-acc>summary:focus,.city-acc>summary:focus-visible{outline:none!important;}
.city-acc>summary .ct{color:var(--brand);}
.city-acc>summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);
  font-size:1.7rem;font-weight:700;color:var(--brand);line-height:0;}
.city-acc[open]>summary::after{content:"\2212";color:var(--ink);}
.city-acc-body{padding:0 20px 20px;animation:fade .28s ease;}
.city-acc-body ul{list-style:none;margin:0;padding:0;}
.city-acc-body li{padding:9px 0;border-bottom:1px solid var(--line);color:var(--text-muted);
  display:flex;gap:10px;align-items:baseline;}
.city-acc-body li b{color:var(--ink);font-weight:600;}
.city-acc-body li::before{content:"";width:7px;height:7px;background:var(--brand);flex:none;transform:translateY(2px);}

/* ---------- FAQ : image gauche + accordéons droite ---------- */
.faq-layout{display:grid;grid-template-columns:0.82fr 1.18fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.faq-media{position:relative;border:2px solid var(--line-strong);min-height:380px;}
.faq-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.faq-layout .faq{max-width:none;margin:0;}
.faq-layout .sec-head{margin-bottom:24px;}
@media(max-width:980px){.faq-layout{grid-template-columns:1fr;}
  .faq-media{min-height:0;aspect-ratio:16/10;}}

/* ---------- Loueur (accueil) : description ---------- */
.loueur-desc{margin-top:10px;color:var(--text-muted);font-size:0.95rem;line-height:1.5;}
.loueur .foot .link-arrow{font-size:0.84rem;}

/* ---------- Hero : image en fond + accroche code postal ---------- */
.hero--bg{position:relative;overflow:hidden;background:var(--ink);border-bottom:2px solid var(--line-strong);}
.hero--bg::before{content:"";position:absolute;inset:0;background-image:var(--hero-img);
  background-size:cover;background-position:center right;}
.hero--bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(95deg,rgba(17,21,22,.95) 0%,rgba(17,21,22,.85) 38%,rgba(17,21,22,.5) 74%,rgba(17,21,22,.28) 100%);}
.hero--bg .wrap{position:relative;z-index:2;}
.hero-inner{max-width:700px;padding-block:clamp(52px,8vw,116px);}
.hero--bg .hero-eyebrow{color:var(--cream);margin-bottom:24px;}
.hero--bg .hero-eyebrow .d-label{color:rgba(242,238,229,.82);}
.hero--bg .hero-eyebrow .d-label::before{background:var(--brand);}
.hero--bg .hero-headline{color:var(--cream);font-size:clamp(2rem,4.2vw,3.7rem);text-transform:uppercase;
  letter-spacing:-0.03em;line-height:1.0;font-family:var(--font-head);font-weight:900;margin:0;text-wrap:balance;}
.hero--bg .hero-headline .hl{color:var(--brand);}
.hero--bg .hero-headline .y{background:var(--cream);color:var(--ink);padding:0 .12em;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;}
/* H1 SEO discret (eyebrow) */
.hero-eyebrow h1.d-label{font-size:0.8rem;font-weight:800;letter-spacing:0.13em;line-height:1.2;margin:0;}
.hero--bg .lede{color:rgba(242,238,229,.92);margin-top:24px;max-width:58ch;}
.cp-incite{margin:30px 0 12px;font-family:var(--font-head);font-weight:800;
  font-size:clamp(1rem,1.5vw,1.18rem);color:var(--cream);display:flex;align-items:center;gap:11px;line-height:1.25;}
.cp-incite::before{content:"";width:22px;height:3px;background:var(--brand);flex:none;}
.cp-search--hero{max-width:600px;}

/* Hero centré : texte au centre + overlay plus uniforme */
.hero--bg::after{background:linear-gradient(180deg,rgba(17,21,22,.82) 0%,rgba(17,21,22,.64) 52%,rgba(17,21,22,.80) 100%);}
.hero--bg::before{background-position:center;}
.hero-inner{margin-inline:auto;text-align:center;}
.hero--bg .hero-eyebrow{justify-content:center;flex-wrap:wrap;}
.hero--bg .lede{margin-inline:auto;}
.cp-incite{justify-content:center;text-align:center;}
.cp-search--hero{margin-inline:auto;}

/* ---------- 3 pages + carrousel meilleurs loueurs ---------- */
.cat-links{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:clamp(32px,4vw,48px);}
.cat-link{border:2px solid var(--ink);background:var(--paper);padding:20px 22px;display:flex;
  flex-direction:column;gap:6px;transition:background .15s ease,color .15s ease;}
.cat-link b{font-family:var(--font-head);font-weight:900;font-size:1.3rem;text-transform:uppercase;letter-spacing:-0.01em;}
.cat-link span{color:var(--text-muted);font-size:0.9rem;}
.cat-link::after{content:"\2192";font-family:var(--font-head);font-weight:800;align-self:flex-end;color:var(--brand);font-size:1.2rem;margin-top:4px;}
.cat-link:hover{background:var(--ink);color:var(--cream);}
.cat-link:hover span{color:var(--muted-on-dark);}
.cat-link:hover::after{color:var(--accent);}
@media(max-width:760px){.cat-links{grid-template-columns:1fr;}}

.carousel-tabs{display:flex;border:2px solid var(--line-strong);width:max-content;max-width:100%;
  margin-bottom:22px;flex-wrap:wrap;background:var(--paper);}
.ct-tab{font-family:var(--font-head);font-weight:800;font-size:0.86rem;text-transform:uppercase;letter-spacing:0.03em;
  padding:12px 20px;background:transparent;border:0;border-right:2px solid var(--line-strong);cursor:pointer;color:var(--ink);}
.ct-tab:last-child{border-right:0;}
.ct-tab.is-active{background:var(--ink);color:var(--cream);}
.carousel-body{position:relative;display:flex;align-items:stretch;gap:12px;}
.carousel-panels{overflow:hidden;flex:1;min-width:0;}
.carousel-track{display:none;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:10px;}
.carousel-track.is-active{display:flex;}
.carousel-track .lcard{flex:0 0 clamp(280px,80vw,330px);scroll-snap-align:start;}
.car-arrow{flex:none;align-self:center;width:48px;height:48px;border:2px solid var(--ink);background:var(--paper);
  font-size:1.6rem;line-height:1;font-family:var(--font-head);cursor:pointer;display:grid;place-items:center;
  color:var(--ink);transition:background .15s ease,color .15s ease;}
.car-arrow:hover{background:var(--ink);color:var(--cream);}
@media(max-width:700px){.car-arrow{display:none;}}

/* ===== Ajustements UI ===== */
/* Hero : pas de surlignage, conteneur plus large, moins haut */
.hero--bg .hero-headline .y{background:transparent;color:var(--cream);padding:0;}
.hero-inner{max-width:960px;padding-block:clamp(44px,6vw,86px);}

/* Villes : image gauche maîtrisée + accordéons sous le texte */
.villes-top--acc{align-items:stretch;}
.villes-top--acc .villes-media{min-height:320px;border:1px solid var(--card-line);border-radius:14px;overflow:hidden;box-shadow:var(--card-sh);}

/* Coins arrondis (cartes, médias, boutons) */
.lcard,.loueur,.step,.cat-link,.callout,.no-loueurs,.lfilter{border-radius:12px;}
.lcard{overflow:hidden;}
.lcard .lc-rate,.lcard .lc-tel,.lcard .lc-cta{border-radius:8px;}
.lcard:hover{border-color:var(--brand);}
.devis-media,.price-media,.vol-media,.villes-media,.profils-media,.faq-media,.hero-media,.loueur .ph{border-radius:12px;overflow:hidden;}

/* Padding section #loueurs (demande) */
section#loueurs{padding-top:50px;padding-bottom:50px;}

/* Formulaire devis : box noire mise en avant */
.devis-box{background:var(--ink);padding:clamp(24px,3.2vw,44px);border-radius:14px;}
.devis-box .field-group label{color:var(--cream);}
.devis-box .form-foot .note{color:var(--muted-on-dark);}
.devis-box .form-success{background:#13230A;border-color:var(--brand);color:var(--cream);}

/* Carrousels meilleurs loueurs : 3 lignes titrées */
.best-row{margin-top:clamp(34px,4vw,52px);}
.best-row-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;}
.best-row-head h3{font-family:var(--font-head);font-weight:900;font-size:clamp(1.25rem,2.2vw,1.9rem);
  text-transform:uppercase;letter-spacing:-0.02em;line-height:1.05;}
.best-row-arrows{display:flex;gap:8px;flex:none;}
@media(max-width:700px){.best-row-arrows{display:none;}}

/* Méthode : image gauche + étapes en accordéons à droite */
.methode-layout{display:grid;grid-template-columns:0.82fr 1.18fr;gap:clamp(28px,4vw,56px);align-items:stretch;}
.methode-media{position:relative;min-height:320px;border:1px solid var(--card-line);border-radius:14px;overflow:hidden;box-shadow:var(--card-sh);}
.methode-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.steps-acc .city-acc{margin-bottom:12px;border-radius:10px;overflow:hidden;}
.steps-acc .city-acc>summary{display:flex;align-items:center;padding-right:54px;}
.steps-acc .step-n{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:30px;
  margin-right:12px;background:var(--brand);color:#13230A;font-family:var(--font-head);font-weight:900;
  border-radius:8px;font-size:1rem;flex:none;}
@media(max-width:1000px){.methode-layout{grid-template-columns:1fr;}.methode-media{aspect-ratio:16/9;min-height:0;}}

/* ===================================================================
   MODERNISATION — cartes blanches arrondies + ombres, plus de bordure noire
   =================================================================== */
:root{--card-line:#ECE6D8;--card-sh:0 8px 28px rgba(21,25,26,.07);--card-sh-h:0 16px 40px rgba(21,25,26,.14);}

/* Cartes loueurs */
.lcard{background:#fff;border:1px solid var(--card-line);border-radius:18px;overflow:hidden;
  box-shadow:var(--card-sh);transition:box-shadow .22s ease,transform .22s ease;}
.lcard:hover{box-shadow:var(--card-sh-h);transform:translateY(-4px);border-color:var(--card-line);}
.lcard .lc-top{border-bottom:1px solid #F2ECE0;background:transparent;}
.lcard .lc-rate{border:1px solid var(--card-line);border-radius:999px;background:#fff;}
.lcard .lc-rate.empty{border-color:var(--card-line);}
.lcard .lc-tel{border:1px solid var(--card-line);border-radius:11px;background:#fff;color:var(--ink);}
.lcard .lc-tel:hover{background:var(--ink);color:#fff;border-color:var(--ink);}
.lcard .lc-cta{border:0;border-radius:11px;background:var(--brand);color:#10220a;box-shadow:0 6px 16px rgba(82,144,47,.28);}
.lcard .lc-cta:hover{background:var(--brand-600);box-shadow:0 8px 22px rgba(82,144,47,.36);}
.dep-chip{border:1px solid var(--card-line);border-radius:7px;background:#FAF7F0;}

/* Cartes catégories : image de fond + overlay */
.cat-links{gap:18px;}
.cat-link{position:relative;overflow:hidden;border:0;border-radius:18px;padding:26px;min-height:160px;
  display:flex;flex-direction:column;justify-content:flex-end;gap:5px;color:#fff;
  box-shadow:var(--card-sh);transition:box-shadow .22s ease,transform .22s ease;}
.cat-link::before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--cl-img);
  background-size:cover;background-position:center;transition:transform .5s ease;}
.cat-link::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(21,25,26,.12),rgba(21,25,26,.86));}
.cat-link>b,.cat-link>span{position:relative;z-index:2;}
.cat-link b{color:#fff;font-size:1.55rem;}
.cat-link span{color:rgba(255,255,255,.85);font-size:0.95rem;}
.cat-link:hover{transform:translateY(-4px);box-shadow:var(--card-sh-h);color:#fff;}
.cat-link:hover::before{transform:scale(1.07);}
.cat-link:hover span{color:rgba(255,255,255,.85);}

/* Accordéons adoucis */
.city-acc{border:1px solid var(--card-line);border-radius:14px;background:#fff;box-shadow:var(--card-sh);}
.city-acc[open]{box-shadow:var(--card-sh-h);}

/* Filtre annuaire adouci */
.lfilter{border:1px solid var(--card-line);border-radius:16px;background:#fff;box-shadow:var(--card-sh);}
.lfilter select{border:1px solid var(--card-line);border-radius:10px;}
.lf-seg{border:1px solid var(--card-line);border-radius:10px;overflow:hidden;background:#fff;}
.lf-seg-btn{border-right:1px solid var(--card-line);}
.lfilter .lf-count{border:1px solid var(--card-line);border-radius:10px;background:#fff;}

/* Flèches carrousel rondes */
.car-arrow{border:1px solid var(--card-line);border-radius:50%;background:#fff;box-shadow:var(--card-sh);color:var(--ink);}
.car-arrow:hover{background:var(--ink);color:#fff;border-color:var(--ink);}

/* Boutons généraux arrondis */
.btn{border-radius:12px;}

/* Accroche code postal (CP ou commune) — peut passer sur 2 lignes */
.cp-incite{white-space:normal;font-size:clamp(0.88rem,1.3vw,1.1rem);}

/* ============================================================
   Onglet sticky "Retirer ma fiche" + modale de retrait
   ============================================================ */
.header-removal{background:none;border:0;cursor:pointer;font-family:var(--font-head);font-weight:800;
  font-size:0.9rem;color:#C0392B;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;padding:6px 0;}
.header-removal:hover{color:#9B2419;text-decoration:underline;}
.header-removal svg{width:15px;height:15px;flex:none;}
.mobile-nav .header-removal{font-size:1.5rem;text-transform:uppercase;padding:16px 0;width:100%;
  border-bottom:1px solid var(--line-dark);color:#E5705F;justify-content:flex-start;}
.mobile-nav .header-removal:hover{text-decoration:none;color:#F08A7B;}

.bda-removal-modal[hidden]{display:none;}
.bda-removal-modal{position:fixed;inset:0;z-index:130;display:flex;align-items:center;justify-content:center;padding:20px;}
.brm-backdrop{position:absolute;inset:0;background:rgba(10,12,13,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);}
.brm-card{position:relative;z-index:2;background:#fff;border-radius:18px;max-width:520px;width:100%;
  padding:clamp(24px,3vw,36px);max-height:90vh;overflow:auto;box-shadow:0 24px 60px rgba(0,0,0,.3);}
.brm-close{position:absolute;top:12px;right:16px;background:none;border:0;font-size:1.9rem;line-height:1;
  color:var(--text-muted);cursor:pointer;}
.brm-close:hover{color:var(--ink);}
.brm-card h3{font-family:var(--font-head);font-weight:900;font-size:1.4rem;text-transform:uppercase;
  letter-spacing:-0.01em;margin:0 24px 12px 0;}
.brm-intro{color:var(--text-muted);font-size:0.95rem;margin:0 0 20px;}
.brm-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px;}
.brm-field{display:flex;flex-direction:column;gap:6px;}
.brm-field.brm-full{grid-column:1/-1;}
.brm-field span{font-family:var(--font-head);font-weight:700;font-size:0.76rem;text-transform:uppercase;
  letter-spacing:0.05em;color:var(--ink);}
.brm-field input,.brm-field textarea{font-family:var(--font-body);font-size:0.98rem;padding:12px 13px;
  border:1px solid var(--card-line);border-radius:10px;background:#fff;color:var(--ink);outline:none;transition:border-color .15s ease;}
.brm-field input:focus,.brm-field textarea:focus{border-color:var(--brand);}
.brm-field textarea{resize:vertical;min-height:70px;}
.bda-removal-modal .btn{width:100%;justify-content:center;}
.brm-note{margin-top:14px;font-size:0.84rem;color:var(--text-muted);}
.brm-note a{color:var(--brand-700);font-weight:700;}
@media(max-width:520px){.brm-grid{grid-template-columns:1fr;}}
body.brm-open{overflow:hidden;}
.cp-search--hero{max-width:680px;}
@media(max-width:620px){.cp-incite{white-space:normal;}}

/* ===== Carte loueur épurée (carrousel + annuaire) ===== */
.lcard--c{display:flex;flex-direction:column;}
.lcard--c .lc-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:18px 20px 0;}
.lcard--c .lc-cat{margin:0;font-family:var(--font-head);font-weight:800;font-size:0.63rem;text-transform:uppercase;
  letter-spacing:0.09em;color:var(--brand-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;}
.lcard--c .lc-rate{flex:none;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-head);font-weight:800;
  font-size:0.82rem;color:var(--ink);background:#F4FAEE;border:1px solid #DCEBCF;border-radius:999px;padding:5px 11px;white-space:nowrap;}
.lcard--c .lc-rate .st{color:#F2A100;}
.lcard--c .lc-rate i{font-style:normal;color:var(--text-muted);font-weight:600;font-size:0.78rem;}
.lcard--c .lc-rate.empty{color:var(--text-muted);background:#F7F4EE;border-color:var(--card-line);font-weight:700;font-size:0.7rem;}
.lc-name{margin:0;padding:11px 20px 2px;font-family:var(--font-head);font-weight:900;font-size:1.16rem;line-height:1.13;
  text-transform:uppercase;letter-spacing:-0.01em;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.48em;}
.lcard--c .lc-body{padding:12px 20px 0;display:flex;flex-direction:column;gap:9px;flex:1;}
.lcard--c .lc-row{display:flex;gap:9px;align-items:flex-start;color:var(--text-muted);font-size:0.9rem;line-height:1.35;}
.lcard--c .lc-row svg{width:16px;height:16px;flex:none;margin-top:1px;color:var(--brand);}
.lcard--c .lc-zone{align-items:center;}
.lcard--c .lc-zone .lc-deps{display:flex;gap:5px;flex:none;}
.lcard--c .lc-phone{color:var(--ink);font-family:var(--font-head);font-weight:800;font-size:0.92rem;text-decoration:none;}
.lcard--c .lc-phone:hover{color:var(--brand-700);}
.lcard--c .lc-foot{margin-top:auto;padding:16px 20px 18px;}
.lcard--c .lc-foot .lc-cta{width:100%;justify-content:center;display:inline-flex;align-items:center;gap:8px;padding:12px 14px;
  border:0;border-radius:11px;background:var(--brand);color:#10220a;font-family:var(--font-head);font-weight:800;font-size:0.85rem;
  box-shadow:0 6px 16px rgba(82,144,47,.28);}
.lcard--c .lc-foot .lc-cta:hover{background:var(--brand-600);box-shadow:0 8px 22px rgba(82,144,47,.36);}

/* Carrousel : masquer la barre de défilement (navigation via flèches) */
.carousel-track{scrollbar-width:none;-ms-overflow-style:none;}
.carousel-track::-webkit-scrollbar{display:none;height:0;width:0;}

/* Cartes catégories : fond plus noir + bouton clairement cliquable */
.cat-link{justify-content:flex-end;padding-bottom:22px;cursor:pointer;}
.cat-link::after{background:linear-gradient(180deg,rgba(10,12,13,.62) 0%,rgba(10,12,13,.78) 55%,rgba(10,12,13,.93) 100%);}
.cat-link .cl-cta{position:relative;z-index:2;display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  margin-top:14px;font-family:var(--font-head);font-weight:800;font-size:0.8rem;text-transform:uppercase;letter-spacing:0.04em;
  color:#fff;background:rgba(255,255,255,.16);border:1.5px solid rgba(255,255,255,.55);padding:8px 15px;border-radius:999px;
  transition:background .2s ease,border-color .2s ease,color .2s ease,gap .2s ease;}
.cat-link:hover{transform:translateY(-5px);}
.cat-link:hover .cl-cta{background:var(--brand);border-color:var(--brand);color:#10220a;gap:12px;}

/* FAQ : mots-clés gras plus contrastés */
.faq .ans b{color:var(--ink);font-weight:700;}

/* Cartes catégories : plus hautes, fond plus noir, bouton vert par défaut */
.cat-link{min-height:230px;}
.cat-link::after{background:linear-gradient(180deg,rgba(6,8,9,.82) 0%,rgba(6,8,9,.88) 50%,rgba(6,8,9,.97) 100%);}
.cat-link .cl-cta{background:var(--brand);border:1.5px solid var(--brand);color:#10220a;}
.cat-link:hover .cl-cta{background:var(--brand-600);border-color:var(--brand-600);color:#10220a;gap:12px;}

/* Cartes loueurs : sans ombre (juste la bordure) */
.lcard{box-shadow:none;}
.lcard:hover{box-shadow:none;transform:translateY(-3px);border-color:var(--brand);}

/* Filtre Ville : champ de saisie avec suggestions */
.lf-city .lf-control input{width:100%;font-family:var(--font-head);font-weight:700;font-size:1rem;
  padding:14px 16px 14px 42px;line-height:1.2;border:1px solid var(--card-line);border-radius:10px;
  background:#fff;color:var(--ink);outline:none;transition:border-color .15s ease;}
.lf-city .lf-control input:hover{border-color:var(--brand);}
.lf-city .lf-control input:focus-visible{border-color:var(--brand);outline:3px solid var(--accent);outline-offset:2px;}
.lf-city .lf-control input::placeholder{color:var(--text-muted);font-weight:600;}

/* Bouton "Site internet" / "Demander un devis" : texte blanc */
.lcard .lc-cta,.lcard--c .lc-foot .lc-cta{color:#fff;}

/* === Cartes catégories : plus hautes + image assombrie + CTA blanc === */
.cat-link{min-height:280px;}
.cat-link::before{filter:brightness(.4) saturate(.95)!important;}
.cat-link::after{background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,.55) 100%)!important;}
.cat-link .cl-cta,.cat-link:hover .cl-cta{color:#fff;}

/* === Tous les CTA verts : texte BLANC === */
.btn{color:#fff;}
.btn--ghost{color:var(--ink);}
.btn--ghost:hover{color:var(--cream);}
.cp-search button{color:#fff;}

/* ============================================================
   PAGE COMMUNE — encart "qui choisir", infos utiles, voisins
   ============================================================ */

/* --- Encart bien visible : top 5 candidats --- */
.choisir-box{background:#fff;border:1px solid var(--card-line);border-radius:18px;
  padding:clamp(22px,2.6vw,34px);margin-bottom:clamp(26px,3vw,40px);position:relative;overflow:hidden;}
.choisir-box::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--brand);}
.choisir-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:800;
  font-size:0.72rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--brand-700);
  background:#F4FAEE;border:1px solid #DCEBCF;border-radius:999px;padding:6px 14px;margin-bottom:18px;}
.choisir-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;}
.choisir-list li{display:flex;align-items:center;gap:14px;padding:14px 4px;border-bottom:1px solid var(--line);}
.choisir-list li:last-child{border-bottom:0;}
.choisir-list .rank{flex:none;width:32px;height:32px;border-radius:9px;display:grid;place-items:center;
  font-family:var(--font-head);font-weight:900;font-size:0.98rem;background:#F4FAEE;color:var(--brand-700);
  border:1px solid #DCEBCF;}
.choisir-list li:first-child .rank{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.choisir-list .cn{flex:1;min-width:0;font-family:var(--font-head);font-weight:800;font-size:1.02rem;
  color:var(--ink);text-transform:uppercase;letter-spacing:-0.01em;line-height:1.15;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.choisir-list .cr{flex:none;font-family:var(--font-head);font-weight:800;font-size:0.86rem;color:#B5790B;
  display:inline-flex;align-items:center;gap:4px;}
.choisir-list .cd{flex:none;font-size:0.82rem;color:var(--text-muted);white-space:nowrap;}
@media(max-width:560px){.choisir-list .cd{display:none;}.choisir-list .cn{white-space:normal;}}

/* --- Infos utiles : zone d'intervention + tailles de bennes --- */
.infos-layout{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(28px,4vw,56px);align-items:start;}
.info-card{background:#fff;border:1px solid var(--card-line);border-radius:16px;
  padding:clamp(22px,2.4vw,30px);}
.info-card h3{font-size:1.3rem;text-transform:uppercase;letter-spacing:-0.01em;margin:0 0 16px;
  padding-bottom:14px;border-bottom:2px solid var(--brand);}
.info-card h4{font-family:var(--font-head);font-weight:800;font-size:0.78rem;text-transform:uppercase;
  letter-spacing:0.08em;color:var(--text-muted);margin:22px 0 12px;}
.info-meta{list-style:none;margin:0;padding:0;}
.info-meta li{padding:11px 0;border-bottom:1px solid var(--line);color:var(--text-muted);font-size:0.95rem;}
.info-meta li:last-child{border-bottom:0;}
.info-meta li b{color:var(--ink);font-weight:700;font-family:var(--font-head);}
.info-links{display:flex;flex-direction:column;gap:10px;}
.info-links a{display:inline-flex;align-items:center;justify-content:space-between;gap:8px;
  font-family:var(--font-head);font-weight:700;font-size:0.92rem;color:var(--brand-700);
  border:1px solid var(--card-line);border-radius:10px;padding:12px 16px;background:#FAFCF7;
  transition:background .15s ease,border-color .15s ease;}
.info-links a:hover{background:#F4FAEE;border-color:var(--brand);}
.info-links .ext{font-size:0.95rem;color:var(--text-muted);}
@media(max-width:980px){.infos-layout{grid-template-columns:1fr;}}

/* --- Communes voisines : pastilles --- */
.voisins-pills{display:flex;flex-wrap:wrap;gap:10px;}
.voisins-pills a{display:inline-flex;align-items:center;gap:9px;background:#fff;
  border:1px solid var(--card-line);border-radius:999px;padding:11px 18px;
  font-family:var(--font-head);font-weight:700;font-size:0.92rem;color:var(--ink);
  transition:background .15s ease,border-color .15s ease,color .15s ease,transform .15s ease;}
.voisins-pills a::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand);flex:none;}
.voisins-pills a:hover{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-2px);}
.voisins-pills a:hover::before{background:#fff;}

/* --- Encart "qui choisir" : image à gauche, sélection à droite --- */
.choisir-wrap{display:grid;grid-template-columns:0.8fr 1.2fr;gap:clamp(22px,3vw,40px);
  align-items:stretch;margin-bottom:clamp(26px,3vw,40px);}
.choisir-media{position:relative;border-radius:18px;overflow:hidden;min-height:300px;border:1px solid var(--card-line);}
.choisir-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.choisir-wrap .choisir-box{margin-bottom:0;}
.choisir-col{display:flex;flex-direction:column;justify-content:center;}
.choisir-col .sec-head{margin-bottom:22px;max-width:none;}
.choisir-col .sec-head .h2{font-size:clamp(1.5rem,2.6vw,2.2rem);}
.choisir-col .sec-head .lede{margin-top:12px;font-size:clamp(1rem,1.2vw,1.12rem);}
@media(max-width:880px){.choisir-wrap{grid-template-columns:1fr;}.choisir-media{min-height:0;aspect-ratio:16/10;}}

/* badge "Confiance" dans la liste de sélection */
.choisir-list .cbadge{flex:none;display:inline-flex;align-items:center;gap:5px;background:#F4FAEE;
  border:1px solid #CFE8BD;color:var(--brand-700);border-radius:999px;padding:3px 9px;
  font-family:var(--font-head);font-weight:800;font-size:0.64rem;text-transform:uppercase;
  letter-spacing:0.04em;white-space:nowrap;}
.choisir-list .cbadge svg{width:12px;height:12px;flex:none;}
.choisir-list .cbadge.reco{background:var(--brand);border-color:var(--brand);color:#fff;}
@media(max-width:620px){.choisir-list .cbadge{display:none;}}

/* --- Comparatif des loueurs (table GEO) --- */
.cmp-wrap{margin-top:0;}
.cmp-title{font-family:var(--font-head);font-weight:900;font-size:clamp(1.2rem,2vw,1.6rem);
  text-transform:uppercase;letter-spacing:-0.01em;margin:0 0 16px;}
.cmp-scroll{overflow-x:auto;border:1px solid var(--card-line);border-radius:14px;background:#fff;}
.cmp-table{width:100%;border-collapse:collapse;font-size:0.95rem;min-width:620px;}
.cmp-table th,.cmp-table td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);}
.cmp-table thead th{font-family:var(--font-head);font-weight:800;font-size:0.74rem;text-transform:uppercase;
  letter-spacing:0.06em;color:var(--text-muted);background:#FAF8F2;}
.cmp-table tbody tr:last-child td{border-bottom:0;}
.cmp-table .cml-name{font-family:var(--font-head);font-weight:800;color:var(--ink);}
.cmp-table .cml-rate{white-space:nowrap;color:#B5790B;font-family:var(--font-head);font-weight:800;}
.cmp-table tr.is-reco{background:#F4FAEE;}
.cmp-table tr.is-reco .cml-name{color:var(--brand-700);}
.reco-pill{display:inline-flex;align-items:center;font-family:var(--font-head);font-weight:800;
  font-size:0.62rem;text-transform:uppercase;letter-spacing:0.05em;color:#fff;background:var(--brand);
  border-radius:999px;padding:2px 8px;margin-left:6px;vertical-align:middle;}
.cml-cta{display:inline-flex;align-items:center;font-family:var(--font-head);font-weight:800;font-size:0.8rem;
  color:#fff;background:var(--brand);border-radius:8px;padding:7px 14px;white-space:nowrap;}
.cml-cta:hover{background:var(--brand-600);}
.cmp-note{margin-top:14px;color:var(--text-muted);font-size:0.88rem;max-width:80ch;}
.cmp-note b{color:var(--ink);}
.vh{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);}

/* --- Badge "Loueur de confiance" sur les cartes --- */
.lc-trust{margin:11px 20px 0;align-self:flex-start;display:inline-flex;align-items:center;gap:7px;
  background:#F4FAEE;border:1px solid #CFE8BD;color:var(--brand-700);border-radius:999px;padding:6px 12px;
  font-family:var(--font-head);font-weight:800;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.05em;}
.lc-trust svg{width:14px;height:14px;flex:none;color:var(--brand-600);}

/* --- Déchets acceptés / refusés --- */
.dechets-layout{display:grid;grid-template-columns:1.25fr 0.75fr;gap:clamp(24px,3vw,44px);align-items:start;}
.dechet-accept h3,.dechet-refus h3{font-size:1.25rem;text-transform:uppercase;letter-spacing:-0.01em;
  margin:0 0 18px;display:flex;align-items:center;gap:10px;}
.dh-ic{width:26px;height:26px;flex:none;border-radius:8px;padding:4px;}
.dh-ic.ok{background:#E7F5DC;color:var(--brand-700);}
.dh-ic.no{background:#F6E1DC;color:#B5402C;}
.dechet-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.dechet-grid li{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--card-line);
  border-radius:12px;padding:13px 15px;font-family:var(--font-head);font-weight:700;font-size:0.95rem;
  color:var(--ink);line-height:1.2;}
.dechet-grid .di{flex:none;width:42px;height:42px;border-radius:11px;background:#F4FAEE;border:1px solid #DCEBCF;
  display:grid;place-items:center;font-size:1.3rem;line-height:1;}
.dechet-refus{background:var(--ink);border-radius:16px;padding:clamp(22px,2.4vw,30px);color:var(--cream);}
.dechet-refus h3{color:var(--cream);}
.refus-list{list-style:none;margin:0;padding:0;}
.refus-list li{padding:11px 0;border-bottom:1px solid var(--line-dark);color:var(--muted-on-dark);
  display:flex;align-items:center;gap:12px;font-size:0.96rem;}
.refus-list li:last-child{border-bottom:0;}
.refus-list li::before{content:"";width:15px;height:2px;background:#C5503C;flex:none;border-radius:2px;}
.refus-note{margin-top:18px;color:var(--muted-on-dark);font-size:0.85rem;border-top:1px solid var(--line-dark);padding-top:16px;}
@media(max-width:880px){.dechets-layout{grid-template-columns:1fr;}.dechet-grid{grid-template-columns:1fr;}}

/* Déchets acceptés : puce verte (les icônes emoji ont été retirées) */
.dechet-grid li{gap:12px;}
.dechet-grid li::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--brand);flex:none;}

/* --- Encart météo locale (Open-Meteo, auto-actualisé) --- */
.meteo-card{background:#fff;border:1px solid var(--card-line);border-radius:16px;
  padding:clamp(20px,2.4vw,30px);margin-bottom:clamp(18px,2.4vw,28px);}
.meteo-head{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;}
.meteo-eyebrow{font-family:var(--font-head);font-weight:900;font-size:1.25rem;text-transform:uppercase;
  letter-spacing:-0.01em;color:var(--ink);display:block;}
.meteo-sub{color:var(--text-muted);font-size:0.9rem;margin:7px 0 0;max-width:52ch;}
.meteo-now{display:flex;align-items:center;gap:12px;flex:none;}
.meteo-now .mn-ic{display:inline-flex;width:42px;height:42px;color:var(--brand-700);flex:none;}
.meteo-now .mn-ic svg{width:100%;height:100%;}
.meteo-now .mn-meta{display:flex;flex-direction:column;line-height:1.1;}
.meteo-now .mn-temp{font-family:var(--font-head);font-weight:900;font-size:2.1rem;color:var(--ink);}
.meteo-now .mn-lbl{font-size:0.85rem;color:var(--text-muted);}
.meteo-days{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:20px;}
.meteo-day{background:#FAF8F2;border:1px solid var(--card-line);border-radius:12px;padding:13px 8px;
  display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;}
.meteo-day .md-day{font-family:var(--font-head);font-weight:800;font-size:0.72rem;text-transform:uppercase;
  letter-spacing:0.04em;color:var(--text-muted);}
.meteo-day .md-ic{display:inline-flex;width:26px;height:26px;color:var(--brand-700);}
.meteo-day .md-ic svg{width:100%;height:100%;}
.meteo-day .md-temp{font-family:var(--font-head);font-weight:800;font-size:0.92rem;color:var(--ink);}
.meteo-day .md-temp .lo{color:var(--text-muted);font-weight:600;}
.meteo-src{margin-top:14px;font-size:0.78rem;color:var(--text-muted);}
.meteo-card.is-error .meteo-days,.meteo-card.is-error .meteo-src{display:none;}
@media(max-width:620px){.meteo-days{grid-template-columns:repeat(3,1fr);}}
@media(max-width:380px){.meteo-days{grid-template-columns:repeat(2,1fr);}}

/* --- Informations pratiques : 2 cartes --- */
.infos-prat{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,2.4vw,28px);align-items:start;}
@media(max-width:760px){.infos-prat{grid-template-columns:1fr;}}

/* --- Tailles de bennes : grille de cartes --- */
.vol-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px);}
.vol-card{background:#fff;border:1px solid var(--card-line);border-radius:14px;padding:22px 20px;
  display:flex;flex-direction:column;gap:10px;}
.vol-card .cap{font-family:var(--font-head);font-weight:900;font-size:1.6rem;color:var(--brand-700);
  letter-spacing:-0.02em;line-height:1;}
.vol-card p{color:var(--text-muted);font-size:0.92rem;line-height:1.45;}
.vol-foot{margin-top:22px;color:var(--text-muted);font-size:0.92rem;max-width:72ch;}
@media(max-width:900px){.vol-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.vol-grid{grid-template-columns:1fr;}}

/* --- Communes voisines : flèche pour signaler le lien --- */
.voisins-pills a::after{content:"→";font-family:var(--font-head);font-weight:800;color:var(--brand);
  margin-left:1px;transition:transform .15s ease,color .15s ease;}
.voisins-pills a:hover::after{color:#fff;transform:translateX(3px);}

/* --- Accueil : zone carrousels (cat-links + 3 carrousels) — padding vertical réduit --- */
#meilleurs{padding-top:clamp(34px,4vw,60px);padding-bottom:clamp(18px,2.4vw,32px);}
.best-section{padding-block:clamp(22px,2.8vw,40px);}
.best-section .best-row{margin-top:0;}

/* === Encadré "Du gravats au DIB" + numéros d'étapes : texte blanc lisible === */
.callout{background:var(--brand-700);color:#fff;}
.callout b{color:#fff;}
.steps-acc .step-n{background:var(--brand-700);color:#fff;}
