/* ═══════════════════════════════════════════════════════════════════
   DKALMEDIA — Design System v9.0
   Direction : Observatoire Éditorial Français
   
   Fond crème · Encre profonde · Cobalt unique · Chiffre héros

   Couleurs :
     #F0EAE0  Parchemin chaud   (fond principal)
     #1A1108  Encre profonde    (texte)
     #0047CC  Cobalt franc      (action unique)
     #C63020  Terre cuite       (coût / alerte)
     #1A7A50  Vert source       (eau douce)
     #9A7600  Or données        (modéré)
   ═══════════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;text-size-adjust:100%;-webkit-text-size-adjust:100%;scroll-behavior:auto}
html,body{overflow-x:hidden;max-width:100vw}
body{font-family:var(--f-body);background:var(--parch);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--cobalt);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
button{cursor:pointer;font-family:inherit;border:none;background:none}
details summary{list-style:none;cursor:pointer}
details summary::-webkit-details-marker{display:none}
p{max-width:72ch}

/* ── TOKENS ───────────────────────────────────────────────── */
:root{
  color-scheme:light;

  /* Palette */
  --parch:    #F0EAE0;
  --parch-dk: #E5DDD2;
  --parch-dkk:#D6CAB8;
  --ink:      #1A1108;
  --ink-2:    #453525;
  --ink-3:    #8A7260;
  --ink-4:    #BBA898;
  --cobalt:   #0047CC;
  --cobalt-dk:#0035A0;
  --cobalt-lt:#EAF0FF;
  --terra:    #C63020;
  --terra-lt: #FDF0EE;
  --green:    #1A7A50;
  --green-lt: #E8F5EF;
  --gold:     #9A7600;
  --gold-lt:  #FDF7E6;
  --purple:   #5A35A0;
  --purple-lt:#F0EAFA;

  /* Sémantique eau */
  --c-soft:  #1A7A50;
  --c-mod:   #9A7600;
  --c-hard:  #C63020;
  --c-vhard: #5A35A0;

  /* Typographie */
  --f-head:'Syne',Georgia,'Times New Roman',serif;
  --f-body:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --f-mono:'JetBrains Mono','Courier New',monospace;

  /* Échelle */
  --t-hero: clamp(3.5rem,10vw,7rem);
  --t-xl:   clamp(2rem,4.5vw,3.25rem);
  --t-lg:   clamp(1.5rem,3vw,2rem);
  --t-md:   clamp(1.0625rem,2vw,1.25rem);
  --t-body: 1rem;
  --t-sm:   .875rem;
  --t-xs:   .75rem;
  --t-2xs:  .6875rem;

  /* Espacement */
  --s1:.5rem;--s2:1rem;--s3:1.5rem;--s4:2rem;
  --s5:2.5rem;--s6:3rem;--s8:4rem;--s10:5rem;--s12:6rem;

  /* Layout */
  --max:1160px;
  --pad:clamp(1.25rem,5vw,2.5rem);
  --hdr:62px;
  --r:6px;--r-sm:4px;--r-lg:12px;

  /* Règles */
  --rule:1px solid var(--parch-dkk);
  --rule-hvy:2px solid #1A1108;
  --ease:.18s ease;
}

/* ── TYPOGRAPHIE ─────────────────────────────────────────── */
.display{font-family:var(--f-head);font-weight:800;font-size:var(--t-hero);line-height:.92;letter-spacing:-.04em;color:var(--ink)}
.h1{font-family:var(--f-head);font-weight:800;font-size:var(--t-xl);line-height:1.05;letter-spacing:-.03em;color:var(--ink)}
.h2{font-family:var(--f-head);font-weight:700;font-size:var(--t-lg);line-height:1.15;letter-spacing:-.025em;color:var(--ink)}
.h3{font-family:var(--f-head);font-weight:700;font-size:var(--t-md);line-height:1.25;color:var(--ink)}
.eyebrow{font-family:var(--f-mono);font-size:var(--t-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3)}
.eyebrow-line{display:flex;align-items:center;gap:var(--s2)}
.eyebrow-line::before{content:'';width:24px;height:2px;background:var(--cobalt);flex-shrink:0}
.lead{font-size:clamp(1rem,2vw,1.125rem);line-height:1.65;color:var(--ink-2)}
.body{font-size:var(--t-body);line-height:1.65;color:var(--ink-2)}
.body-sm{font-size:var(--t-sm);line-height:1.6;color:var(--ink-3)}
.caption{font-family:var(--f-mono);font-size:var(--t-xs);color:var(--ink-4)}

/* Couleurs utilitaires */
.text-cobalt{color:var(--cobalt)!important}
.text-terra{color:var(--terra)!important}
.text-green{color:var(--green)!important}
.text-gold{color:var(--gold)!important}
.text-ink-2{color:var(--ink-2)!important}
.text-ink-3{color:var(--ink-3)!important}
.text-muted{color:var(--ink-4)!important}
.text-parch{color:var(--parch)!important}

/* ── LAYOUT ──────────────────────────────────────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.wrap--sm{max-width:800px}
.wrap--xs{max-width:640px}
.section{padding:var(--s10) var(--pad)}
.section--sm{padding:var(--s6) var(--pad)}
.section--parch{background:var(--parch)}
.section--dk{background:var(--parch-dk)}
.section--ink{background:var(--ink);color:#fff}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3)}
.split-63{display:grid;grid-template-columns:3fr 2fr;gap:var(--s8);align-items:start}
.split-36{display:grid;grid-template-columns:2fr 3fr;gap:var(--s8);align-items:start}

/* ── HEADER ──────────────────────────────────────────────── */
.hdr{
  position:fixed;inset:0 0 auto;height:var(--hdr);
  background:var(--ink);
  border-bottom:1px solid rgba(240,234,224,.08);
  display:flex;align-items:center;
  padding:0 var(--pad);
  padding-left:max(var(--pad),env(safe-area-inset-left));
  padding-right:max(var(--pad),env(safe-area-inset-right));
  gap:var(--s3);z-index:1000;
  will-change:box-shadow;
}

.hdr-logo{
  font-family:var(--f-head);font-weight:800;
  font-size:1.0625rem;letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:.05em;flex-shrink:0;
}
.hdr-logo:hover{text-decoration:none;opacity:.85}
.hdr-logo .dk{color:#002395}
.hdr-logo .al{color:#FFFFFF}
.hdr-logo .med{color:#ED2939}

.hdr-nav{display:flex;flex:1;margin-left:var(--s2)}
.hdr-nav a{
  font-size:.8125rem;font-weight:500;
  color:rgba(240,234,224,.5);
  padding:.5rem .8rem;min-height:44px;
  display:inline-flex;align-items:center;
  border-bottom:2px solid transparent;
  transition:color var(--ease),border-color var(--ease);
}
.hdr-nav a:hover{color:var(--parch);text-decoration:none;border-bottom-color:var(--cobalt)}

.hdr-cta{
  margin-left:auto;flex-shrink:0;
  font-family:var(--f-head);font-weight:800;font-size:.8125rem;
  letter-spacing:-.01em;
  background:var(--cobalt);color:#fff;
  padding:.5rem 1.125rem;border-radius:var(--r-sm);
  min-height:44px;border:none;cursor:pointer;
  transition:background var(--ease);
  touch-action:manipulation;
}
.hdr-cta:hover{background:var(--cobalt-dk);text-decoration:none;color:#fff}

.mob-toggle{
  display:none;flex-direction:column;align-items:center;
  justify-content:center;gap:5px;padding:8px;
  min-height:44px;min-width:44px;touch-action:manipulation;
  margin-left:auto;
}
.mob-toggle span{display:block;width:20px;height:1.5px;background:var(--parch);border-radius:1px;transition:var(--ease)}
.mob-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.mob-toggle.open span:nth-child(2){opacity:0}
.mob-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mob-drawer{
  display:none;position:fixed;
  top:var(--hdr);left:0;right:0;
  background:var(--ink);
  border-bottom:1px solid rgba(240,234,224,.1);
  padding:var(--s3) var(--pad) var(--s4);
  flex-direction:column;z-index:999;
  max-height:calc(100svh - var(--hdr));
  overflow-y:auto;overscroll-behavior:contain;
}
.mob-drawer.open{display:flex}
.mob-drawer a{
  font-family:var(--f-head);font-weight:700;font-size:1rem;
  color:rgba(240,234,224,.65);
  padding:.9rem 0;border-bottom:1px solid rgba(240,234,224,.07);
  min-height:44px;display:flex;align-items:center;
  transition:color var(--ease);touch-action:manipulation;
}
.mob-drawer a:hover{color:var(--parch);text-decoration:none}
.mob-drawer a:last-child{border-bottom:none}

/* ── SKIP LINK ────────────────────────────────────────────── */
.skip-link{
  position:absolute;top:-60px;left:1rem;
  background:var(--cobalt);color:#fff;
  padding:.6rem 1.25rem;font-size:.875rem;font-weight:700;
  border-radius:0 0 var(--r) var(--r);z-index:9999;
  transition:top .15s;text-decoration:none;
}
.skip-link:focus{top:0}

/* ── HERO HOME ───────────────────────────────────────────── */
.hero-home{
  min-height:100svh;
  padding-top:var(--hdr);
  background:var(--ink);
  position:relative;overflow:hidden;
}

/* Cercles eau */
.hero-home::before{
  content:'';position:absolute;
  right:-8%;top:50%;transform:translateY(-50%);
  width:min(58vw,680px);height:min(58vw,680px);
  border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(0,71,204,.16) 0%,rgba(0,71,204,.05) 50%,transparent 70%);
  pointer-events:none;
}
.hero-home::after{
  content:'';position:absolute;
  right:-4%;top:50%;transform:translateY(-50%);
  width:min(42vw,500px);height:min(42vw,500px);
  border-radius:50%;border:1px solid rgba(240,234,224,.05);
  pointer-events:none;
}

.hero-inner{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(var(--s8),10vh,var(--s12)) var(--pad) var(--s8);
  max-width:var(--max);margin:0 auto;width:100%;
  position:relative;z-index:1;
}

.hero-eyebrow{
  display:flex;align-items:center;gap:var(--s2);
  margin-bottom:var(--s5);
}
.hero-eyebrow::before{content:'';width:28px;height:2px;background:var(--cobalt);flex-shrink:0}
.hero-eyebrow::before{display:none}
.hero-eyebrow span{
  font-family:var(--f-mono);font-size:.6875rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;
  color:rgba(240,234,224,.3);
}

.hero-h1{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(2.25rem,5.5vw,3.75rem);
  line-height:1.04;letter-spacing:-.03em;
  color:var(--parch);margin-bottom:var(--s6);
}
.hero-h1 em{font-style:normal;color:#FF6B52}

/* ── BARRE RECHERCHE ─────────────────────────────────────── */
.search-wrap{max-width:480px;margin-bottom:var(--s6)}
.search-lbl{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;
  color:rgba(240,234,224,.28);display:block;margin-bottom:.65rem;
}
.search-field{
  display:flex;align-items:center;
  border-bottom:1.5px solid rgba(240,234,224,.2);
  gap:var(--s2);transition:border-color .2s;position:relative;
}
.search-field:focus-within{border-bottom-color:var(--cobalt)}

.search-input{
  flex:1;background:none;border:none;outline:none;
  font-family:var(--f-head);font-weight:700;
  font-size:clamp(1.125rem,2.5vw,1.5rem);
  color:var(--parch);padding:.75rem 0;min-height:44px;
  caret-color:var(--cobalt);
}
.search-input::placeholder{color:rgba(240,234,224,.2);font-weight:400}

.search-btn{
  width:42px;height:42px;flex-shrink:0;
  background:var(--cobalt);color:#fff;
  border:none;border-radius:var(--r-sm);
  font-size:1.0625rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background var(--ease),transform var(--ease);
  touch-action:manipulation;
}
.search-btn:hover{background:var(--cobalt-dk);transform:translateX(2px)}
.search-btn:disabled{background:rgba(240,234,224,.12);cursor:default;transform:none}

/* Autocomplete */
.search-ac{
  display:none;position:absolute;
  top:calc(100% + 6px);left:0;right:0;
  background:var(--parch);border-radius:var(--r);
  box-shadow:0 24px 60px rgba(0,0,0,.4);
  overflow:hidden;z-index:10;
}
.search-ac.open{display:block}
.ac-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:.875rem 1.25rem;cursor:pointer;
  border-bottom:var(--rule);transition:background .1s;
}
.ac-item:last-child{border-bottom:none}
.ac-item:hover{background:var(--cobalt-lt)}
.ac-nom strong{font-weight:600;font-size:.9375rem;color:var(--ink)}
.ac-nom span{color:var(--ink-3);font-size:.8125rem;font-weight:400;margin-left:.3rem}
.ac-th{
  font-family:var(--f-mono);font-size:.6875rem;font-weight:700;
  padding:.2rem .55rem;border-radius:100px;
}
.th-soft .ac-th{background:var(--green-lt);color:var(--green)}
.th-mod  .ac-th{background:var(--gold-lt);color:var(--gold)}
.th-hard .ac-th{background:var(--terra-lt);color:var(--terra)}
.th-vhrd .ac-th{background:var(--purple-lt);color:var(--purple)}

/* Trust */
.trust{display:flex;flex-wrap:wrap;gap:var(--s3)}
.trust-item{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:rgba(240,234,224,.25);
  display:flex;align-items:center;gap:.35rem;
}
.trust-dot{width:4px;height:4px;border-radius:50%;background:var(--cobalt)}

/* ── RÉSULTAT TUNNEL ────────────────────────────────────── */
.result{
  display:none;background:var(--ink);
  border-top:1px solid rgba(240,234,224,.08);
}
.result.show{display:block}

.result-top{
  max-width:var(--max);margin:0 auto;
  padding:var(--s6) var(--pad) var(--s4);
  display:grid;grid-template-columns:1fr auto;
  gap:var(--s5);align-items:end;
  border-bottom:1px solid rgba(240,234,224,.07);
}
.result-city{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:rgba(240,234,224,.28);margin-bottom:.5rem;
}
.result-cost{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(3.5rem,11vw,6.5rem);
  line-height:.88;letter-spacing:-.04em;
  color:#FF6B52;display:block;margin-bottom:.4rem;
}
.result-sentence{
  font-size:clamp(.875rem,1.8vw,1rem);
  font-weight:500;color:rgba(240,234,224,.65);
  line-height:1.55;max-width:44ch;
}
.result-th-side{text-align:right;flex-shrink:0}
.result-th-num{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(2rem,5vw,3.25rem);
  line-height:.88;letter-spacing:-.035em;display:block;margin-bottom:.35rem;
}
.result-th-lbl{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:rgba(240,234,224,.3);
}

.result-bar{
  max-width:var(--max);margin:0 auto;
  padding:var(--s3) var(--pad);
  border-bottom:1px solid rgba(240,234,224,.06);
}
.bar-labels{display:flex;justify-content:space-between;margin-bottom:.5rem}
.bar-lbl{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;color:rgba(240,234,224,.25);
}
.bar-track{height:3px;background:rgba(240,234,224,.1);border-radius:100px;overflow:hidden}
.bar-fill{height:100%;border-radius:100px;transition:transform .7s cubic-bezier(.4,0,.2,1);transform-origin:left}

.result-impacts{
  max-width:var(--max);margin:0 auto;
  padding:var(--s4) var(--pad);
  border-bottom:1px solid rgba(240,234,224,.06);
}
.impacts-lbl{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:rgba(240,234,224,.28);margin-bottom:var(--s3);
}
.impacts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.impact-item{
  border:1px solid rgba(240,234,224,.08);border-radius:var(--r);
  background:rgba(240,234,224,.03);padding:var(--s2) var(--s3);
}
.impact-app{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  color:rgba(240,234,224,.35);margin-bottom:.35rem;
}
.impact-val{font-family:var(--f-head);font-weight:800;font-size:.9375rem;line-height:1.2}

.result-cta{
  max-width:var(--max);margin:0 auto;
  padding:var(--s3) var(--pad) var(--s5);
  display:flex;gap:var(--s2);flex-wrap:wrap;
}

/* ── STATS SECTION ──────────────────────────────────────── */
.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:var(--rule-hvy);
}
.stat-col{padding:var(--s4) var(--s4) var(--s4) 0;border-right:var(--rule)}
.stat-col:last-child{border-right:none;padding-right:0}
.stat-col:not(:first-child){padding-left:var(--s4)}
.stat-num{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(2rem,4.5vw,3rem);
  line-height:.9;letter-spacing:-.04em;display:block;margin-bottom:.45rem;
}
.stat-lbl{
  font-family:var(--f-mono);font-size:.6875rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);line-height:1.55;
}

/* ── KPI VILLES ─────────────────────────────────────────── */
.kpi-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:var(--rule-hvy);border-bottom:var(--rule);
  margin:var(--s5) 0;
}
.kpi-col{padding:var(--s4) var(--s4) var(--s4) 0;border-right:var(--rule)}
.kpi-col:last-child{border-right:none;padding-right:0}
.kpi-col:not(:first-child){padding-left:var(--s4)}
.kpi-num{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(1.5rem,3.5vw,2.25rem);
  line-height:.92;letter-spacing:-.035em;display:block;margin-bottom:.4rem;
}
.kpi-lbl{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);line-height:1.5;
}

/* ── ÉTAPES ─────────────────────────────────────────────── */
.steps{display:flex;flex-direction:column}
.step{display:flex;gap:var(--s3);padding:var(--s3) 0;border-bottom:var(--rule)}
.step:last-child{border-bottom:none}
.step-num{
  width:34px;height:34px;border-radius:50%;
  background:var(--cobalt);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-head);font-weight:800;font-size:.8125rem;
  flex-shrink:0;margin-top:2px;
}
.step-title{font-family:var(--f-head);font-weight:700;font-size:.9375rem;color:var(--ink);margin-bottom:.25rem}
.step-desc{font-size:.875rem;color:var(--ink-2);line-height:1.6}

/* ── LISTE VILLES ÉDITORIALE ────────────────────────────── */
.ville-list{border-top:var(--rule-hvy)}
.ville-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:.875rem 0;border-bottom:var(--rule);cursor:pointer;
  transition:background .1s;
}
.ville-row:hover{background:rgba(0,71,204,.04)}
.ville-nom{font-family:var(--f-head);font-weight:700;font-size:.9375rem;color:var(--ink);transition:color .15s}
.ville-row:hover .ville-nom{color:var(--cobalt)}
.ville-data{font-family:var(--f-head);font-weight:800;font-size:.9375rem}
.ville-all{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:var(--s4);font-family:var(--f-head);font-weight:700;
  font-size:.875rem;color:var(--ink);cursor:pointer;
  border-bottom:1.5px solid var(--ink);padding-bottom:2px;
  transition:color .15s,border-color .15s;
}
.ville-all:hover{color:var(--cobalt);border-color:var(--cobalt);text-decoration:none}

/* ── PROBLEM CARD ────────────────────────────────────────── */
.prob-card{
  border:var(--rule);border-radius:var(--r);
  background:var(--parch);overflow:hidden;cursor:pointer;
  transition:border-color .15s,box-shadow .15s,transform .15s;
  display:flex;flex-direction:column;
}
.prob-card:hover{border-color:var(--cobalt);box-shadow:0 6px 24px rgba(26,17,8,.1);transform:translateY(-2px)}
.prob-head{display:flex;align-items:center;justify-content:space-between;padding:var(--s3);border-bottom:var(--rule)}
.prob-icon{font-size:1.625rem}
.prob-badge{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  padding:.2rem .55rem;border-radius:100px;
}
.prob-body{flex:1;padding:var(--s3)}
.prob-title{font-family:var(--f-head);font-weight:700;font-size:.9375rem;color:var(--ink);margin-bottom:.4rem;line-height:1.3}
.prob-card:hover .prob-title{color:var(--cobalt)}
.prob-desc{font-size:.8125rem;color:var(--ink-2);line-height:1.6}
.prob-foot{padding:.7rem var(--s3);border-top:var(--rule);font-family:var(--f-mono);font-size:.625rem;font-weight:700;color:var(--cobalt);text-transform:uppercase;letter-spacing:.06em}

/* ── ARTICLE CARD ────────────────────────────────────────── */
.article-card{
  border:var(--rule);border-radius:var(--r);
  background:var(--parch);cursor:pointer;
  transition:border-color .15s,box-shadow .15s;
  display:flex;flex-direction:column;text-decoration:none;color:inherit;
}
.article-card:hover{border-color:var(--cobalt);box-shadow:0 4px 20px rgba(26,17,8,.08);text-decoration:none}
.article-card-img{
  background:var(--ink);padding:var(--s5);
  display:flex;align-items:center;justify-content:center;
  font-size:2.25rem;min-height:80px;border-bottom:var(--rule);
}
.article-card-body{flex:1;display:flex;flex-direction:column;padding:var(--s3);gap:var(--s1)}
.article-card-title{font-family:var(--f-head);font-weight:700;font-size:.9375rem;line-height:1.35;flex:1;color:var(--ink)}
.article-card:hover .article-card-title{color:var(--cobalt)}
.article-card-foot{display:flex;justify-content:space-between;margin-top:auto;padding-top:var(--s2);border-top:var(--rule)}
.article-card-read{font-family:var(--f-mono);font-size:.625rem;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em}
.article-card-link{font-family:var(--f-mono);font-size:.625rem;font-weight:700;color:var(--cobalt)}

/* ── HERO PAGE INTERNE ───────────────────────────────────── */
.hero-page{
  background:var(--ink);
  padding:calc(var(--hdr) + var(--s6)) var(--pad) var(--s6);
  padding-left:max(var(--pad),env(safe-area-inset-left));
  padding-right:max(var(--pad),env(safe-area-inset-right));
  border-bottom:1px solid rgba(240,234,224,.1);
}
.hero-page .h1,.hero-page .h2{color:var(--parch)}
.hero-page .lead{color:rgba(240,234,224,.6)}

/* Héro page ville */
.hero-ville{
  background:var(--ink);
  padding:calc(var(--hdr) + var(--s5)) var(--pad) var(--s5);
  border-bottom:1px solid rgba(240,234,224,.1);
}
.hero-ville-inner{max-width:var(--max);margin:0 auto}
.hero-ville-grid{
  display:grid;grid-template-columns:1fr auto;
  gap:var(--s5);align-items:end;padding-top:var(--s3);
}
.ville-badge-row{display:flex;align-items:center;gap:var(--s2);margin-bottom:var(--s3)}
.ville-badge-pill{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  padding:.25rem .65rem;border-radius:100px;
}
.ville-dept-tag{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(240,234,224,.28)}
.hero-ville .h1{color:var(--parch);margin-bottom:var(--s2)}
.hero-ville .lead{color:rgba(240,234,224,.6)}
.ville-th-block{text-align:right;flex-shrink:0;padding-bottom:.2rem}
.ville-th-num{
  font-family:var(--f-head);font-weight:800;
  font-size:clamp(2.5rem,7vw,4.5rem);
  line-height:.88;letter-spacing:-.04em;display:block;margin-bottom:.35rem;
}
.ville-th-lbl{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(240,234,224,.3)}

/* ── ALERTES ────────────────────────────────────────────── */
.alert{
  border-radius:var(--r);padding:var(--s3) var(--s4);
  border:1.5px solid;border-left-width:4px;
  font-family:var(--f-head);font-weight:700;font-size:.9375rem;
  line-height:1.4;
}
.alert-hard{color:var(--terra);border-color:var(--terra);background:var(--terra-lt)}
.alert-mod{color:var(--gold);border-color:var(--gold);background:var(--gold-lt)}
.alert-soft{color:var(--green);border-color:var(--green);background:var(--green-lt)}
.alert-vhard{color:var(--purple);border-color:var(--purple);background:var(--purple-lt)}

/* ── BREADCRUMB ─────────────────────────────────────────── */
.bc{
  display:flex;align-items:center;flex-wrap:wrap;gap:.3rem;
  margin-bottom:var(--s3);font-family:var(--f-mono);
  font-size:.625rem;color:rgba(240,234,224,.28);
  text-transform:uppercase;letter-spacing:.08em;
}
.bc a{color:inherit;transition:color .15s}
.bc a:hover{color:rgba(240,234,224,.65);text-decoration:none}
.bc-sep{opacity:.35}

/* ── WQS SIDEBAR ─────────────────────────────────────────── */
.wqs-card{border:var(--rule);border-radius:var(--r);padding:var(--s4);background:var(--parch-dk)}
.wqs-title{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-3);margin-bottom:var(--s3)}
.wqs-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:var(--rule)}
.wqs-row:last-of-type{border-bottom:none}
.wqs-param{font-size:.875rem;color:var(--ink-2);font-weight:500}
.wqs-val{font-family:var(--f-mono);font-size:.8125rem;font-weight:700}
.wqs-mini-bar{height:3px;background:var(--parch-dkk);border-radius:100px;margin-top:.25rem;overflow:hidden}
.wqs-mini-fill{height:100%;border-radius:100px}
.wqs-total{margin-top:var(--s3);padding-top:var(--s3);border-top:var(--rule);display:flex;align-items:center;justify-content:space-between}
.wqs-total-lbl{font-family:var(--f-mono);font-size:.625rem;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em}
.wqs-total-num{font-family:var(--f-head);font-weight:800;font-size:1.5rem;letter-spacing:-.03em;color:var(--cobalt)}

/* ── VILLES VOISINES ─────────────────────────────────────── */
.ctx-card{
  border:var(--rule);border-radius:var(--r);padding:var(--s3);
  background:var(--parch);display:flex;flex-direction:column;gap:.4rem;
  cursor:pointer;transition:border-color .15s;text-decoration:none;color:inherit;
}
.ctx-card:hover{border-color:var(--cobalt);text-decoration:none}
.ctx-nom{font-family:var(--f-head);font-weight:700;font-size:.9375rem;color:var(--ink)}
.ctx-card:hover .ctx-nom{color:var(--cobalt)}
.ctx-val{font-family:var(--f-mono);font-size:.75rem;font-weight:700}
.ctx-dept{font-family:var(--f-mono);font-size:.625rem;color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em}

/* ── SOLUTION CARD ───────────────────────────────────────── */
.sol-card{
  border:var(--rule);border-left:4px solid var(--sol-col,var(--cobalt));
  border-radius:0 var(--r) var(--r) 0;padding:var(--s4);
  background:var(--parch);margin-bottom:var(--s3);
  transition:box-shadow .15s;
}
.sol-card:hover{box-shadow:0 4px 20px rgba(26,17,8,.07)}
.sol-name{font-family:var(--f-head);font-weight:700;font-size:1.0625rem;color:var(--ink);margin-bottom:.35rem}
.sol-desc{font-size:var(--t-sm);color:var(--ink-2);margin-bottom:var(--s3);line-height:1.6}
.sol-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:var(--s2)}
.sol-col-lbl{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.sol-col-lbl--pro{color:var(--green)}
.sol-col-lbl--con{color:var(--terra)}
.sol-point{font-size:var(--t-sm);color:var(--ink-2);padding:.08rem 0;line-height:1.55}

/* ── SOLUTION CARD DARK (tunnel) ─────────────────────────── */
.sol-dark{
  border:1px solid rgba(240,234,224,.1);
  border-left:4px solid var(--sol-col,var(--cobalt));
  border-radius:0 var(--r) var(--r) 0;
  background:rgba(240,234,224,.03);
  padding:var(--s3) var(--s4);margin-bottom:var(--s2);
}
.sol-dark-name{font-family:var(--f-head);font-weight:700;font-size:.9375rem;color:var(--parch);margin-bottom:.3rem}
.sol-dark-desc{font-size:.875rem;color:rgba(240,234,224,.5);margin-bottom:var(--s2);line-height:1.55}
.sol-dark-link{font-family:var(--f-mono);font-size:.625rem;font-weight:700;color:var(--cobalt);text-transform:uppercase;letter-spacing:.06em}

/* ── CALLOUT ─────────────────────────────────────────────── */
.callout{
  background:var(--cobalt-lt);border:1.5px solid var(--cobalt-lt);
  border-left:4px solid var(--cobalt);border-radius:0 var(--r) var(--r) 0;
  padding:var(--s3) var(--s4);margin:var(--s4) 0;
}
.callout--orange{background:var(--gold-lt);border-color:var(--gold-lt);border-left-color:var(--gold)}
.callout--green{background:var(--green-lt);border-color:var(--green-lt);border-left-color:var(--green)}
.callout--red{background:var(--terra-lt);border-color:var(--terra-lt);border-left-color:var(--terra)}
.callout-title{font-family:var(--f-head);font-weight:700;margin-bottom:.4rem;color:var(--ink)}
.callout p{font-size:var(--t-sm);color:var(--ink-2);line-height:1.6;max-width:none;margin:0}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq details{padding:var(--s3) 0;border-bottom:var(--rule)}
.faq details:first-child{border-top:var(--rule)}
.faq summary{font-family:var(--f-head);font-weight:700;font-size:1rem;color:var(--ink);padding-right:2.5rem;position:relative;user-select:none}
.faq summary::after{content:'+';position:absolute;right:0;color:var(--cobalt);font-size:1.25rem;font-weight:400;transition:transform .2s}
.faq details[open] summary::after{content:'−'}
.faq .answer{font-size:var(--t-body);color:var(--ink-2);line-height:1.65;margin-top:var(--s2);padding-right:2.5rem}

/* ── TABLE ───────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
.tbl{width:100%;border-collapse:collapse;min-width:480px;font-size:var(--t-sm)}
.tbl th{
  border-bottom:var(--rule-hvy);text-align:left;padding:.875rem .75rem;
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);
  cursor:pointer;user-select:none;white-space:nowrap;
}
.tbl th:hover{color:var(--ink)}
.tbl th.sort-asc::after{content:' ↑';color:var(--cobalt)}
.tbl th.sort-desc::after{content:' ↓';color:var(--cobalt)}
.tbl td{padding:.75rem;border-bottom:var(--rule);color:var(--ink-2);vertical-align:middle}
.tbl tr:hover td{background:var(--parch-dk)}
.city-name{font-weight:600;color:var(--ink)}
.city-name a{color:inherit}
.city-name a:hover{color:var(--cobalt);text-decoration:none}
.city-dept{font-family:var(--f-mono);font-size:.625rem;color:var(--ink-4);background:var(--parch-dk);padding:.15rem .4rem;border-radius:var(--r-sm)}
.th-val{font-family:var(--f-head);font-weight:800;font-size:1.0625rem}
.cost-val{font-family:var(--f-mono);font-weight:700}

/* ── BADGES & TAGS ───────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  padding:.25rem .625rem;border-radius:100px;
}
.badge--green{color:var(--green);background:var(--green-lt)}
.badge--orange{color:var(--gold);background:var(--gold-lt)}
.badge--red{color:var(--terra);background:var(--terra-lt)}
.badge--purple{color:var(--purple);background:var(--purple-lt)}
.badge--cobalt{color:var(--cobalt);background:var(--cobalt-lt)}
.badge--ink{color:var(--parch);background:var(--ink)}
.badge--neutral{color:var(--ink-3);background:var(--parch-dk)}
.tag{display:inline-block;padding:.18rem .55rem;border-radius:100px;font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:var(--rule)}
.tag--cobalt{background:var(--cobalt-lt);color:var(--cobalt);border-color:var(--cobalt-lt)}
.tag--green{background:var(--green-lt);color:var(--green);border-color:var(--green-lt)}
.tag--orange{background:var(--gold-lt);color:var(--gold);border-color:var(--gold-lt)}
.tag--gray{background:var(--parch-dk);color:var(--ink-3);border-color:var(--parch-dkk)}

/* ── BOUTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--f-head);font-weight:700;font-size:.9375rem;
  padding:.7rem 1.5rem;border-radius:var(--r-sm);border:none;cursor:pointer;
  text-decoration:none;white-space:nowrap;line-height:1;
  min-height:44px;touch-action:manipulation;letter-spacing:-.01em;
  transition:background var(--ease),transform var(--ease),border-color var(--ease),color var(--ease);
}
.btn:hover{text-decoration:none}
.btn--primary{background:var(--cobalt);color:#fff}
.btn--primary:hover{background:var(--cobalt-dk);color:#fff;transform:translateY(-1px)}
.btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn--outline:hover{background:var(--ink);color:var(--parch)}
.btn--outline-light{background:transparent;color:rgba(240,234,224,.75);border:1px solid rgba(240,234,224,.3)}
.btn--outline-light:hover{background:rgba(240,234,224,.08);color:var(--parch);border-color:rgba(240,234,224,.6)}
.btn--ghost-ink{background:rgba(240,234,224,.07);color:rgba(240,234,224,.65)}
.btn--ghost-ink:hover{background:rgba(240,234,224,.13);color:var(--parch)}
.btn--full{width:100%;justify-content:center}
.btn--sm{font-size:.8125rem;padding:.55rem 1.125rem}
.btn--lg{font-size:1.0625rem;padding:1rem 2rem}
.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}

/* ── FILTER BAR ──────────────────────────────────────────── */
.filter-bar{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-bottom:var(--s4)}
.filter-lbl{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);margin-right:.5rem;white-space:nowrap}
.filter-btn{
  padding:.4rem .875rem;min-height:44px;border:var(--rule);border-radius:100px;
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--ink-2);
  background:var(--parch);cursor:pointer;
  transition:background var(--ease),border-color var(--ease),color var(--ease);
  white-space:nowrap;touch-action:manipulation;
}
.filter-btn:hover{border-color:var(--cobalt);color:var(--cobalt)}
.filter-btn.active{background:var(--ink);border-color:var(--ink);color:var(--parch)}

/* ── ALPHA NAV ───────────────────────────────────────────── */
.alpha-nav{display:flex;flex-wrap:wrap;gap:.25rem}
.alpha-btn{
  padding:.25rem .5rem;min-width:36px;min-height:44px;text-align:center;
  border:var(--rule);border-radius:var(--r-sm);
  font-family:var(--f-mono);font-size:.6875rem;font-weight:700;
  color:var(--ink-2);background:var(--parch);cursor:pointer;
  transition:background .12s;
  display:flex;align-items:center;justify-content:center;touch-action:manipulation;
}
.alpha-btn.active{background:var(--ink);color:var(--parch);border-color:var(--ink)}
.alpha-btn.disabled{opacity:.3;pointer-events:none}
.alpha-btn:not(.disabled):not(.active):hover{background:var(--parch-dk)}

/* ── WIZARD ──────────────────────────────────────────────── */
.step-opt{
  padding:.875rem .75rem;background:var(--parch);border:var(--rule);
  border-radius:var(--r);font-family:var(--f-head);font-weight:700;
  font-size:.875rem;color:var(--ink-2);cursor:pointer;text-align:center;
  transition:border-color var(--ease),background var(--ease),color var(--ease);
  min-height:44px;touch-action:manipulation;display:flex;align-items:center;justify-content:center;
}
.step-opt:hover{border-color:var(--cobalt);color:var(--cobalt);background:var(--cobalt-lt)}
.step-opt.sel{background:var(--ink);border-color:var(--ink);color:var(--parch)}
.step-opts{display:grid;gap:.5rem}
.step-opts--3{grid-template-columns:repeat(3,1fr)}
.step-opts--4{grid-template-columns:repeat(4,1fr)}
.step-block{display:none;padding:var(--s3) var(--pad);border-top:1px solid rgba(240,234,224,.07)}
.step-block.active{display:block}
.step-lbl{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(240,234,224,.28);margin-bottom:var(--s2)}
.result-final{display:none;padding:var(--s3) var(--pad);border-top:1px solid rgba(240,234,224,.07)}
.result-cta-btns{display:flex;gap:var(--s2);flex-wrap:wrap;margin-top:var(--s3)}

/* ── CTA BAND ────────────────────────────────────────────── */
.cta-band{background:var(--ink);padding:var(--s10) var(--pad);border-top:3px solid var(--cobalt)}
.cta-band .h2{color:var(--parch);margin-bottom:var(--s3)}
.cta-band .lead{color:rgba(240,234,224,.55);margin-bottom:var(--s5);max-width:52ch;font-size:.9375rem}
.cta-btns{display:flex;gap:var(--s2);flex-wrap:wrap}

/* ── FOOTER ──────────────────────────────────────────────── */
.ftr{background:var(--ink);border-top:1px solid rgba(240,234,224,.07)}
.ftr-inner{
  max-width:var(--max);margin:0 auto;
  padding:var(--s10) var(--pad) calc(var(--s6) + env(safe-area-inset-bottom));
}
.ftr-logo{font-family:var(--f-head);font-weight:800;font-size:1.0625rem;letter-spacing:-.02em;margin-bottom:var(--s8);display:flex;align-items:baseline;gap:.05em}
.ftr-logo .dk{color:#002395}
.ftr-logo .al{color:#FFFFFF}
.ftr-logo .med{color:#ED2939}
.ftr-tagline{font-family:var(--f-mono);font-size:.625rem;color:rgba(240,234,224,.22);margin-bottom:var(--s6);margin-top:calc(-1 * var(--s6) + var(--s2))}
.ftr-cols{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:var(--s4);margin-bottom:var(--s5)}
.ftr-col-title{font-family:var(--f-mono);font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(240,234,224,.25);margin-bottom:var(--s2)}
.ftr-col a{display:flex;align-items:center;font-size:.8125rem;color:rgba(240,234,224,.42);padding:.18rem 0;min-height:44px;transition:color var(--ease);touch-action:manipulation}
.ftr-col a:hover{color:var(--parch);text-decoration:none}
.ftr-bottom{border-top:1px solid rgba(240,234,224,.07);padding-top:var(--s3);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s2)}
.ftr-copy{font-family:var(--f-mono);font-size:.625rem;color:rgba(240,234,224,.25)}
.ftr-legal{display:flex;gap:var(--s3)}
.ftr-legal a{font-family:var(--f-mono);font-size:.625rem;color:rgba(240,234,224,.25);transition:color var(--ease)}
.ftr-legal a:hover{color:rgba(240,234,224,.6)}

/* ── COOKIE NOTICE ───────────────────────────────────────── */
#cookie-notice{
  display:none;position:fixed;bottom:0;left:0;right:0;
  background:rgba(26,17,8,.97);border-top:1px solid rgba(240,234,224,.1);
  padding:1rem var(--pad);align-items:center;gap:var(--s3);
  flex-wrap:wrap;z-index:9998;
  padding-bottom:max(1rem,env(safe-area-inset-bottom));
}
.show-cookie #cookie-notice{display:flex!important}

/* ── STICKY CTA MOBILE ───────────────────────────────────── */
.sticky-mob-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:900;
  transform:translateY(100%);will-change:transform;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  padding:.875rem var(--pad);
  padding-bottom:max(.875rem,env(safe-area-inset-bottom));
  background:var(--ink);border-top:1px solid rgba(240,234,224,.1);
}
.sticky-mob-cta.visible{transform:translateY(0)}

/* ── BACK TO TOP ─────────────────────────────────────────── */
.back-top{
  position:fixed;bottom:1.5rem;right:1.5rem;
  width:44px;height:44px;background:var(--parch-dk);color:var(--ink);
  border:var(--rule);border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:1.125rem;
  opacity:0;transform:translateY(10px);
  transition:opacity .2s,transform .2s;pointer-events:none;z-index:90;touch-action:manipulation;
}
.back-top.visible{opacity:1;transform:none;pointer-events:auto}
.back-top:hover{background:var(--cobalt);border-color:var(--cobalt);color:#fff}

/* ── UTILITAIRES ─────────────────────────────────────────── */
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.hidden{display:none!important}
.init-hidden{display:none}
.w-full{width:100%}
.text-center{text-align:center}
.mt-sm{margin-top:var(--s2)}
.mt-md{margin-top:var(--s3)}
.mt-lg{margin-top:var(--s5)}
.mt-xl{margin-top:var(--s8)}
.mb-sm{margin-bottom:var(--s2)}
.mb-md{margin-bottom:var(--s3)}
.mb-lg{margin-bottom:var(--s5)}
.gap-sm{gap:var(--s2)}
.gap-md{gap:var(--s3)}
.fw-bold{font-weight:700}
.pre-code{font-family:var(--f-mono);font-size:.8125rem;color:var(--cobalt);white-space:pre-wrap;word-break:break-all}
.badge-row{display:flex;flex-wrap:wrap;gap:.35rem}
.border-top{border-top:var(--rule)}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--s5);padding-bottom:var(--s3);border-bottom:var(--rule-hvy)}
.section-all{font-family:var(--f-mono);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--cobalt);cursor:pointer}
.section-all:hover{text-decoration:underline}

/* Source link */
.source-link{font-family:var(--f-mono);font-size:.75rem;color:var(--cobalt);font-weight:700}
.source-link:hover{text-decoration:underline}

/* timeline */
.timeline{position:relative;padding-left:var(--s5)}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--cobalt),var(--parch-dkk))}
.timeline-item{position:relative;padding-bottom:var(--s5)}
.timeline-item::before{content:'';position:absolute;left:calc(-1 * var(--s5) - 4px);top:4px;width:9px;height:9px;border-radius:50%;background:var(--cobalt);border:2px solid var(--parch);box-shadow:0 0 0 2px var(--cobalt)}
.timeline-date{font-family:var(--f-mono);font-size:.625rem;font-weight:700;color:var(--cobalt);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
.timeline-title{font-family:var(--f-head);font-weight:700;font-size:var(--t-md);color:var(--ink);margin-bottom:.35rem}
.timeline-body{font-size:var(--t-sm);color:var(--ink-2);line-height:1.6}

/* ── PRINT ───────────────────────────────────────────────── */
@media print{
  .hdr,.ftr,.mob-drawer,.mob-toggle,.sticky-mob-cta,.back-top{display:none!important}
  body{background:#fff;color:#000}
  a{color:#000}
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .split-63,.split-36{grid-template-columns:1fr;gap:var(--s5)}
}
@media(max-width:768px){
  :root{--hdr:58px}
  .hdr-nav,.hdr-cta{display:none}
  .mob-toggle{display:flex}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .stats-row .stat-col:nth-child(3){grid-column:1/-1;border-right:none;border-top:var(--rule);padding-top:var(--s3)}
  .kpi-row{grid-template-columns:1fr 1fr}
  .kpi-col:nth-child(3){grid-column:1/-1;border-right:none;border-top:var(--rule);padding-top:var(--s3)}
  .kpi-col:nth-child(2){border-right:none}
  .hero-ville-grid{grid-template-columns:1fr}
  .result-top{grid-template-columns:1fr}
  .impacts-grid{grid-template-columns:repeat(2,1fr)}
  .sol-pros-cons{grid-template-columns:1fr}
  .ftr-cols{grid-template-columns:1fr 1fr;gap:var(--s4)}
  .section{padding:var(--s8) var(--pad)}
  .sticky-mob-cta{display:block}
  p{max-width:100%}
  .step-opts--4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .kpi-row{grid-template-columns:1fr}
  .kpi-col{border-right:none;border-bottom:var(--rule)}
  .kpi-col:last-child{border-bottom:none}
  .stats-row{grid-template-columns:1fr}
  .stats-row .stat-col{border-right:none;border-bottom:var(--rule)}
  .ftr-cols{grid-template-columns:1fr}
  .impacts-grid{grid-template-columns:repeat(2,1fr)}
  .step-opts--3{grid-template-columns:1fr}
}

/* ── FOCUS ───────────────────────────────────────────────── */
:focus-visible{outline:2px solid var(--cobalt);outline-offset:3px;border-radius:var(--r-sm)}
.search-input:focus:not(:focus-visible),
.input:focus:not(:focus-visible){outline:none}

/* ── REDUCED MOTION ──────────────────────────────────────── */
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ── SYMPTÔME CHIPS (tunnel) ─────────────────────────────────── */
.tc-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:var(--s2)}
.tc-chip{
  padding:.4rem .875rem;min-height:44px;
  border:1px solid rgba(240,234,224,.15);border-radius:100px;
  font-size:.8125rem;font-weight:500;color:rgba(240,234,224,.6);
  background:rgba(240,234,224,.05);cursor:pointer;
  transition:border-color .15s,background .15s,color .15s;
  display:inline-flex;align-items:center;touch-action:manipulation;
}
.tc-chip:hover{border-color:rgba(240,234,224,.3);color:rgba(240,234,224,.85)}
.tc-chip.sel{background:rgba(198,48,32,.15);border-color:var(--terra);color:var(--parch)}

/* ── IMPACT ITEM (tunnel) ────────────────────────────────────── */
.impact-item{
  border:1px solid rgba(240,234,224,.08);border-radius:var(--r);
  background:rgba(240,234,224,.03);padding:var(--s2) var(--s3);
}
.impact-app{
  font-family:var(--f-mono);font-size:.625rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  color:rgba(240,234,224,.35);margin-bottom:.35rem;
}
.impact-val{font-family:var(--f-head);font-weight:800;font-size:.9375rem;line-height:1.2}
