/* =====================================================================
   PAGE VILLE — composants additionnels
   Charge ce fichier APRÈS brand.css
   ===================================================================== */

/* Garde anti-débordement horizontal (mobile) */
html { overflow-x: hidden; }
body { overflow-x: hidden; max-width: 100%; }
img { max-width: 100%; height: auto; }

/* Container réutilisé */
.container { max-width: 1240px; margin: 0 auto; padding: 0 var(--page-gutter); width: 100%; }

/* ── Live bar ───────────────────────────────────────────────── */
.live-bar {
  background: var(--alber-navy-900);
  color: #fff;
  font-size: 13px;
  padding: 8px var(--page-gutter);
  display: flex; align-items: center; justify-content: center;
  gap: var(--space-6); flex-wrap: wrap;
  font-family: var(--font-mono); letter-spacing: .04em;
}
.live-bar .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #16A34A;
  box-shadow: 0 0 0 0 rgba(22,163,74,.7);
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%   { box-shadow: 0 0 0 0 rgba(22,163,74,.7); }
  70%  { box-shadow: 0 0 0 8px rgba(22,163,74,0); }
}
.live-bar strong { color: var(--alber-orange-300); }

/* ── Sticky header ─────────────────────────────────────────── */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-1);
  padding: 0 var(--page-gutter);
}
.site-header__inner {
  position: relative;
  max-width: 1240px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 72px; gap: var(--space-6);
}
.site-logo {
  display: flex; align-items: center; gap: 10px;
  color: var(--alber-navy-800); text-decoration: none;
  font-family: var(--font-display); font-weight: 700; font-size: 22px;
  letter-spacing: -0.02em;
}
.site-nav { display: flex; gap: var(--space-6); font-family: var(--font-display); font-weight: 500; font-size: 15px; color: var(--alber-navy-800); }
.site-nav a { text-decoration: none; color: inherit; }
.site-nav a:hover { color: var(--alber-orange-500); }
.header-cta { align-items: center; }
.nav-burger {
  display: none; align-items: center; justify-content: center;
  width: 42px; height: 42px; border-radius: var(--radius-2);
  border: 1px solid var(--border-1); background: #fff;
  color: var(--alber-navy-800); cursor: pointer;
}
.nav-burger .msr { font-size: 24px; }

@media (max-width: 920px) {
  .site-nav {
    position: absolute; top: calc(100% + 1px); left: 0; right: 0;
    flex-direction: column; gap: 0;
    background: #fff; border-bottom: 1px solid var(--border-1);
    box-shadow: var(--shadow-3);
    padding: var(--space-2) var(--page-gutter) var(--space-4);
    display: none;
  }
  .nav-toggle:checked ~ .site-nav { display: flex; }
  .site-nav a { padding: var(--space-3) 2px; border-bottom: 1px solid var(--border-1); font-size: 16px; }
  .site-nav a:last-child { border-bottom: 0; }
  .nav-burger { display: inline-flex; }
}

/* ── Hero ──────────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: var(--space-16) 0 var(--space-12);
  background: linear-gradient(180deg, var(--alber-cream) 0%, #fff 100%);
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(800px 400px at 90% 10%, rgba(255,107,44,.10), transparent 60%),
    radial-gradient(600px 400px at 10% 90%, rgba(0,184,217,.08), transparent 60%);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-12);
  align-items: center;
}
.hero__inner > * { min-width: 0; }   /* empêche les enfants (H1, texte) de déborder la piste grid */
@media (max-width: 900px) { .hero__inner { grid-template-columns: minmax(0, 1fr); } }
.hero h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(28px, 5vw, 50px);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: var(--alber-navy-800);
  margin: var(--space-4) 0;
  text-wrap: balance;
  overflow-wrap: break-word;
}
.hero h1 em { color: var(--alber-orange-500); font-style: italic; }
.hero__h1-sub {
  display: block;
  margin-top: var(--space-2);
  font-size: 0.52em;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--alber-orange-500);
}
.hero__sub {
  font-size: var(--text-xl);
  color: var(--fg-2);
  line-height: var(--lh-loose);
  max-width: 50ch;
  margin: 0 0 var(--space-8);
}
.hero__avis { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-6) 0 0; }
.hero__avis-avatars { display: flex; }
.hero__avis-avatars > * {
  width: 36px; height: 36px;
  border-radius: 50%; border: 2px solid #fff;
  margin-left: -10px; background: var(--alber-navy-100);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700;
  font-size: 12px; color: var(--alber-navy-800);
}
.hero__avis-avatars > *:first-child { margin-left: 0; }
.hero__avis-stars { color: var(--alber-orange-500); font-size: 14px; letter-spacing: 1px; }
.hero__avis-text { font-size: 13px; color: var(--fg-2); }
.hero__avis-text strong { color: var(--fg-deep); }

.hero__mascot-wrap { position: relative; display: grid; place-items: center; }
.hero__mascot-wrap::before {
  content: ""; position: absolute; inset: -40px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,107,44,.18), transparent 70%);
}
.hero__mascot {
  position: relative;
  max-height: 560px; width: auto;
  filter: drop-shadow(0 30px 40px rgba(10,31,68,.18));
}
.hero__chip {
  position: absolute; background: #fff;
  padding: 10px 14px; border-radius: 14px;
  box-shadow: var(--shadow-3);
  font-size: 13px; color: var(--alber-navy-800);
  font-family: var(--font-display); font-weight: 600;
  display: flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.hero__chip--a { top: 18%; left: -10px; animation: float 6s var(--ease-out) infinite; }
.hero__chip--b { bottom: 26%; right: -10px; background: var(--alber-navy-800); color: #fff; font-family: var(--font-mono); animation: float 6s var(--ease-out) infinite reverse; }
.hero__chip--c { top: 50%; right: -20px; background: var(--alber-aqua-500); color: var(--alber-navy-900); animation: float 5s var(--ease-out) infinite; animation-delay: -2s; }
.hero__chip .msr { color: var(--alber-orange-500); font-size: 18px; }
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

/* Trust strip */
.trust-strip {
  background: var(--alber-navy-800); color: #fff;
  padding: var(--space-5) var(--page-gutter);
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: .1em; text-transform: uppercase;
}
.trust-strip__inner {
  max-width: 1240px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-around;
  gap: var(--space-8); flex-wrap: wrap;
}
.trust-strip .msr { color: var(--alber-orange-400); font-size: 18px; }

/* ── Breadcrumb ─────────────────────────────────────────────── */
.breadcrumb { font-size: 13px; color: var(--fg-3); padding: var(--space-6) 0; }
.breadcrumb ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.breadcrumb li::after { content: "/"; margin-left: 8px; color: var(--gray-300); }
.breadcrumb li:last-child::after { display: none; }
.breadcrumb a { color: var(--fg-2); text-decoration: none; }
.breadcrumb a:hover { color: var(--alber-orange-500); }

/* ── Section frames ─────────────────────────────────────────── */
.section { padding: var(--space-16) 0; position: relative; }
.section--paper { background: #fff; }
.section--cream { background: var(--alber-cream); }
.section--navy { background: var(--alber-navy-800); color: #fff; }
.section--navy h2, .section--navy h3 { color: #fff; }
.section h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(32px, 3.5vw, 52px);
  line-height: 1.05; letter-spacing: -0.03em;
  margin: 0 0 var(--space-4);
  color: var(--alber-navy-800);
  text-wrap: balance;
}
.section h2 em { color: var(--alber-orange-500); font-style: italic; }
.section--navy h2 em { color: var(--alber-orange-400); }
.section h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: var(--display-s); letter-spacing: -0.015em;
  margin: var(--space-8) 0 var(--space-3);
  color: var(--alber-navy-800);
}
.section p { color: var(--fg-2); line-height: var(--lh-loose); }
.section .lede { font-size: var(--text-xl); color: var(--fg-2); max-width: 60ch; margin: 0 0 var(--space-8); }
.eyebrow {
  font-family: var(--font-mono); font-size: 11px;
  font-weight: 600; text-transform: uppercase;
  letter-spacing: .14em; color: var(--alber-orange-500);
  margin: 0 0 var(--space-3);
  display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow::before {
  content: ""; width: 24px; height: 2px;
  background: currentColor; display: inline-block;
}
.section--navy .eyebrow { color: var(--alber-orange-400); }

/* ── PRESTATIONS CAROUSEL ───────────────────────────────────── */
.carousel {
  display: flex;
  gap: var(--space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding-left: var(--page-gutter);
  padding: var(--space-3) var(--page-gutter) var(--space-6);
  margin: 0 calc(-1 * var(--page-gutter));
  scrollbar-width: thin;
  scrollbar-color: var(--alber-orange-300) transparent;
}
.carousel::-webkit-scrollbar { height: 8px; }
.carousel::-webkit-scrollbar-track { background: transparent; }
.carousel::-webkit-scrollbar-thumb { background: var(--alber-orange-300); border-radius: 99px; }

.presta-card {
  flex: 0 0 280px;
  scroll-snap-align: start;
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-4);
  padding: var(--space-6);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform var(--t-base) var(--ease-out), box-shadow var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);
  min-height: 280px;
}
.presta-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-4);
  border-color: var(--alber-orange-300);
}
.presta-card__icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-3);
  display: grid; place-items: center;
  margin-bottom: var(--space-5);
  background: var(--alber-orange-50);
  position: relative;
}
.presta-card__icon .msr { font-size: 30px; color: var(--alber-orange-500); }
.presta-card--aqua .presta-card__icon { background: var(--alber-aqua-50); }
.presta-card--aqua .presta-card__icon .msr { color: var(--alber-aqua-600); }
.presta-card--navy .presta-card__icon { background: var(--alber-navy-50); }
.presta-card--navy .presta-card__icon .msr { color: var(--alber-navy-800); }
.presta-card h3 { margin: 0 0 var(--space-2); font-size: 20px; color: var(--alber-navy-800); font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em; }
.presta-card p { margin: 0 0 var(--space-5); font-size: 14px; color: var(--fg-2); line-height: 1.55; flex: 1; }
.presta-card__cta { display: flex; align-items: center; gap: 6px; font-weight: 600; font-size: 14px; color: var(--alber-orange-500); }
.presta-card__cta .msr { font-size: 18px; transition: transform var(--t-fast) var(--ease-out); }
.presta-card:hover .presta-card__cta .msr { transform: translateX(4px); }
.presta-card__price {
  position: absolute; top: var(--space-5); right: var(--space-5);
  background: var(--alber-navy-50);
  font-family: var(--font-mono); font-size: 11px;
  font-weight: 600; padding: 4px 8px;
  border-radius: var(--radius-pill);
  color: var(--alber-navy-800);
}

.carousel-nav {
  display: flex; align-items: center; gap: var(--space-3);
  margin-top: var(--space-3);
}
.carousel-nav__btn {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1.5px solid var(--alber-navy-200);
  background: #fff; cursor: pointer;
  display: grid; place-items: center;
  color: var(--alber-navy-800);
  transition: all var(--t-fast) var(--ease-out);
}
.carousel-nav__btn:hover { border-color: var(--alber-orange-500); color: var(--alber-orange-500); transform: translateY(-1px); }
.carousel-nav__btn .msr { font-size: 20px; }
.carousel-nav__hint { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); letter-spacing: .04em; }

/* ── SYMPTOMS GRID ──────────────────────────────────────────── */
.symptoms {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.symptom {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-3);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: all var(--t-base) var(--ease-out);
}
.symptom:hover { border-color: var(--alber-orange-500); box-shadow: var(--shadow-2); }
.symptom__num {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--alber-orange-500); font-weight: 600;
  letter-spacing: .08em;
}
.symptom__icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-2);
  background: var(--alber-orange-50);
  display: grid; place-items: center;
}
.symptom__icon .msr { color: var(--alber-orange-500); font-size: 26px; }
.symptom h4 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 16px; margin: 0; color: var(--alber-navy-800);
  line-height: 1.25;
}
.symptom p { font-size: 13px; margin: 0; color: var(--fg-2); }

/* ── PROCESS TIMELINE ───────────────────────────────────────── */
.timeline {
  position: relative;
  display: grid;
  gap: var(--space-6);
}
.timeline-row {
  display: grid;
  grid-template-columns: 80px 1fr 1fr;
  gap: var(--space-6);
  align-items: center;
}
@media (max-width: 800px) {
  .timeline-row { grid-template-columns: 60px 1fr; }
  .timeline-row__visual { grid-column: span 2; order: -1; }
}
.timeline-row__num {
  font-family: var(--font-display); font-weight: 800;
  font-size: 64px; line-height: 1;
  color: var(--alber-orange-500); letter-spacing: -0.04em;
  position: relative;
}
.timeline-row__num::after {
  content: ""; position: absolute; left: 24px; top: 80px;
  width: 2px; height: 80px; background: var(--alber-orange-200);
}
.timeline-row:last-child .timeline-row__num::after { display: none; }
.timeline-row h3 { margin: 0 0 var(--space-2); font-size: 22px; color: var(--alber-navy-800); }
.timeline-row p { margin: 0; font-size: 15px; color: var(--fg-2); }
.timeline-row__visual {
  aspect-ratio: 4/3; border-radius: var(--radius-4); overflow: hidden;
  background: var(--alber-navy-100);
  position: relative;
}
.timeline-row__visual img { width: 100%; height: 100%; object-fit: cover; }
.timeline-row__visual-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(10,31,68,.75));
  display: flex; align-items: flex-end; padding: var(--space-4);
  color: #fff; font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
}
.timeline-row__time {
  position: absolute; top: 12px; right: 12px;
  background: rgba(10,31,68,.8); color: #fff;
  padding: 6px 10px; border-radius: var(--radius-pill);
  font-family: var(--font-mono); font-size: 11px;
  font-weight: 600; backdrop-filter: blur(4px);
}

/* ── EDITORIAL BLOCK (alternating text + image) ─────────────── */
/* Layout éditorial : TEXTE PLEINE LARGEUR, petite image flottée sur le côté
   (le texte l'enroule puis reprend toute la largeur). Desktop + mobile. */
.editorial {
  display: block;
  max-width: 860px;
  margin: 0 auto var(--space-12);
}
.editorial::after { content: ""; display: block; clear: both; }
.editorial > div:last-child { min-width: 0; }
.editorial .editorial__visual { float: right; width: 240px; margin: 4px 0 18px 32px; }
.editorial--reverse .editorial__visual { float: left; margin: 4px 32px 18px 0; }
/* Bloc sans vraie photo (mockup décoratif du bloc « rapport ») → pleine largeur */
.editorial:not(:has(img)) .editorial__visual { display: none; }
.editorial__visual {
  aspect-ratio: 4/3; border-radius: var(--radius-5); overflow: hidden;
  background: var(--alber-navy-100);
  box-shadow: var(--shadow-3);
  position: relative;
}
.editorial__visual img { width: 100%; height: 100%; object-fit: cover; }
.editorial__pull {
  position: absolute; bottom: 16px; left: 16px; right: 16px;
  background: rgba(255,255,255,.96);
  padding: var(--space-4);
  border-radius: var(--radius-3);
  box-shadow: var(--shadow-2);
  display: flex; align-items: center; gap: var(--space-3);
  font-family: var(--font-display);
  backdrop-filter: blur(4px);
}
.editorial__pull strong { display: block; font-size: 18px; color: var(--alber-navy-800); }
.editorial__pull small { font-size: 12px; color: var(--fg-3); }
.editorial__pull .msr { font-size: 28px; color: var(--alber-orange-500); }
.editorial h3 {
  font-size: clamp(26px, 2.8vw, 36px);
  line-height: 1.15; letter-spacing: -0.02em;
  margin: 0 0 var(--space-4); color: var(--alber-navy-800);
  font-family: var(--font-display); font-weight: 700;
  text-wrap: balance;
}
.editorial h3 em { color: var(--alber-orange-500); font-style: italic; }
.editorial p { font-size: 16px; color: var(--fg-2); line-height: 1.7; margin: 0 0 var(--space-3); }

/* ── DATA CALLOUT (inline stat) ──────────────────────────────── */
.data-callout {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-4);
  background: var(--alber-cream);
  border-left: 4px solid var(--alber-orange-500);
  border-radius: var(--radius-3);
  padding: var(--space-6);
  margin: var(--space-6) 0;
}
@media (max-width: 700px) { .data-callout { grid-template-columns: 1fr; } }
.data-callout__num {
  font-family: var(--font-display); font-weight: 700;
  font-size: 36px; line-height: 1;
  color: var(--alber-navy-800);
  letter-spacing: -0.02em;
}
.data-callout__num em { color: var(--alber-orange-500); font-style: normal; }
.data-callout__label { font-size: 13px; color: var(--fg-3); margin-top: 4px; line-height: 1.4; }
.data-callout small {
  display: block;
  font-family: var(--font-mono); font-size: 10px;
  color: var(--alber-aqua-700);
  margin-top: var(--space-3);
  letter-spacing: .04em;
}

/* ── QUARTIERS GRID ─────────────────────────────────────────── */
.quartiers {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4);
}
@media (max-width: 900px) { .quartiers { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .quartiers { grid-template-columns: repeat(2, 1fr); } }
.quartier {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-4);
  overflow: hidden;
  transition: all var(--t-base) var(--ease-out);
}
.quartier:hover { transform: translateY(-2px); box-shadow: var(--shadow-3); }
.quartier__visual {
  height: 140px;
  position: relative;
  overflow: hidden;
}
.quartier__pattern {
  position: absolute; inset: 0;
  display: grid; place-items: center;
}
.quartier__pattern svg { width: 80%; height: 80%; opacity: .7; }
.quartier__visual--p0 { background: linear-gradient(135deg, #FDE8DA, #FFD0B8); }
.quartier__visual--p1 { background: linear-gradient(135deg, #DCE6F4, #B8CCE8); }
.quartier__visual--p2 { background: linear-gradient(135deg, #E8F8FC, #B2EAF5); }
.quartier__visual--p3 { background: linear-gradient(135deg, #FFF4ED, #FFE3D2); }
.quartier__visual--p4 { background: linear-gradient(135deg, #F0F5FB, #DCE6F4); }
.quartier__visual--p5 { background: linear-gradient(135deg, #FEF3C7, #FDE68A); }
.quartier__visual--p6 { background: linear-gradient(135deg, #DCFCE7, #BBF7D0); }
.quartier__visual--p7 { background: linear-gradient(135deg, #FCE7F3, #FBCFE8); }
.quartier__visual--p8 { background: linear-gradient(135deg, #E0E7FF, #C7D2FE); }
.quartier__visual--p9 { background: linear-gradient(135deg, #E8F8FC, #CFFAFE); }
.quartier__body { padding: var(--space-4) var(--space-5); display: flex; align-items: center; min-height: 56px; }
.quartier__title { margin: 0; font-size: 16px; font-family: var(--font-display); font-weight: 700; color: var(--alber-navy-800); line-height: 1.25; }
.quartier:hover .quartier__title { color: var(--alber-orange-600); }

/* ── HABITAT BREAKDOWN (Épinay stats) ───────────────────────── */
.habitat {
  background: #fff;
  border-radius: var(--radius-5);
  padding: var(--space-8);
  border: 1px solid var(--border-1);
}
.habitat__hero {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--space-8);
  align-items: center;
}
@media (max-width: 700px) { .habitat__hero { grid-template-columns: 1fr; } }
.habitat__bars { display: grid; gap: var(--space-3); }
.habitat__bar {
  display: grid; grid-template-columns: 1fr auto;
  gap: var(--space-2);
  align-items: center;
}
.habitat__bar-label { font-size: 14px; font-weight: 500; color: var(--fg-deep); }
.habitat__bar-value { font-family: var(--font-mono); font-size: 13px; color: var(--alber-orange-500); font-weight: 600; }
.habitat__bar-rail {
  grid-column: 1 / -1;
  height: 12px; background: var(--gray-100);
  border-radius: 99px; overflow: hidden;
}
.habitat__bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--alber-navy-800), var(--alber-orange-500));
  border-radius: 99px;
}
.habitat__big {
  text-align: center;
  background: var(--alber-orange-50);
  padding: var(--space-8);
  border-radius: var(--radius-4);
}
.habitat__big-num {
  font-family: var(--font-display);
  font-weight: 800; font-size: 80px;
  line-height: 1; color: var(--alber-orange-500);
  letter-spacing: -0.035em;
}
.habitat__big-label {
  font-family: var(--font-display);
  font-size: 18px; color: var(--alber-navy-800);
  margin-top: var(--space-2);
}
.habitat__sources {
  margin-top: var(--space-6); padding-top: var(--space-4);
  border-top: 1px solid var(--border-1);
  font-family: var(--font-mono); font-size: 11px;
  color: var(--fg-3); letter-spacing: .04em;
}

/* ── QUOTE INTERACTIF ───────────────────────────────────────── */
.quote { background: #fff; border-radius: var(--radius-5); box-shadow: var(--shadow-3); overflow: hidden; border: 1px solid var(--border-1); }
.quote__head { background: var(--alber-navy-800); color: #fff; padding: var(--space-6) var(--space-8); display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.quote__head h3 { color: #fff; margin: 0; font-size: var(--display-s); }
.quote__steps { display: flex; gap: var(--space-3); font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; }
.quote__step-pill { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-pill); padding: 6px 12px; color: rgba(255,255,255,.5); }
.quote__step-pill.is-active { background: var(--alber-orange-500); color: var(--alber-navy-900); border-color: var(--alber-orange-500); }
.quote__step-pill.is-done { background: rgba(22,163,74,.18); color: #6EE7A2; border-color: rgba(22,163,74,.3); }
.quote__body { padding: var(--space-8); }
.quote__panel { display: none; }
.quote__panel.is-active { display: block; }
.quote__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-3); }
.quote__choice {
  background: var(--alber-cream); border: 1.5px solid var(--border-1);
  border-radius: var(--radius-3); padding: var(--space-5);
  cursor: pointer; text-align: left;
  font-family: var(--font-body); font-size: 15px; color: var(--fg-deep);
  transition: all var(--t-fast) var(--ease-out);
  display: flex; align-items: center; gap: var(--space-3);
}
.quote__choice:hover { border-color: var(--alber-orange-500); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.quote__choice .msr { font-size: 28px; color: var(--alber-orange-500); flex-shrink: 0; }
.quote__choice strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.quote__choice small { display: block; font-size: 12px; color: var(--fg-3); margin-top: 2px; }
.quote__estimate { background: var(--alber-navy-50); border: 1px solid var(--alber-navy-100); border-radius: var(--radius-4); padding: var(--space-6); margin-bottom: var(--space-6); display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.quote__estimate strong { display: block; font-family: var(--font-display); font-size: 28px; color: var(--alber-navy-800); font-weight: 700; }
.quote__estimate small { color: var(--fg-3); font-size: 12px; font-family: var(--font-mono); letter-spacing: .08em; text-transform: uppercase; }
.quote__back { background: none; border: none; cursor: pointer; color: var(--fg-3); font-size: 13px; display: inline-flex; align-items: center; gap: 4px; margin-top: var(--space-6); }
.quote__back:hover { color: var(--alber-orange-500); }

/* ── STATS ──────────────────────────────────────────────────── */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); }
@media (max-width: 700px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stats__cell { background: #fff; border: 1px solid var(--border-1); border-radius: var(--radius-4); padding: var(--space-6); }
.stats__num { font-family: var(--font-display); font-weight: 700; font-size: 44px; line-height: 1; color: var(--alber-navy-800); letter-spacing: -0.025em; }
.stats__num em { color: var(--alber-orange-500); font-style: normal; }
.stats__label { font-size: 14px; color: var(--fg-3); margin-top: var(--space-2); }

/* ── COMPARISON TABLE ───────────────────────────────────────── */
.compare {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 0;
  border-radius: var(--radius-4);
  overflow: hidden;
  border: 1px solid var(--border-1);
  background: #fff;
}
.compare__row { display: contents; }
.compare__cell {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-1);
  font-size: 14px;
}
.compare__cell--head {
  background: var(--alber-navy-50);
  font-family: var(--font-display); font-weight: 700;
  color: var(--alber-navy-800); font-size: 15px;
  text-align: center;
}
.compare__cell--head.is-alber {
  background: var(--alber-navy-800); color: #fff;
}
.compare__cell--head.is-alber svg { fill: #fff; }
.compare__cell--label { font-weight: 500; color: var(--fg-deep); }
.compare__cell--alber {
  background: var(--alber-orange-50);
  text-align: center;
  font-weight: 600;
  color: var(--alber-navy-800);
}
.compare__cell--alber .msr { color: var(--success-500); }
.compare__cell--other { text-align: center; color: var(--fg-3); }
.compare__cell--other .msr { color: var(--gray-400); }
.compare__row:last-child .compare__cell { border-bottom: none; }
@media (max-width: 700px) {
  .compare { grid-template-columns: 1fr; }
  .compare__cell { text-align: left; }
  .compare__cell--label::before { content: ""; display: block; height: 1px; background: var(--border-1); margin-bottom: 8px; }
}

/* ── METHODS WITH THERMAL ───────────────────────────────────── */
.method-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-4);
  overflow: hidden;
  color: #fff;
}
.method-card__visual {
  height: 180px;
  position: relative;
  overflow: hidden;
}
.method-card__visual--thermal {
  background:
    radial-gradient(circle at 35% 40%, #FFEC00, #FF6B2C 25%, #DC2626 45%, #2563EB 70%, #0F1623);
  filter: blur(1px);
}
.method-card__visual--acoustic {
  background: var(--alber-aqua-700);
  display: grid; place-items: center;
}
.method-card__visual--acoustic::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 50% 50%, rgba(77,210,236,.4) 0%, transparent 30%),
    radial-gradient(circle at 50% 50%, rgba(77,210,236,.3) 30%, transparent 50%),
    radial-gradient(circle at 50% 50%, rgba(77,210,236,.2) 50%, transparent 70%);
  animation: pulse-ring 3s infinite;
}
@keyframes pulse-ring {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .6; transform: scale(1.05); }
}
.method-card__visual--gaz {
  background:
    radial-gradient(ellipse at 30% 70%, rgba(0,184,217,.6), transparent 50%),
    radial-gradient(ellipse at 70% 30%, rgba(255,107,44,.4), transparent 50%),
    var(--alber-navy-900);
}
.method-card__visual-label {
  position: absolute; bottom: 12px; left: 12px;
  background: rgba(0,0,0,.7); color: #fff;
  padding: 4px 8px; border-radius: 4px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .08em; backdrop-filter: blur(4px);
}
.method-card__body { padding: var(--space-5) var(--space-6); }
.method-card__icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-3);
  background: rgba(255,107,44,.18);
  display: grid; place-items: center;
  margin-bottom: var(--space-3);
}
.method-card__icon .msr { color: var(--alber-orange-400); font-size: 26px; }
.method-card h3 { color: #fff; margin: 0 0 var(--space-2); font-size: 22px; }
.method-card p { color: rgba(255,255,255,.7); font-size: 14px; margin: 0; }

/* ── CUSTOMER STORY ─────────────────────────────────────────── */
.story {
  background: var(--alber-cream);
  border-radius: var(--radius-5);
  padding: var(--space-12);
  position: relative;
  overflow: hidden;
}
.story__inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
}
@media (max-width: 800px) { .story__inner { grid-template-columns: 1fr; } }
.story__quote {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(24px, 2.6vw, 32px);
  line-height: 1.3;
  color: var(--alber-navy-800);
  letter-spacing: -0.015em;
  margin: 0 0 var(--space-6);
  text-wrap: balance;
}
.story__quote::before {
  content: "«";
  font-size: 64px; color: var(--alber-orange-500);
  display: block; line-height: 0.5; margin-bottom: 16px;
}
.story__meta { display: flex; align-items: center; gap: var(--space-4); }
.story__avatar {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--alber-orange-100);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700;
  font-size: 22px; color: var(--alber-orange-700);
}
.story__author { font-weight: 600; color: var(--alber-navy-800); }
.story__location { font-size: 13px; color: var(--fg-3); }
.story__facts {
  background: #fff;
  border-radius: var(--radius-4);
  padding: var(--space-6);
  border: 1px solid var(--border-1);
}
.story__facts h4 {
  font-family: var(--font-mono); font-size: 11px;
  font-weight: 600; text-transform: uppercase;
  letter-spacing: .14em; color: var(--alber-orange-500);
  margin: 0 0 var(--space-4);
}
.story__fact {
  display: grid; grid-template-columns: 120px 1fr;
  gap: var(--space-3); padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-1);
  font-size: 14px;
}
.story__fact:last-child { border-bottom: none; }
.story__fact strong { color: var(--alber-navy-800); font-weight: 600; }
.story__fact span { color: var(--fg-2); }

/* ── PARTNERS LOGO WALL ─────────────────────────────────────── */
.partners {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-4);
}
.partner {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-3);
  padding: var(--space-5);
  display: grid; place-items: center;
  min-height: 80px;
  transition: all var(--t-fast) var(--ease-out);
}
.partner:hover { border-color: var(--alber-orange-300); box-shadow: var(--shadow-2); }
.partner__name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: -0.02em;
  color: var(--alber-navy-800);
}

/* ── REVIEWS (Google style) ─────────────────────────────────── */
.reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
@media (max-width: 900px) { .reviews { grid-template-columns: 1fr; } }
.review {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: var(--radius-4);
  padding: var(--space-6);
  display: flex; flex-direction: column;
  gap: var(--space-3);
}
.review__head { display: flex; align-items: center; gap: var(--space-3); }
.review__avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background-size: cover; background-position: center;
  flex-shrink: 0;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 700;
  color: var(--alber-navy-800);
}
.review__name { font-weight: 600; color: var(--alber-navy-800); }
.review__meta { font-size: 12px; color: var(--fg-3); display: flex; align-items: center; gap: 6px; }
.review__google {
  width: 16px; height: 16px;
  border-radius: 50%; background: #fff;
  display: grid; place-items: center;
  border: 1px solid var(--border-1);
  font-size: 10px; font-weight: 700;
}
.review__stars { color: var(--alber-orange-500); font-size: 16px; letter-spacing: 2px; }
.review p { font-size: 15px; color: var(--fg-2); margin: 0; line-height: 1.55; }
.review__tag {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--alber-aqua-50); color: var(--alber-aqua-700);
  font-size: 11px; padding: 3px 8px;
  border-radius: var(--radius-pill);
  font-family: var(--font-mono); letter-spacing: .04em;
  width: fit-content;
}
.review__tag .msr { font-size: 13px; }

/* ── TABLES ─────────────────────────────────────────────────── */
.table-wrap {
  background: #fff;
  border-radius: var(--radius-4);
  border: 1px solid var(--border-1);
  overflow: hidden;
  margin-top: var(--space-6);
}
.table-wrap table { width: 100%; border-collapse: collapse; font-size: 14px; }
.table-wrap th, .table-wrap td {
  padding: var(--space-4) var(--space-5);
  text-align: left; border-bottom: 1px solid var(--border-1);
}
.table-wrap th {
  background: var(--alber-navy-50);
  font-family: var(--font-display); font-weight: 600;
  color: var(--alber-navy-800); font-size: 12px;
  letter-spacing: .08em; text-transform: uppercase;
}
.table-wrap tr:last-child td { border-bottom: none; }
.table-wrap td strong { color: var(--alber-navy-800); }

/* ── FAQ ────────────────────────────────────────────────────── */
.faq { display: grid; gap: var(--space-3); }
.faq details {
  background: #fff; border: 1px solid var(--border-1);
  border-radius: var(--radius-3); padding: var(--space-5) var(--space-6);
  transition: box-shadow var(--t-base) var(--ease-out);
}
.faq details[open] { box-shadow: var(--shadow-2); border-color: var(--alber-orange-200); }
.faq summary {
  font-family: var(--font-display); font-weight: 700;
  font-size: 17px; color: var(--alber-navy-800);
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--space-4);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .msr { color: var(--alber-orange-500); transition: transform var(--t-base) var(--ease-out); }
.faq details[open] summary .msr { transform: rotate(180deg); }
.faq p { margin: var(--space-3) 0 0; color: var(--fg-2); }

/* ── City links ─────────────────────────────────────────────── */
.city-links {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-6);
}
.city-links a {
  background: #fff; border: 1px solid var(--border-1);
  border-radius: var(--radius-3);
  padding: var(--space-4) var(--space-5);
  text-decoration: none; color: var(--alber-navy-800);
  font-weight: 500; font-size: 14px;
  display: flex; justify-content: space-between; align-items: center;
  transition: all var(--t-fast) var(--ease-out);
}
.city-links a:hover {
  border-color: var(--alber-orange-500);
  color: var(--alber-orange-600);
  transform: translateY(-1px);
}
.city-links .msr { color: var(--alber-orange-500); font-size: 16px; }
.city-links small { color: var(--fg-3); font-family: var(--font-mono); font-size: 11px; }

/* ── FINAL CTA ──────────────────────────────────────────────── */
.final-cta {
  background: linear-gradient(135deg, var(--alber-navy-900) 0%, var(--alber-navy-800) 100%);
  color: #fff; padding: var(--space-16) 0;
  position: relative; overflow: hidden;
}
.final-cta::before {
  content: ""; position: absolute;
  right: -100px; top: -100px; width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,107,44,.25), transparent 65%);
}
.final-cta__inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: var(--space-8); align-items: center;
}
@media (max-width: 700px) { .final-cta__inner { grid-template-columns: 1fr; } }
.final-cta h2 { color: #fff; }

/* ── Sticky mobile CTA ──────────────────────────────────────── */
.sticky-cta {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border-top: 1px solid var(--border-1);
  padding: 12px var(--page-gutter);
  display: none; z-index: 100;
  box-shadow: 0 -8px 24px rgba(10,31,68,.08);
}
.sticky-cta__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (max-width: 900px) { .sticky-cta { display: block; } body { padding-bottom: 80px; } }

/* ── Footer ─────────────────────────────────────────────────── */
.site-footer { background: var(--alber-navy-900); color: rgba(255,255,255,.7); padding: var(--space-12) 0 var(--space-6); }
.site-footer__grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-8); }
@media (max-width: 700px) { .site-footer__grid { grid-template-columns: 1fr 1fr; } }
.site-footer h4 { color: #fff; font-family: var(--font-display); font-size: 13px; letter-spacing: .08em; text-transform: uppercase; margin: 0 0 var(--space-3); }
.site-footer a { color: inherit; text-decoration: none; display: block; padding: 4px 0; font-size: 14px; }
.site-footer a:hover { color: var(--alber-orange-400); }
.site-footer__bottom { margin-top: var(--space-10); padding-top: var(--space-5); border-top: 1px solid rgba(255,255,255,.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(255,255,255,.5); flex-wrap: wrap; gap: var(--space-3); }

/* Team mini */
.team-mini {
  display: flex; align-items: center; gap: var(--space-4);
  background: var(--alber-cream);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-4);
  border: 1px solid var(--alber-orange-100);
  margin-top: var(--space-6);
}
.team-mini img { width: 64px; height: 64px; object-fit: cover; object-position: top; border-radius: 50%; background: var(--alber-navy-100); }
.team-mini strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--fg-deep); }
.team-mini small { color: var(--fg-3); font-size: 13px; }

/* Template note (editor only) */
.template-note {
  background: var(--alber-aqua-50);
  border-left: 4px solid var(--alber-aqua-500);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-2);
  font-family: var(--font-mono); font-size: 13px;
  color: var(--alber-aqua-700);
  margin: var(--space-6) 0;
}
.template-note strong { color: var(--alber-navy-800); }
.template-note code { background: rgba(0,0,0,.04); border-color: transparent; }

/* ── Zone map (OpenStreetMap / Leaflet) ─────────────────────── */
.zone-map-wrap {
  margin-top: var(--space-8);
  border-radius: var(--radius-5);
  border: 1px solid var(--border-1);
  overflow: hidden;
  box-shadow: var(--shadow-2);
}
#alber-map {
  width: 100%;
  height: 420px;
  background: var(--alber-navy-50);
  z-index: 1;
}
@media (max-width: 700px) { #alber-map { height: 300px; } }
.alber-map-pin span {
  display: block; width: 22px; height: 22px;
  background: var(--alber-orange-500);
  border: 3px solid #fff;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  box-shadow: 0 2px 8px rgba(10,31,68,.4);
}
/* Leaflet controls sobres */
.leaflet-container { font-family: var(--font-sans, sans-serif); }
.leaflet-bar a { color: var(--alber-navy-800); }

/* Lien "En savoir plus" dans les method-cards */
.method-card__link {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: var(--space-3); color: var(--alber-orange-400);
  font-family: var(--font-display); font-weight: 600; font-size: 14px;
  text-decoration: none;
}
.method-card__link .msr { font-size: 16px; transition: transform var(--t-fast) var(--ease-out); }
.method-card__link:hover .msr { transform: translateX(3px); }

/* ── Template Contenu (page/single) ─────────────────────────── */
.content-hero {
  background: linear-gradient(135deg, var(--alber-navy-800), var(--alber-navy-900));
  color: #fff;
  padding: var(--space-10) 0 var(--space-12);
}
.content-hero .breadcrumb, .content-hero .breadcrumb a { color: rgba(255,255,255,.65); }
.content-hero .eyebrow { color: var(--alber-orange-300); }
.content-hero h1 { color: #fff; margin: var(--space-2) 0 0; }
.content-hero__lead { color: rgba(255,255,255,.8); font-size: var(--text-l, 18px); max-width: 70ch; margin: var(--space-4) 0 0; line-height: 1.6; }
.content-layout {
  display: grid; grid-template-columns: minmax(0,1fr) 320px;
  gap: var(--space-10); align-items: start;
}
.content-prose { max-width: 760px; }
.content-prose h2 { margin-top: var(--space-8); }
.content-prose h3 { margin-top: var(--space-6); }
.content-prose p, .content-prose li { color: var(--fg-2); line-height: 1.7; }
.content-prose ul, .content-prose ol { padding-left: 1.2em; }
.content-prose table { width: 100%; border-collapse: collapse; margin: var(--space-5) 0; }
.content-prose th, .content-prose td { border: 1px solid var(--border-1); padding: 10px 12px; text-align: left; font-size: 14px; }
.content-prose th { background: var(--alber-cream); font-family: var(--font-display); }
.content-aside { position: sticky; top: 88px; }
.content-card {
  background: #fff; border: 1px solid var(--border-1);
  border-radius: var(--radius-4); padding: var(--space-6);
  box-shadow: var(--shadow-2);
}
.content-card__icon {
  width: 48px; height: 48px; border-radius: var(--radius-2);
  background: var(--alber-orange-50); display: grid; place-items: center;
  margin-bottom: var(--space-3);
}
.content-card__icon .msr { color: var(--alber-orange-500); font-size: 26px; }
.content-card strong { display: block; font-family: var(--font-display); font-size: 17px; color: var(--alber-navy-800); }
.content-card p { color: var(--fg-3); font-size: 14px; margin: var(--space-2) 0 var(--space-4); }
.faq__answer { margin: var(--space-3) 0 0; color: var(--fg-2); line-height: 1.7; }
.faq__answer p:first-child { margin-top: 0; }
@media (max-width: 860px) {
  .content-layout { grid-template-columns: 1fr; }
  .content-aside { position: static; }
}
.content-hero__badge {
  width: 56px; height: 56px; border-radius: var(--radius-3);
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15);
  display: grid; place-items: center; flex: 0 0 auto;
}
.content-hero__badge .msr { color: var(--alber-orange-300); font-size: 30px; }
.content-hero__price {
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
  color: #fff; font-family: var(--font-display); font-weight: 700;
  padding: 8px 16px; border-radius: var(--radius-pill); font-size: 15px;
}
/* Grille de liens de maillage */
.link-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3); margin-top: var(--space-6);
}
.link-grid__item {
  display: flex; align-items: center; gap: 8px;
  background: #fff; border: 1px solid var(--border-1);
  border-radius: var(--radius-3); padding: var(--space-3) var(--space-4);
  text-decoration: none; color: var(--alber-navy-800);
  font-weight: 500; font-size: 14px;
  transition: all var(--t-fast) var(--ease-out);
}
.link-grid__item:hover { border-color: var(--alber-orange-500); color: var(--alber-orange-600); transform: translateY(-1px); }
.link-grid__item .msr { color: var(--alber-orange-500); font-size: 18px; flex: 0 0 auto; }
@media (max-width: 900px) { .link-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .link-grid { grid-template-columns: 1fr; } }
/* Grille prestations (hub) — réutilise .presta-card */
.presta-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
.presta-grid .presta-card { flex: initial; min-height: 0; }
@media (max-width: 1000px) { .presta-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .presta-grid { grid-template-columns: 1fr; } }

/* ── PHOTOS (intégration visuels réels) ─────────────────────── */
/* Méthodes : la photo remplace le visuel CSS dégradé */
.method-card__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Cartes prestation : bandeau photo en tête + pastille icône */
.presta-card__photo {
  margin: calc(-1 * var(--space-6)) calc(-1 * var(--space-6)) var(--space-5);
  height: 150px; overflow: hidden; position: relative;
  border-radius: var(--radius-4) var(--radius-4) 0 0;
  background: var(--alber-navy-100);
}
.presta-card__photo img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--t-slow, .5s) var(--ease-out); }
.presta-card:hover .presta-card__photo img { transform: scale(1.05); }
.presta-card__photo .presta-card__icon {
  position: absolute; left: var(--space-4); bottom: var(--space-4); margin: 0;
  width: 44px; height: 44px;
  background: rgba(255, 255, 255, .94); backdrop-filter: blur(4px);
  box-shadow: var(--shadow-2);
}
.presta-card__photo .presta-card__icon .msr { font-size: 24px; }
.presta-grid .presta-card { overflow: hidden; }

/* Cartes symptômes : bandeau photo + pastille icône */
.symptom { padding: 0; overflow: hidden; }
.symptom__photo {
  height: 130px; overflow: hidden; position: relative;
  background: var(--alber-navy-100);
}
.symptom__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.symptom__photo .symptom__icon {
  position: absolute; left: var(--space-4); bottom: var(--space-4);
  background: rgba(255, 255, 255, .94); backdrop-filter: blur(4px);
  box-shadow: var(--shadow-2);
}
.symptom__body { padding: var(--space-4) var(--space-5) var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); }

/* Hero contenu (prestation / technologie) : illustration à droite */
.content-hero__grid {
  display: grid; grid-template-columns: minmax(0, 1fr) 360px;
  gap: var(--space-10); align-items: center;
}
.content-hero__media {
  border-radius: var(--radius-5); overflow: hidden;
  box-shadow: var(--shadow-4); aspect-ratio: 4 / 3;
  border: 1px solid rgba(255, 255, 255, .12);
}
.content-hero__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.content-hero__portrait {
  width: 116px; height: 116px; border-radius: 50%; overflow: hidden;
  border: 4px solid rgba(255, 255, 255, .15); flex: 0 0 auto;
  box-shadow: var(--shadow-3);
}
.content-hero__portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 900px) {
  .content-hero__grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .content-hero__media { aspect-ratio: 16 / 9; max-height: 240px; }
}

/* Mascot principal (Alber) — footer / CTA / logo mobile */
.site-footer__mascot { display: block; height: 210px; width: auto; margin-top: var(--space-2); }
.final-cta__mascot { display: grid; place-items: center; }
.final-cta__mascot img { max-height: 440px; width: auto; filter: drop-shadow(0 24px 48px rgba(0, 0, 0, .45)); }
.site-logo__fox { display: none; height: 40px; width: auto; }

/* Habitat : photo de contexte par type de bâti (pages villes) */
.habitat__photo {
  border-radius: var(--radius-4); overflow: hidden; box-shadow: var(--shadow-3);
  aspect-ratio: 16 / 10; margin-top: var(--space-6);
}
.habitat__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Figure dans l'aside (prestation / technologie) */
.aside-figure { border-radius: var(--radius-4); overflow: hidden; box-shadow: var(--shadow-2); margin-bottom: var(--space-4); aspect-ratio: 4 / 3; }
.aside-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Bande galerie (page À propos) */
.gallery-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4);
  margin-top: var(--space-8);
}
.gallery-strip figure { margin: 0; }
.gallery-strip__img { border-radius: var(--radius-4); overflow: hidden; box-shadow: var(--shadow-2); aspect-ratio: 4 / 3; }
.gallery-strip__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.gallery-strip figcaption { font-size: 12px; color: var(--fg-3); margin-top: var(--space-2); text-align: center; }
@media (max-width: 760px) { .gallery-strip { grid-template-columns: repeat(2, 1fr); } }

/* ════════════════════════════════════════════════════════════
   REPASSE RESPONSIVE MOBILE — bloc consolidé, placé après toutes
   les règles de base pour gagner la cascade à spécificité égale.
   ════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Mascotte hero EN FOND, ancrée en bas à droite (filigrane de marque).
     N'ajoute aucune hauteur (position absolue) et reste visible sans gêner la lecture. */
  .hero { position: relative; overflow: hidden; }
  .hero__inner { position: relative; }
  .hero__inner > div:first-child { position: relative; z-index: 1; }   /* texte au-dessus */
  .hero__mascot-wrap {
    display: block; position: absolute; right: -14px; bottom: 0;
    width: 48%; max-width: 240px; margin: 0; opacity: .85; z-index: 0; pointer-events: none;
  }
  .hero__mascot-wrap::before { display: none; }   /* halo retiré en mode fond */
  .hero__mascot { max-height: none; width: 100%; filter: none; }
  .hero__chip { display: none; }                  /* chips flottants masqués (mode fond) */
  .symptoms { grid-template-columns: repeat(3, 1fr); }
  /* Éditorial mobile : image flottée plus petite, texte densifié. Texte intact. */
  .editorial { max-width: 100%; margin-bottom: var(--space-8); }
  .editorial .editorial__visual { width: 34%; max-width: 120px; aspect-ratio: 1 / 1; max-height: none; margin: 2px 0 10px 14px; box-shadow: var(--shadow-2); }
  .editorial--reverse .editorial__visual { margin: 2px 14px 10px 0; }
  .editorial__pull { display: none; }                  /* illisible à cette taille */
  .editorial h3 { font-size: clamp(20px, 5.5vw, 25px); margin-bottom: var(--space-2); }
  .editorial p { font-size: 15px; line-height: 1.55; margin-bottom: var(--space-2); }
  .content-prose { max-width: 100%; }
  .content-prose p, .content-prose li { font-size: 15px; line-height: 1.55; }
  .content-prose h2 { margin-top: var(--space-5); font-size: clamp(22px, 6vw, 28px); }
  .content-prose h3 { margin-top: var(--space-4); }
  /* Padding vertical des sections réduit sur mobile : ~840px de scroll en moins
     sur l'ensemble de la page (≈15 sections), sans rien retirer au contenu. */
  .section { padding: 36px 0; }
  .section h2 { margin-bottom: var(--space-4); }
}
@media (max-width: 760px) {
  /* Live-bar : message court, jamais de débordement */
  .live-bar { gap: 10px; font-size: 11.5px; padding: 7px 16px; }
  .live-bar__route,
  .live-bar__item--secondary,
  .live-bar__sep { display: none; }
  /* Hero : titres et sous-titre adaptés */
  .hero { padding: var(--space-10) 0 var(--space-8); }
  .hero h1 { font-size: clamp(26px, 7.5vw, 40px); }
  .hero__sub { font-size: 16px; max-width: 100%; }
  .trust-strip__inner { gap: 12px; font-size: 10.5px; }
}
@media (max-width: 640px) {
  .symptoms { grid-template-columns: repeat(2, 1fr); }
  /* Header compact : mascotte (tête) à la place de la goutte → on voit Alber */
  .site-header__inner { gap: 8px; height: 64px; }
  .header-devis { display: none; }
  /* Header : bouton appel en icône seule (numéro dispo dans le hero + sticky bas) */
  .header-call { font-size: 0; padding: 0; width: 42px; height: 42px; justify-content: center; border-radius: var(--radius-2); }
  .header-call .msr { font-size: 20px; margin: 0; }
  .site-logo { font-size: 19px; gap: 8px; }   /* goutte + wordmark */
  .nav-burger { background: var(--alber-cream); border-color: var(--alber-orange-200); width: 42px; height: 42px; }
  .badge { font-size: 11px; padding: 3px 9px; }
  .hero .row.gap-2 { gap: 6px; }
  /* Fix bloc "Une équipe de spécialistes" : le bouton à droite écrasait le texte
     (wrap mot par mot). On masque ce bouton (redondant : CTA appel au-dessus +
     sticky bas) et on rend toute la largeur au texte. */
  .team-mini { gap: var(--space-3); padding: var(--space-3) var(--space-4); }
  .team-mini > div { flex: 1 1 0; min-width: 0; }
  .team-mini > a { display: none; }
}
