/* =============================================================
   BATIYS — Design system premium
   Typographie : Inter (corps) + Fraunces (titres)
   Palette    : bleu profond, orange terre, fonds sobres
   Objectif   : rendu entreprise locale, crédible et rassurant
   ============================================================= */

/* ─── 1. RESET BASE ─────────────────────────────────────────── */
*,
*::before,
*::after { margin:0; padding:0; box-sizing:border-box; }

html {
  scroll-behavior: smooth;
  max-width: 100%;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, Arial, sans-serif;
  color: var(--texte);
  background: var(--blanc);
  line-height: 1.7;
  font-weight: 400;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "ss01", "cv11";
}

img, svg { max-width:100%; height:auto; display:block; }

a { color: inherit; text-decoration: none; }

button { font-family: inherit; cursor: pointer; }

/* ─── 2. VARIABLES ──────────────────────────────────────────── */
:root {
  /* Bleu */
  --bleu:         #0F2744;
  --bleu-fonce:   #0A1D35;
  --bleu-clair:   #23588C;
  --bleu-pale:    #EBF1F8;

  /* Orange */
  --orange:       #E5671C;
  --orange-fonce: #BE4E10;
  --orange-pale:  #FFF2E8;

  /* Gris */
  --gris-clair:   #F7F8FA;
  --gris-bordure: #E6EBF1;
  --gris:         #6B7684;

  /* Texte */
  --texte:        #1A2430;
  --texte-doux:   #4B5867;
  --blanc:        #FFFFFF;

  /* Rayons, ombres, transitions */
  --r-s: 10px;
  --r-m: 14px;
  --r-l: 18px;

  --shadow-s: 0 1px 2px rgba(15,39,68,.04);
  --shadow-m: 0 1px 2px rgba(15,39,68,.04), 0 8px 22px rgba(15,39,68,.06);
  --shadow-l: 0 2px 6px rgba(15,39,68,.06), 0 18px 40px rgba(15,39,68,.10);

  --t-fast: .2s cubic-bezier(.4,0,.2,1);
  --t-med:  .3s cubic-bezier(.4,0,.2,1);

  --max: 1180px;
}

/* ─── 3. TYPOGRAPHIE ────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
.hero h2,
.hero-service h2,
.hero-section h2,
.cta-final h3,
.section-title h3,
.section-header h3,
.blocs-title h3,
.zone h3,
.pourquoi-box h4,
.card-devis h4 {
  font-family: 'Fraunces', 'Fraunces Fallback', Georgia, 'Times New Roman', serif;
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--bleu);
  line-height: 1.2;
}

/* Eyebrows : libellés en capitales */
.eyebrow,
.section-header .eyebrow,
.section-title .eyebrow,
.blocs-title .eyebrow,
.service-tag,
.hero-tag {
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
}

/* ─── 4. HEADER + NAV ───────────────────────────────────────── */
header {
  background: var(--bleu);
  color: var(--blanc);
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 48px;
  height: 76px;
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 1px 0 rgba(255,255,255,.04), 0 8px 24px rgba(10,29,53,.18);
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.logo {
  display: flex; align-items: center; gap: 14px;
  text-decoration: none; min-height: 56px;
}
.site-logo-img {
  width: 48px !important; height: 48px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(232,117,42,.18);
}
.logo-text h1 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.2rem; font-weight: 700;
  color: var(--blanc); letter-spacing: 0;
}
.logo-text h1 span { color: var(--orange); }
.logo-text small { font-size: .72rem; opacity: .65; }

.nav-links {
  display: flex; gap: 34px; align-items: center;
}
.nav-links a {
  color: rgba(255,255,255,.8);
  font-size: .92rem;
  font-weight: 500;
  padding: 4px 0;
  position: relative;
  transition: color var(--t-fast);
}
.nav-links a:hover { color: var(--blanc); }
.nav-links a.is-active,
.nav-links a[aria-current="page"] {
  color: var(--blanc);
  font-weight: 600;
}
.nav-links a.is-active::after,
.nav-links a[aria-current="page"]::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -8px;
  height: 2px; background: var(--orange); border-radius: 2px;
}

.hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; padding: 8px;
}
.hamburger span {
  display: block; width: 24px; height: 2px;
  background: rgba(255,255,255,.92); border-radius: 2px;
  transition: var(--t-fast);
}

.nav-overlay {
  display: none;
  position: fixed; top: 76px; left: 0; right: 0; bottom: 0;
  background: var(--bleu);
  z-index: 99;
  flex-direction: column;
  align-items: center; justify-content: flex-start;
  padding: 28px 20px;
  gap: 12px;
  overflow-y: auto;
}
.nav-overlay.open { display: flex; }
.nav-overlay a {
  width: 100%; max-width: 360px;
  display: flex; align-items: center; justify-content: center;
  min-height: 50px; padding: 12px 16px;
  color: rgba(255,255,255,.9);
  font-size: 1rem; font-weight: 600;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
}
.nav-overlay .btn-tel {
  margin-top: 8px;
  background: var(--orange);
  border-color: transparent;
  color: var(--blanc);
}

/* ─── 5. BOUTONS ────────────────────────────────────────────── */
.btn-primary,
.btn-secondary,
.btn-outline-light,
.btn-outline-dark,
.btn-tel {
  display: inline-flex;
  align-items: center; justify-content: center;
  gap: 8px;
  font-family: inherit;
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .01em;
  text-decoration: none;
  padding: 14px 26px;
  border-radius: var(--r-s);
  border: 1px solid transparent;
  transition: background var(--t-fast), color var(--t-fast),
              border-color var(--t-fast), transform var(--t-fast),
              box-shadow var(--t-fast);
  min-height: 48px;
  line-height: 1.2;
  cursor: pointer;
}

.btn-primary {
  background: var(--orange);
  color: var(--blanc);
  box-shadow: 0 1px 2px rgba(190,78,16,.12), 0 10px 24px rgba(229,103,28,.22);
}
.btn-primary:hover {
  background: var(--orange-fonce);
  transform: translateY(-1px);
  box-shadow: 0 1px 2px rgba(190,78,16,.2), 0 12px 28px rgba(229,103,28,.28);
}

.btn-secondary,
.btn-outline-light {
  background: transparent;
  color: var(--blanc);
  border-color: rgba(255,255,255,.28);
}
.btn-secondary:hover,
.btn-outline-light:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.48);
}

.btn-outline-dark {
  background: var(--blanc);
  color: var(--bleu);
  border-color: var(--gris-bordure);
}
.btn-outline-dark:hover {
  background: var(--bleu-pale);
  border-color: var(--bleu-clair);
}

/* ─── Bouton "Devis gratuit" — sobre & pro ──────────────────── */
.btn-tel {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: var(--orange, #E5671C);
  color: #fff !important;
  padding: 10px 18px;
  font-size: .9rem;
  font-weight: 600;
  letter-spacing: .005em;
  min-height: 42px;
  border-radius: 10px;
  border: none;
  box-shadow: 0 3px 10px rgba(229,103,28,.24);
  transition:
    background .2s ease,
    transform .2s ease,
    box-shadow .2s ease;
  gap: 6px;
}
/* Petit point pulsant discret — signale « dispo » sans être criard */
.btn-tel::before {
  content: "";
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #fff;
  margin-right: 4px;
  box-shadow: 0 0 0 0 rgba(255,255,255,.65);
  animation: btn-tel-dot 2.2s ease-in-out infinite;
  flex: none;
}
@keyframes btn-tel-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,.7); opacity: 1; }
  50%      { box-shadow: 0 0 0 5px rgba(255,255,255,0); opacity: .85; }
}
.btn-tel:hover {
  background: #D05714;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(229,103,28,.36);
}
.btn-tel:active {
  transform: translateY(0);
  box-shadow: 0 2px 6px rgba(229,103,28,.22);
}
.btn-tel:focus-visible {
  outline: 2px solid var(--orange, #E5671C);
  outline-offset: 3px;
}

/* Variante nav-overlay : bouton pleine largeur dans le menu burger */
.nav-overlay .btn-tel {
  margin-top: 14px;
  padding: 14px 22px;
  font-size: 1rem;
  min-height: 52px;
  width: 100%;
  justify-content: center;
  border-radius: 12px;
}

/* ─── 6. VAGUES — on masque, on garde les transitions sobres ── */
.wave { display: none !important; }

/* ─── 7. LAYOUT ─────────────────────────────────────────────── */
section { position: relative; }

/* ─── 8. HERO ACCUEIL ───────────────────────────────────────── */
.hero-section {
  background: var(--bleu);
  background-image:
    radial-gradient(ellipse 60% 70% at 85% 30%, rgba(35,88,140,.22) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 15% 80%, rgba(229,103,28,.10) 0%, transparent 55%);
  padding: 0; overflow: hidden; position: relative;
}

.hero {
  color: var(--blanc);
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr);
  max-width: var(--max);
  margin: 0 auto;
  align-items: stretch;
  position: relative; z-index: 1;
}

.hero-content { padding: 92px 56px 96px 48px; text-align: left; }

.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.85);
  padding: 6px 14px;
  border-radius: 999px;
  font-size: .78rem; font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 26px;
}

.hero h2 {
  font-size: clamp(2rem, 3.4vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  color: var(--blanc);
  letter-spacing: -.02em;
  margin-bottom: 22px;
}
.hero h2 em {
  font-style: italic;
  color: var(--orange);
  font-weight: 700;
}

.hero-desc {
  font-family: 'Inter', sans-serif;
  font-size: 1.04rem; line-height: 1.75;
  color: rgba(255,255,255,.78);
  margin-bottom: 36px;
  max-width: 520px;
}
.hero-desc strong { color: #FFCBA4; font-weight: 600; }

.hero-btns {
  display: flex; gap: 12px; flex-wrap: wrap;
  justify-content: flex-start;
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 52px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.12);
  max-width: 560px;
}
.hero-stats .stat {
  display: flex; flex-direction: column;
  padding: 0 22px;
  border-right: 1px solid rgba(255,255,255,.12);
}
.hero-stats .stat:first-child { padding-left: 0; }
.hero-stats .stat:last-child  { border-right: none; }
.hero-stats .stat strong {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.85rem; font-weight: 700;
  color: var(--orange);
  line-height: 1;
}
.hero-stats .stat span {
  margin-top: 6px;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.65);
}

/* Panneau droit */
.hero-visual {
  position: relative;
  min-height: 580px;
  padding: 56px 48px 56px 24px;
  display: grid;
  align-items: center;
  overflow: hidden;
}

.hero-photo-grid {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(160px, .82fr);
  gap: 14px;
  width: 100%;
}
.hero-photo-stack { display: grid; gap: 14px; }
.hero-photo-card {
  position: relative; overflow: hidden;
  border-radius: var(--r-l);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 24px 50px rgba(6,18,31,.35);
}
.hero-photo-card img { width: 100%; height: 100%; object-fit: cover; }
.hero-photo-card::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,29,53,0) 40%, rgba(10,29,53,.72) 100%);
}
.hero-photo-main { min-height: 492px; }
.hero-photo-stack .hero-photo-card:first-child,
.hero-photo-stack .hero-photo-card:last-child { min-height: 238px; }

.hero-photo-caption {
  position: absolute; left: 18px; right: 18px; bottom: 16px; z-index: 1;
}
.hero-photo-caption strong {
  display: block; color: #fff;
  font-size: .95rem; margin-bottom: 4px;
  font-weight: 600;
}
.hero-photo-caption span {
  display: block;
  color: rgba(255,255,255,.78);
  font-size: .78rem; line-height: 1.5;
}

/* Cartes flottantes (fallback) */
.hero-cards { position: relative; z-index: 2; display: flex; flex-direction: column; gap: 12px; padding: 32px 28px; width: 100%; }
.hero-card { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12); border-radius: 12px; padding: 14px 18px; display: flex; align-items: center; gap: 14px; backdrop-filter: blur(8px); transition: background var(--t-fast); }
.hero-card:hover { background: rgba(255,255,255,.12); }
.hero-card-ico { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; background: rgba(229,103,28,.18); font-size: 1.1rem; }
.hero-card-text strong { display: block; font-size: .87rem; font-weight: 700; color: #fff; }
.hero-card-text span { font-size: .76rem; color: rgba(255,255,255,.6); }
.hero-card-price { margin-left: auto; background: rgba(229,103,28,.22); border: 1px solid rgba(229,103,28,.4); color: #FFCBA4; font-size: .72rem; font-weight: 700; padding: 3px 10px; border-radius: 999px; white-space: nowrap; }

/* ─── 9. HERO PAGES SERVICES ────────────────────────────────── */
.hero-service {
  background: var(--bleu);
  background-image:
    radial-gradient(ellipse 60% 70% at 85% 30%, rgba(35,88,140,.22) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 15% 85%, rgba(229,103,28,.10) 0%, transparent 55%);
  color: var(--blanc);
  padding: 72px 48px 64px;
  text-align: center;
}
.breadcrumb { font-size: .82rem; opacity: .6; margin-bottom: 18px; }
.breadcrumb a { color: rgba(255,255,255,.78); transition: color var(--t-fast); }
.breadcrumb a:hover { color: var(--blanc); }

.service-tag {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.88);
  padding: 6px 16px; border-radius: 999px;
  font-size: .78rem; font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.hero-service h2 {
  font-size: clamp(1.9rem, 3.2vw, 2.8rem);
  font-weight: 700;
  line-height: 1.14;
  color: var(--blanc);
  margin-bottom: 18px;
}
.hero-service h2 em { font-style: italic; color: var(--orange); }
.hero-service .sub {
  font-size: 1.04rem; line-height: 1.72;
  color: rgba(255,255,255,.82);
  max-width: 620px;
  margin: 0 auto 34px;
}
.hero-service .hero-btns { justify-content: center; }

/* ─── 10. TRUST BAR + ARGUMENTS ─────────────────────────────── */
.trust-bar,
.arguments {
  background: var(--bleu-pale);
  display: flex; flex-wrap: wrap;
  justify-content: center; align-items: center;
  gap: 10px;
  padding: 22px 32px;
  border-top: 1px solid #D9E3EF;
  border-bottom: 1px solid #D9E3EF;
}
.trust-item,
.argument {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--blanc);
  border: 1px solid #D0DDEB;
  border-radius: 999px;
  padding: 9px 18px;
  font-size: .87rem; font-weight: 600;
  color: var(--bleu);
  box-shadow: var(--shadow-s);
  white-space: nowrap;
}
.trust-item .t-ico,
.argument .ico { font-size: 1rem; line-height: 1; }

/* ─── 11. STATS BAND ────────────────────────────────────────── */
.stats-band {
  background: var(--bleu-fonce);
  display: flex; justify-content: center; flex-wrap: wrap;
  border-bottom: 2px solid var(--orange);
}
.stats-band .stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 22px 44px;
  color: var(--blanc);
  border-right: 1px solid rgba(255,255,255,.08);
}
.stats-band .stat:last-child { border-right: none; }
.stat-n {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 2.1rem; font-weight: 700;
  color: var(--orange);
  line-height: 1;
}
.stat-n small { font-size: 1rem; font-weight: 700; }
.stat-l {
  font-size: .78rem;
  opacity: .7;
  margin-top: 6px;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* ─── 12. SECTION TITLES ────────────────────────────────────── */
.section-title,
.section-header {
  text-align: center;
  margin-bottom: 52px;
}
.section-title .eyebrow,
.section-header .eyebrow,
.blocs-title .eyebrow,
.eyebrow {
  display: inline-block;
  background: var(--bleu-pale);
  color: var(--bleu-clair);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 999px;
  margin-bottom: 14px;
  font-weight: 700;
}
.section-title h3,
.section-header h3,
.blocs-title h3 {
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  font-weight: 700;
  color: var(--bleu);
  margin-bottom: 12px;
  letter-spacing: -.015em;
}
.section-title p,
.section-header p {
  color: var(--texte-doux);
  font-size: 1rem;
  max-width: 560px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ─── 13. CARTES GÉNÉRIQUES ─────────────────────────────────── */
.card,
.presta,
.service-card,
.svc-card,
.tarif-card,
.temoignage,
.zone-card,
.info-card,
.card-devis,
.card-garanties,
.avantages-grid .avantage {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--r-m);
  box-shadow: var(--shadow-m);
  transition: transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
}
.card:hover,
.presta:hover,
.service-card:hover,
.svc-card:hover,
.tarif-card:hover,
.zone-card:hover,
.avantages-grid .avantage:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-l);
  border-color: #D3DEEA;
}

/* On retire la barre gradient orange en tête de cartes génériques */
.card::before,
.presta::before,
.service-card::before { content: none !important; }

/* ─── 14. SERVICES (INDEX) ──────────────────────────────────── */
.services,
section[id="services"] { background: var(--gris-clair); padding: 88px 48px; }

.services-grid,
.idx-services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  max-width: var(--max);
  margin: 0 auto;
}
.services-grid .service-card { grid-column: auto; }

.service-card,
.svc-card {
  padding: 28px;
  text-align: left;
  display: flex; flex-direction: column;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
}

/* Badge "Le plus demandé" */
.svc-popular {
  border-color: var(--orange) !important;
}
.svc-popular::before {
  content: ''; position: absolute;
  top: 0; bottom: 0; left: 0; width: 3px;
  background: var(--orange);
  border-top-left-radius: var(--r-m);
  border-bottom-left-radius: var(--r-m);
}
.svc-badge {
  position: absolute; top: 14px; right: 14px;
  background: var(--orange);
  color: var(--blanc);
  font-size: .7rem; font-weight: 700;
  letter-spacing: .04em;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow: 0 4px 12px rgba(229,103,28,.3);
}

.svc-bar { display: none !important; } /* plus de barre gradient */

.svc-ico,
.service-card .emoji,
.service-card .svc-icon {
  width: 52px; height: 52px;
  background: var(--bleu-pale);
  border-radius: var(--r-s);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 16px;
  flex-shrink: 0;
}
.svc-popular .svc-ico { background: var(--orange-pale); }

.svc-body { display: flex; flex-direction: column; flex: 1; }
.svc-title,
.service-card h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.1rem; font-weight: 700;
  color: var(--bleu);
  margin-bottom: 10px;
  line-height: 1.3;
  letter-spacing: -.01em;
}
.svc-desc,
.service-card p {
  color: var(--texte-doux);
  font-size: .92rem;
  line-height: 1.65;
  margin-bottom: 16px;
}
.svc-list {
  display: flex; flex-direction: column; gap: 6px;
  margin-bottom: 18px;
}
.svc-list span {
  font-size: .85rem; color: var(--texte-doux);
  line-height: 1.55;
}
.svc-link {
  margin-top: auto;
  font-size: .86rem; font-weight: 700;
  color: var(--orange);
  display: inline-flex; align-items: center; gap: 6px;
  transition: gap var(--t-fast);
}
.svc-card:hover .svc-link { gap: 10px; }

/* ─── 15. TARIFS ────────────────────────────────────────────── */
.tarifs { background: var(--blanc); padding: 88px 48px; }
.tarifs-grid,
.idx-tarifs-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  max-width: var(--max); margin: 0 auto;
}
.tarif-card {
  padding: 32px 28px;
  text-align: left;
  position: relative;
}
.tarif-card.popular,
.tarif-card-popular {
  border-color: var(--orange);
}
.tarif-card.popular::before,
.tarif-card-popular::before {
  content: ''; position: absolute; left: 0; top: 16px; bottom: 16px; width: 3px;
  background: var(--orange); border-radius: 2px;
}
.tarif-card .badge-pop {
  position: absolute; top: -12px; left: 24px;
  background: var(--orange); color: var(--blanc);
  font-size: .7rem; font-weight: 700;
  letter-spacing: .04em;
  padding: 4px 12px; border-radius: 999px;
  box-shadow: 0 4px 12px rgba(229,103,28,.25);
}
.tarif-card .t-emoji,
.tarif-card .svc-ico {
  width: 48px; height: 48px;
  background: var(--bleu-pale);
  border-radius: var(--r-s);
  font-size: 1.35rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.tarif-card h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1rem; font-weight: 700;
  color: var(--bleu);
  margin-bottom: 12px;
}
.prix {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 2rem; font-weight: 700;
  color: var(--bleu);
  line-height: 1; margin-bottom: 4px;
}
.prix-unite {
  font-size: .82rem; color: var(--gris);
  margin-bottom: 20px;
}
.tarif-details {
  list-style: none; display: flex; flex-direction: column; gap: 8px;
}
.tarif-details li {
  padding: 6px 0;
  font-size: .88rem; color: var(--texte-doux);
  display: flex; align-items: flex-start; gap: 10px;
  line-height: 1.55;
  border-bottom: 1px solid var(--gris-bordure);
}
.tarif-details li:last-child { border-bottom: none; }
.tarif-details li::before {
  content: '';
  width: 16px; height: 16px; min-width: 16px;
  background: var(--orange-pale);
  color: var(--orange);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .7rem; font-weight: 800;
  background-image: linear-gradient(var(--orange-pale), var(--orange-pale)),
                    radial-gradient(circle, var(--orange) 50%, transparent 50%);
  background-size: 100% 100%, 8px 8px;
  background-position: center, center;
  background-repeat: no-repeat;
  margin-top: 2px;
}
.tarif-note {
  text-align: center; margin-top: 32px;
  color: var(--texte-doux); font-size: .9rem;
}
.tarif-note strong { color: var(--bleu); }

/* ─── 16. TÉMOIGNAGES ───────────────────────────────────────── */
.temoignages { background: var(--gris-clair); padding: 88px 48px; }
.temoignages-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: var(--max); margin: 0 auto;
}
.temoignage {
  padding: 32px 28px;
  position: relative;
}
.temoignage::before {
  content: '\201C';
  position: absolute; top: 6px; right: 18px;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 5rem;
  color: var(--bleu-pale);
  line-height: 1;
  pointer-events: none;
}
.stars { color: var(--orange); font-size: 1rem; margin-bottom: 14px; letter-spacing: 2px; }
.temoignage blockquote {
  font-family: 'Fraunces', Georgia, serif;
  font-size: .98rem; color: var(--texte);
  line-height: 1.65;
  font-style: italic;
  margin-bottom: 22px;
  position: relative; z-index: 1;
}
.temoignage-auteur { display: flex; align-items: center; gap: 12px; }
.avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--bleu-pale);
  color: var(--bleu);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 700;
  font-family: 'Fraunces', Georgia, serif;
  flex-shrink: 0;
}
.auteur-info strong { display: block; font-size: .92rem; color: var(--bleu); font-weight: 700; }
.auteur-info span { font-size: .82rem; color: var(--gris); }

/* ─── 17. ZONE ──────────────────────────────────────────────── */
.zone {
  background: var(--bleu-fonce);
  background-image:
    radial-gradient(ellipse 60% 80% at 80% 0%, rgba(35,88,140,.28) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 10% 100%, rgba(229,103,28,.10) 0%, transparent 55%);
  color: var(--blanc);
  padding: 80px 48px;
  text-align: left;
}
.zone > h3 {
  font-size: clamp(1.5rem, 2.4vw, 2rem);
  color: var(--blanc);
  margin-bottom: 14px;
}
.zone > p {
  color: rgba(255,255,255,.76);
  font-size: 1rem; line-height: 1.7;
  margin-bottom: 20px;
  max-width: 620px;
}
.zone > p strong { color: var(--blanc); font-weight: 600; }
.zone-sub { opacity: .82; margin-bottom: 28px; font-size: 1rem; }
.zone-label {
  font-size: .74rem;
  color: rgba(255,255,255,.6);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin: 24px 0 12px;
  display: block;
}
.villes {
  display: flex; flex-wrap: wrap; gap: 8px;
  max-width: 820px; margin: 0 auto 36px;
  justify-content: flex-start;
}
.ville-tag {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  padding: 7px 16px;
  border-radius: 999px;
  font-size: .85rem;
  color: rgba(255,255,255,.88);
}

.zone-cards {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  max-width: var(--max); margin: 32px auto 0;
}
.zone-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--r-l);
  padding: 24px 22px;
  box-shadow: none;
  color: var(--blanc);
}
.zone-card:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
  transform: translateY(-2px);
}
.zone-card h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.02rem; font-weight: 700;
  color: var(--blanc);
  margin-bottom: 6px;
  letter-spacing: -.01em;
}
.zone-card p {
  color: rgba(255,255,255,.66);
  font-size: .86rem;
  margin-bottom: 14px;
}
.zone-points {
  list-style: none; padding: 0;
  display: grid; gap: 7px;
}
.zone-points li {
  position: relative;
  padding-left: 14px;
  font-size: .85rem;
  color: rgba(255,255,255,.88);
  line-height: 1.5;
}
.zone-points li::before {
  content: '';
  position: absolute; left: 0; top: 9px;
  width: 5px; height: 5px;
  background: var(--orange);
  border-radius: 50%;
}

/* ─── 18. POURQUOI ──────────────────────────────────────────── */
.pourquoi { background: var(--blanc); padding: 88px 48px; }
.pourquoi-inner {
  max-width: 1000px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.pourquoi .avantage {
  display: flex; gap: 14px;
  margin-bottom: 22px;
  align-items: flex-start;
  background: transparent;
  box-shadow: none;
  border: none;
  padding: 0;
}
.pourquoi .avantage:hover { transform: none; box-shadow: none; }
.check {
  background: var(--orange);
  color: var(--blanc);
  border-radius: 50%;
  width: 28px; height: 28px; min-width: 28px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: .75rem;
  flex-shrink: 0; margin-top: 2px;
}
.pourquoi .avantage strong {
  display: block;
  font-family: 'Fraunces', Georgia, serif;
  color: var(--bleu); margin-bottom: 4px;
  font-size: 1rem;
  font-weight: 700;
}
.pourquoi .avantage p {
  color: var(--texte-doux); font-size: .92rem;
}
.pourquoi-box {
  background: var(--bleu);
  background-image: radial-gradient(ellipse 80% 100% at 100% 0%, rgba(35,88,140,.30), transparent 60%);
  border-radius: var(--r-l);
  padding: 44px 36px;
  text-align: center;
  color: var(--blanc);
}
.pourquoi-box .big { font-size: 3.2rem; margin-bottom: 14px; display: block; }
.pourquoi-box h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.35rem; font-weight: 700;
  color: var(--blanc);
  margin-bottom: 12px;
}
.pourquoi-box p {
  color: rgba(255,255,255,.78); font-size: .94rem;
  margin-bottom: 24px;
}
.pourquoi-box a {
  background: var(--orange); color: var(--blanc);
  padding: 13px 26px; border-radius: var(--r-s);
  font-weight: 700; display: inline-block;
  text-decoration: none;
  transition: background var(--t-fast);
}
.pourquoi-box a:hover { background: var(--orange-fonce); }

/* ─── 19. CONTACT / FORM ────────────────────────────────────── */
.contact { background: var(--gris-clair); padding: 88px 48px; }
.contact-inner {
  max-width: 1000px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.4fr;
  gap: 56px; align-items: start;
}
.contact-info h3 {
  font-size: clamp(1.5rem, 2.2vw, 1.9rem);
  color: var(--bleu);
  margin-bottom: 16px;
  font-weight: 700;
}
.contact-info p {
  color: var(--texte-doux);
  font-size: .98rem;
  margin-bottom: 32px;
}
.info-bloc { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.info-ico {
  width: 44px; height: 44px;
  background: var(--bleu-pale);
  color: var(--bleu);
  border-radius: var(--r-s);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.info-bloc strong {
  display: block; color: var(--bleu);
  font-size: .76rem; text-transform: uppercase;
  letter-spacing: .08em; margin-bottom: 3px;
  font-weight: 700;
}
.info-bloc a,
.info-bloc span {
  color: var(--texte); font-size: .98rem; font-weight: 600;
  text-decoration: none;
}
.info-bloc a:hover { color: var(--orange); }

form {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--r-l);
  padding: 36px;
  box-shadow: var(--shadow-m);
  display: flex; flex-direction: column; gap: 14px;
}
form h4 {
  font-family: 'Fraunces', Georgia, serif;
  color: var(--bleu);
  font-size: 1.2rem; font-weight: 700;
  margin-bottom: 6px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
form input,
form select,
form textarea {
  padding: 13px 16px;
  border: 1.5px solid var(--gris-bordure);
  border-radius: var(--r-s);
  font-size: .95rem;
  font-family: inherit;
  color: var(--texte);
  background: var(--blanc);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
form input:focus,
form select:focus,
form textarea:focus {
  outline: none;
  border-color: var(--bleu-clair);
  box-shadow: 0 0 0 3px rgba(35,88,140,.15);
}
form textarea { min-height: 110px; resize: vertical; }
form button {
  background: var(--orange); color: var(--blanc);
  border: none; padding: 15px;
  border-radius: var(--r-s);
  font-size: 1rem; font-weight: 700;
  cursor: pointer; font-family: inherit;
  transition: background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
  box-shadow: 0 8px 20px rgba(229,103,28,.22);
}
form button:hover {
  background: var(--orange-fonce);
  transform: translateY(-1px);
  box-shadow: 0 12px 26px rgba(229,103,28,.28);
}

/* ─── 20. FAQ ───────────────────────────────────────────────── */
.faq {
  background: var(--blanc);
  padding: 80px 48px;
}
.faq-inner,
.faq-list {
  max-width: 820px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 10px;
}
.faq-item {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--r-m);
  overflow: hidden;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.faq-item:hover { border-color: #D3DEEA; }
.faq-item.open {
  border-color: var(--bleu-clair);
  box-shadow: var(--shadow-m);
}

.faq-q,
.faq-question {
  width: 100%; background: none; border: none;
  padding: 20px 24px;
  text-align: left;
  font-family: inherit;
  font-size: .98rem; font-weight: 600;
  color: var(--bleu);
  cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
}
.faq-question { font-weight: 700; }
.faq-q:hover,
.faq-question:hover { background: var(--gris-clair); }

.faq-icon,
.faq-chevron {
  font-size: 1.15rem;
  color: var(--orange);
  flex-shrink: 0;
  transition: transform var(--t-med);
}
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-item.open .faq-chevron { transform: rotate(180deg); }

.faq-a,
.faq-reponse {
  max-height: 0; overflow: hidden;
  transition: max-height .4s ease, padding .3s ease;
}
.faq-a p {
  padding: 0 24px 22px;
  font-size: .94rem; color: var(--texte-doux);
  line-height: 1.75;
}
.faq-reponse {
  padding: 0 24px;
  color: var(--texte-doux);
  font-size: .94rem;
  line-height: 1.75;
}
.faq-item.open .faq-a { max-height: 480px; }
.faq-item.open .faq-a p { padding: 0 24px 22px; }
.faq-item.open .faq-reponse { max-height: 480px; padding: 0 24px 22px; }

/* ─── 21. PAGE BODY SERVICE ─────────────────────────────────── */
.page-body {
  max-width: 1120px; margin: 0 auto;
  padding: 64px 48px;
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 52px;
  align-items: start;
}
.main-content h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.4rem; font-weight: 700;
  color: var(--bleu);
  margin: 36px 0 14px;
  letter-spacing: -.01em;
}
.main-content h3:first-child { margin-top: 0; }
.main-content p {
  color: var(--texte);
  margin-bottom: 14px;
  font-size: 1rem;
  line-height: 1.78;
}

.check-list {
  list-style: none; margin: 0 0 22px;
  display: flex; flex-direction: column; gap: 10px;
}
.check-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: .98rem; color: var(--texte);
}
.check-list li::before {
  content: '\2713';
  background: var(--orange);
  color: var(--blanc);
  border-radius: 50%;
  width: 22px; height: 22px; min-width: 22px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: .72rem;
  margin-top: 2px;
}
.bullet-list { margin: 0 0 20px 20px; }
.bullet-list li {
  color: var(--texte); font-size: .98rem;
  margin-bottom: 8px; line-height: 1.7;
}
.bullet-list li::marker { color: var(--orange); }

.info-banner {
  background: var(--bleu-pale);
  border-left: 3px solid var(--orange);
  border-radius: 0 var(--r-s) var(--r-s) 0;
  padding: 16px 20px;
  margin: 20px 0;
  font-size: .94rem; color: var(--texte-doux);
  line-height: 1.7;
}
.info-banner strong { color: var(--bleu); }

/* ─── 22. SIDEBAR ───────────────────────────────────────────── */
.sidebar {
  display: flex; flex-direction: column; gap: 18px;
  position: sticky; top: 96px;
}
.card-devis {
  background: var(--bleu);
  color: var(--blanc);
  border: none !important;
  box-shadow: var(--shadow-l);
  border-radius: var(--r-l);
  padding: 30px 26px;
  text-align: center;
}
.card-devis h4 {
  font-size: 1.15rem; font-weight: 700;
  color: var(--blanc);
  margin-bottom: 10px;
}
.card-devis p {
  font-size: .88rem;
  color: rgba(255,255,255,.78);
  margin-bottom: 20px;
}
.card-devis .btn-primary {
  display: flex; width: 100%;
  text-align: center; margin-bottom: 14px;
}
.card-devis .tel-link {
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  color: rgba(255,255,255,.9);
  font-weight: 700; font-size: 1rem;
  text-decoration: none;
}
.card-devis .tel-link:hover { color: var(--blanc); }

.card-garanties {
  background: var(--blanc);
  border-radius: var(--r-l);
  padding: 24px 22px;
}
.card-garanties h4 {
  font-size: .78rem; font-weight: 700;
  color: var(--bleu);
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.garantie-item {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 11px;
  font-size: .89rem; color: var(--texte-doux);
}
.garantie-item:last-child { margin-bottom: 0; }

/* ─── 23. AVANTAGES ─────────────────────────────────────────── */
.avantages-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 18px; max-width: var(--max); margin: 0 auto;
}
.avantages-grid .avantage {
  padding: 28px 22px;
  text-align: center;
  border-bottom: 2px solid var(--orange);
}
.av-ico {
  font-size: 1.9rem;
  margin-bottom: 12px;
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 52px; height: 52px;
  background: var(--bleu-pale);
  border-radius: var(--r-s);
}
.avantages-grid .avantage h4 {
  font-family: 'Fraunces', Georgia, serif;
  color: var(--bleu);
  font-size: .98rem; font-weight: 700;
  margin-bottom: 8px;
}
.avantages-grid .avantage p {
  color: var(--texte-doux);
  font-size: .87rem;
  line-height: 1.65;
}

/* ─── 24. PRESTATIONS / BLOCS / SECTION FULL ────────────────── */
.section-full { padding: 72px 48px; }
.section-full.bg-gray { background: var(--gris-clair); }
.section-full.bg-white { background: var(--blanc); }
.prestations { background: var(--gris-clair); padding: 72px 48px; }
.prestations-inner { max-width: 1120px; margin: 0 auto; }

.cards-grid,
.presta-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1060px; margin: 0 auto;
}
.card,
.presta {
  padding: 30px 26px;
  text-align: center;
  position: relative;
}
.card-num {
  width: 44px; height: 44px;
  background: var(--orange); color: var(--blanc);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 700; font-size: 1.1rem;
  margin: 0 auto 16px;
}
.card-ico,
.presta .p-ico {
  width: 54px; height: 54px;
  background: var(--bleu-pale);
  border-radius: var(--r-s);
  font-size: 1.5rem;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.card h4,
.presta h4 {
  font-family: 'Fraunces', Georgia, serif;
  color: var(--bleu);
  font-size: 1.02rem;
  margin-bottom: 10px;
  font-weight: 700;
}
.card p,
.presta p {
  color: var(--texte-doux);
  font-size: .9rem; line-height: 1.65;
}

/* ─── 25. INFO CARDS ────────────────────────────────────────── */
.info-card {
  padding: 28px 24px;
}
.info-card h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: .88rem; font-weight: 700;
  color: var(--bleu);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--bleu-pale);
}
.info-card-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 8px 0;
  font-size: .9rem;
  color: var(--texte-doux);
  border-bottom: 1px solid var(--gris-bordure);
}
.info-card-row:last-child { border-bottom: none; }
.info-card-row a {
  color: var(--bleu-clair);
  font-size: .9rem;
  text-decoration: none;
}
.info-card-row a:hover { color: var(--orange); }

/* ─── 26. CTA FINAL ─────────────────────────────────────────── */
.cta-final {
  background: var(--gris-clair);
  padding: 80px 48px;
  text-align: center;
}
.cta-final h3 {
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  color: var(--bleu);
  margin-bottom: 14px;
  font-weight: 700;
  letter-spacing: -.015em;
}
.cta-final p {
  color: var(--texte-doux);
  margin-bottom: 32px;
  font-size: 1rem; max-width: 520px;
  margin-left: auto; margin-right: auto;
  line-height: 1.7;
}
.cta-btns {
  display: flex; gap: 12px;
  justify-content: center; flex-wrap: wrap;
}

/* ─── 27. SERVICE HERO SHELL (pages services premium) ───────── */
.service-hero-shell {
  max-width: var(--max); margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, .9fr);
  gap: 48px;
  align-items: center;
  position: relative; z-index: 1;
  text-align: left;
}
.service-hero-copy { text-align: left; }
.service-hero-copy .breadcrumb { margin-bottom: 14px; }
.service-hero-copy h2 { text-align: left; }
.service-hero-copy .sub {
  margin-left: 0; margin-right: 0;
  max-width: 560px;
}
.service-hero-copy .hero-btns { justify-content: flex-start; }

.service-kpis {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 42px;
  padding-top: 28px;
  border-top: 1px solid rgba(255,255,255,.12);
  gap: 16px;
}
.service-kpi { padding-right: 16px; border-right: 1px solid rgba(255,255,255,.12); }
.service-kpi:last-child { border-right: none; padding-right: 0; }
.service-kpi strong {
  display: block;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.05rem; font-weight: 700;
  color: var(--blanc);
  margin-bottom: 4px;
}
.service-kpi span {
  font-size: .82rem;
  color: rgba(255,255,255,.68);
  line-height: 1.5;
}

.service-visual {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, .7fr);
  gap: 14px;
  align-items: stretch;
}
.service-photo-main { display: grid; }
.service-photo-stack { display: grid; gap: 14px; }
.service-photo-card {
  position: relative; overflow: hidden;
  border-radius: var(--r-l);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 24px 50px rgba(6,18,31,.35);
  background: rgba(255,255,255,.08);
}
.service-photo-card img { width: 100%; height: 100%; object-fit: cover; }
.service-photo-card::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,29,53,0) 44%, rgba(10,29,53,.72) 100%);
}
.service-photo-main .service-photo-card { min-height: 460px; }
.service-photo-stack .service-photo-card { min-height: 218px; }
.service-photo-caption {
  position: absolute; left: 18px; right: 18px; bottom: 16px; z-index: 1;
}
.service-photo-caption strong {
  display: block; color: #fff;
  font-size: .92rem; margin-bottom: 4px; font-weight: 600;
}
.service-photo-caption span {
  display: block;
  color: rgba(255,255,255,.78);
  font-size: .78rem; line-height: 1.5;
}

/* ─── 28. SERVICE INTRO ─────────────────────────────────────── */
.service-intro { background: var(--blanc); padding: 72px 48px; }
.service-intro-shell {
  max-width: 1100px; margin: 0 auto;
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 48px; align-items: center;
}
.service-intro-copy { padding: 0; }
.service-intro-copy .eyebrow { margin-bottom: 14px; }
.service-intro-copy h3 {
  font-size: clamp(1.4rem, 2.2vw, 1.85rem);
  color: var(--bleu);
  margin-bottom: 16px;
  letter-spacing: -.015em;
}
.service-intro-copy p {
  color: var(--texte-doux);
  font-size: 1rem; line-height: 1.75;
  margin-bottom: 22px;
}
.service-intro-points { display: grid; gap: 14px; }
.service-intro-points > div {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 14px;
  align-items: baseline;
  font-size: .95rem;
  color: var(--texte-doux);
  line-height: 1.6;
}
.service-intro-points span {
  width: 30px; height: 30px;
  background: var(--orange-pale);
  color: var(--orange);
  border-radius: 50%;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 700; font-size: .95rem;
}
.service-intro-points strong { color: var(--bleu); font-weight: 700; }
.service-intro-visual .service-photo-card { min-height: 380px; }

/* ─── 29. FLOATING BUTTON ───────────────────────────────────── */
.btn-flottant {
  display: none;
  position: fixed;
  bottom: max(20px, env(safe-area-inset-bottom, 20px));
  left: 50%; transform: translateX(-50%);
  z-index: 999;
  background: var(--orange);
  color: var(--blanc);
  padding: 14px 28px;
  border-radius: var(--r-s);
  font-size: .95rem; font-weight: 700;
  text-decoration: none;
  box-shadow: 0 12px 26px rgba(229,103,28,.36);
  align-items: center; gap: 8px;
  white-space: nowrap;
}

/* ─── 30. COOKIE BANNER ─────────────────────────────────────── */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--bleu-fonce);
  color: rgba(255,255,255,.88);
  padding: 16px 28px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
  z-index: 1000;
  box-shadow: 0 -6px 20px rgba(0,0,0,.3);
  font-size: .88rem;
  border-top: 1px solid rgba(255,255,255,.06);
}
.cookie-banner p { flex: 1; min-width: 200px; margin: 0; }
.cookie-banner a { color: var(--orange); }
.cookie-btns { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-accept {
  background: var(--orange); color: var(--blanc);
  border: none; padding: 10px 22px;
  border-radius: var(--r-s);
  font-weight: 700; cursor: pointer;
  font-family: inherit; font-size: .88rem;
  transition: background var(--t-fast);
}
.cookie-accept:hover { background: var(--orange-fonce); }
.cookie-refuse {
  background: transparent;
  color: rgba(255,255,255,.68);
  border: 1px solid rgba(255,255,255,.2);
  padding: 10px 22px;
  border-radius: var(--r-s);
  font-weight: 600; cursor: pointer;
  font-family: inherit; font-size: .88rem;
  transition: background var(--t-fast);
}
.cookie-refuse:hover { background: rgba(255,255,255,.06); }

/* ─── 31. FOOTER PREMIUM (unique système) ───────────────────── */
.site-footer-premium,
footer.site-footer-premium {
  background: var(--bleu-fonce);
  background-image: radial-gradient(ellipse 60% 80% at 80% 0%, rgba(35,88,140,.18) 0%, transparent 60%);
  color: rgba(255,255,255,.8);
  padding: 0 32px 32px;
  width: 100%;
  clear: both;
  display: block;
}
.site-footer-premium .site-footer-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding-top: 56px;
}
.site-footer-premium .site-footer-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr .8fr;
  gap: 18px;
  align-items: stretch;
}
.site-footer-premium .site-footer-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--r-l);
  padding: 24px 22px;
}
.site-footer-premium .site-footer-brand {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 14px;
}
.site-footer-premium .site-footer-brand img {
  width: 54px; height: 54px;
  border-radius: 50%;
  object-fit: cover;
  background: #fff;
  border: 2px solid rgba(229,103,28,.28);
}
.site-footer-premium .site-footer-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.15rem; font-weight: 700;
  color: var(--blanc);
  letter-spacing: .01em;
}
.site-footer-premium .site-footer-text {
  font-size: .92rem;
  line-height: 1.7;
  color: rgba(255,255,255,.72);
  margin-top: 10px;
}
.site-footer-premium .site-footer-heading {
  font-family: 'Inter', sans-serif;
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,203,164,.92);
  margin: 0 0 14px;
  font-weight: 700;
}
.site-footer-premium .site-footer-links {
  display: flex; flex-direction: column; gap: 10px;
}
.site-footer-premium .site-footer-links a {
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-size: .9rem;
  transition: color var(--t-fast);
}
.site-footer-premium .site-footer-links a:hover { color: var(--orange); }

.site-footer-premium .site-footer-bottom {
  max-width: var(--max); margin: 20px auto 0;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex; justify-content: space-between;
  gap: 14px; flex-wrap: wrap;
  font-size: .8rem;
  color: rgba(255,255,255,.6);
}
.site-footer-premium .site-footer-bottom a {
  color: rgba(255,255,255,.78);
  text-decoration: underline dotted;
  text-underline-offset: 3px;
}
.site-footer-premium .site-footer-bottom a:hover { color: var(--orange); }

/* Legacy footer (si présent) — aligné visuellement */
body > footer:not(.site-footer-premium) {
  background: var(--bleu-fonce);
  color: rgba(255,255,255,.7);
  padding: 48px 32px 32px;
  display: flex; flex-direction: column; align-items: center; gap: 22px;
}
.footer-top {
  width: 100%; max-width: var(--max);
  display: flex; justify-content: space-between;
  align-items: center; flex-wrap: wrap; gap: 16px;
}
.footer-brand strong {
  color: var(--blanc); display: block;
  margin-bottom: 4px; font-family: 'Fraunces', Georgia, serif;
  font-weight: 700;
}
.footer-brand span { font-size: .84rem; line-height: 1.6; }
.footer-links {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-size: .82rem;
}
.footer-links a {
  color: rgba(255,255,255,.68);
  text-decoration: none;
  transition: color var(--t-fast);
}
.footer-links a:hover { color: var(--orange); }
.footer-bottom { font-size: .8rem; opacity: .5; }
.footer-payments {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap; justify-content: center;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  width: 100%; max-width: var(--max);
}
.footer-payments span {
  font-size: .76rem; color: rgba(255,255,255,.48);
  margin-right: 4px;
}
.pay-badge {
  display: flex; align-items: center; gap: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-s);
  padding: 6px 12px;
  font-size: .76rem;
  color: rgba(255,255,255,.72);
}

/* ─── 32. ANIMATIONS ────────────────────────────────────────── */
.anim-hidden {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .5s cubic-bezier(.4,0,.2,1), transform .5s cubic-bezier(.4,0,.2,1);
}
.anim-hidden.visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .anim-hidden { opacity: 1; transform: none; transition: none; }
}

/* Utilitaire tap */
a, button, [role="button"], input[type="submit"], input[type="button"] {
  touch-action: manipulation;
}

/* ─── 33. RESPONSIVE ────────────────────────────────────────── */

/* tablette - 900 */
@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero-content { padding: 60px 28px 56px; }
  .service-hero-shell { grid-template-columns: 1fr; gap: 28px; }
  .service-visual { grid-template-columns: minmax(0, 1fr) minmax(140px, .7fr); }
  .service-photo-main .service-photo-card { min-height: 320px; }
  .page-body { grid-template-columns: 1fr; gap: 36px; padding: 44px 24px; }
  .sidebar { position: static; }
  .services-grid,
  .idx-services-grid { grid-template-columns: repeat(2, 1fr); }
  .tarifs-grid,
  .idx-tarifs-grid,
  .temoignages-grid { grid-template-columns: 1fr; }
  .pourquoi-inner,
  .contact-inner { grid-template-columns: 1fr; gap: 40px; }
  .service-intro-shell { grid-template-columns: 1fr; gap: 32px; }
  .zone-cards { grid-template-columns: repeat(2, 1fr); }
  .stats-band .stat { padding: 18px 24px; border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); width: 50%; }
  .avantages-grid { grid-template-columns: repeat(2, 1fr); }
  .services,
  .tarifs,
  .temoignages,
  .pourquoi,
  .contact,
  .faq,
  .zone,
  .cta-final,
  .section-full,
  .prestations,
  .service-intro { padding: 56px 24px; }
  .hero-service { padding: 56px 24px 48px; }
}

/* mobile - 768 */
@media (max-width: 768px) {
  header {
    padding: 0 16px;
    height: 64px;
  }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .nav-overlay { top: 64px; }
  .hero-content { padding: 44px 20px 44px; text-align: center; }
  .hero h2 { font-size: 1.95rem; line-height: 1.15; }
  .hero-desc { font-size: .96rem; margin-left: auto; margin-right: auto; }
  .hero-tag { margin-bottom: 14px; }
  .hero-btns { justify-content: center; gap: 10px; }
  .hero-btns a { flex: 1; min-width: 160px; max-width: 260px; }
  .hero-stats { max-width: 100%; grid-template-columns: repeat(3, 1fr); margin-top: 32px; padding-top: 20px; }
  .hero-stats .stat { padding: 0 10px; text-align: center; align-items: center; }
  .hero-stats .stat strong { font-size: 1.4rem; }
  .hero-stats .stat span { font-size: .64rem; }
  .hero-service { padding: 44px 20px 40px; }
  .hero-service h2 { font-size: 1.75rem; line-height: 1.2; }
  .hero-service .sub { font-size: .98rem; margin-bottom: 24px; }
  .hero-btns { flex-direction: column; align-items: center; gap: 10px; }
  .hero-btns a { width: 100%; max-width: 320px; padding: 14px 20px; font-size: .95rem; min-height: 48px; }
  .cta-btns { flex-direction: column; align-items: center; gap: 10px; }
  .cta-btns a { width: 100%; max-width: 320px; padding: 14px 20px; }
  .trust-bar,
  .arguments {
    padding: 16px 14px;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    scrollbar-width: none;
  }
  .trust-bar::-webkit-scrollbar,
  .arguments::-webkit-scrollbar { display: none; }
  .trust-item,
  .argument { flex: 0 0 auto; padding: 8px 14px; font-size: .82rem; }
  .stats-band .stat { width: 50%; padding: 16px 14px; border-right: 1px solid rgba(255,255,255,.08); }
  .stats-band .stat:nth-child(2n) { border-right: none; }
  .services,
  .tarifs,
  .temoignages,
  .pourquoi,
  .contact,
  .faq,
  .zone,
  .cta-final,
  .section-full,
  .prestations,
  .service-intro { padding: 48px 18px; }
  .hero-service { padding: 44px 20px 40px; }
  .section-title,
  .section-header { margin-bottom: 30px; }
  .services-grid,
  .idx-services-grid { grid-template-columns: 1fr; gap: 14px; }
  .cards-grid,
  .presta-grid { grid-template-columns: 1fr; gap: 14px; }
  .avantages-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .zone-cards { grid-template-columns: 1fr; gap: 12px; }
  .service-card,
  .svc-card,
  .tarif-card,
  .temoignage,
  .zone-card,
  .info-card { padding: 22px 18px; }
  .form-row { grid-template-columns: 1fr; gap: 10px; }
  form { padding: 24px 18px; }
  .faq-q,
  .faq-question { padding: 18px 18px; font-size: .94rem; }
  .faq-a p,
  .faq-reponse { font-size: .92rem; line-height: 1.72; }
  .villes { gap: 8px; justify-content: flex-start; }
  .ville-tag { font-size: .82rem; padding: 6px 13px; }
  .zone > h3 { font-size: 1.6rem; text-align: left; }
  .zone > p { font-size: .95rem; text-align: left; }
  .zone { text-align: left; padding: 52px 20px; }
  .zone .btn-primary { width: 100%; max-width: 320px; }
  .service-kpis { grid-template-columns: 1fr; gap: 10px; padding-top: 20px; margin-top: 28px; }
  .service-kpi { padding-right: 0; border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); padding-bottom: 10px; }
  .service-kpi:last-child { border-bottom: none; }
  .service-visual { grid-template-columns: 1fr; }
  .service-photo-stack { grid-template-columns: repeat(2, 1fr); }
  .service-photo-stack .service-photo-card { min-height: 180px; }
  .service-photo-main .service-photo-card { min-height: 260px; }
  .btn-flottant { display: flex; width: calc(100% - 28px); max-width: 360px; padding: 14px 24px; font-size: .95rem; }
  .cookie-banner { padding: 14px 16px; }
  .cookie-banner p { font-size: .84rem; }
  .site-footer-premium { padding: 0 16px 28px; }
  .site-footer-premium .site-footer-grid { grid-template-columns: 1fr; }
  .site-footer-premium .site-footer-card { padding: 20px; }
  .site-footer-premium .site-footer-bottom { flex-direction: column; align-items: flex-start; }
  body > footer:not(.site-footer-premium) { padding: 36px 20px 28px; }
  .footer-top { flex-direction: column; text-align: center; gap: 14px; }
  .footer-links { justify-content: center; }

  /* Gros input/textarea anti-zoom iOS */
  input, select, textarea,
  form input, form select, form textarea { font-size: 16px !important; }

  /* Accessibilité touch */
  .btn-tel, .btn-primary, .btn-outline-light, .btn-outline-dark, .btn-secondary,
  .cookie-accept, .cookie-refuse, .hamburger,
  .faq-q, .faq-question { min-height: 44px; }

  h1, h2, h3, h4, p, li, .ville-tag {
    word-break: break-word;
    overflow-wrap: break-word;
  }
  body { background: var(--gris-clair); }
}

/* petit mobile - 480 */
@media (max-width: 480px) {
  header { padding: 0 14px; height: 58px; }
  .site-logo-img { width: 42px !important; height: 42px !important; }
  .nav-overlay { top: 58px; }
  .hero-content { padding: 36px 16px 36px; }
  .hero h2 { font-size: 1.6rem; }
  .hero-desc { font-size: .9rem; }
  .hero-stats { grid-template-columns: 1fr; gap: 14px; max-width: 240px; margin: 28px auto 0; }
  .hero-stats .stat { border-right: none; padding: 0; }
  .hero-service h2 { font-size: 1.5rem; }
  .section-title h3,
  .section-header h3,
  .cta-final h3,
  .zone > h3 { font-size: 1.4rem !important; }
  .temoignage,
  .service-card,
  .svc-card,
  .tarif-card,
  .zone-card,
  .info-card,
  .card,
  .presta { padding: 20px 16px; }
  .prix { font-size: 1.7rem; }
  .services,
  .tarifs,
  .temoignages,
  .pourquoi,
  .contact,
  .faq,
  .zone,
  .cta-final,
  .section-full,
  .prestations,
  .service-intro,
  .hero-service { padding-left: 14px; padding-right: 14px; }
  form { padding: 20px 16px; }
  .avantages-grid { grid-template-columns: 1fr; }
  .site-footer-premium { padding: 0 14px 24px; }
  .site-footer-premium .site-footer-inner { padding-top: 40px; }
  .site-footer-premium .site-footer-card { padding: 18px 16px; }
}

/* =============================================================
   34. PREMIUM EXTENSIONS — animations, hover, gradients
   Ajouts non destructifs pour un rendu plus haut de gamme.
   ============================================================= */

/* ─── 34.1 Animations d'apparition (révélations) ───────────── */
.reveal-up,
.reveal-left,
.reveal-right,
.reveal-zoom,
.reveal-fade {
  opacity: 0;
  transition:
    opacity .8s cubic-bezier(.22,1,.36,1),
    transform .8s cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform;
}
.reveal-up    { transform: translateY(28px); }
.reveal-left  { transform: translateX(-28px); }
.reveal-right { transform: translateX(28px); }
.reveal-zoom  { transform: scale(.94); }

.reveal-up.is-visible,
.reveal-left.is-visible,
.reveal-right.is-visible,
.reveal-zoom.is-visible,
.reveal-fade.is-visible {
  opacity: 1;
  transform: none;
}

/* Stagger : applique des delays progressifs aux enfants */
.stagger > *           { transition-delay: 0s; }
.stagger > *:nth-child(1) { transition-delay: .05s; }
.stagger > *:nth-child(2) { transition-delay: .12s; }
.stagger > *:nth-child(3) { transition-delay: .19s; }
.stagger > *:nth-child(4) { transition-delay: .26s; }
.stagger > *:nth-child(5) { transition-delay: .33s; }
.stagger > *:nth-child(6) { transition-delay: .40s; }
.stagger > *:nth-child(7) { transition-delay: .47s; }
.stagger > *:nth-child(8) { transition-delay: .54s; }

@media (prefers-reduced-motion: reduce) {
  .reveal-up, .reveal-left, .reveal-right, .reveal-zoom, .reveal-fade {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* ─── 34.2 Effet Ken Burns ultra-subtil pour images de hero ── */
@keyframes kenBurns {
  0%   { transform: scale(1)    translate(0,0); }
  100% { transform: scale(1.06) translate(-1.5%, -1%); }
}
.kb-img,
.hero-photo-card.kb-img img,
.service-photo-card.kb-img img {
  animation: kenBurns 16s ease-in-out infinite alternate;
}

/* ─── 34.3 Lignes décoratives (séparateurs élégants) ───────── */
.divider-grad {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(15,39,68,.18), transparent);
  margin: 0 auto;
  max-width: 320px;
}
.divider-orange {
  width: 56px; height: 3px; border-radius: 2px;
  background: linear-gradient(90deg, var(--orange), var(--orange-fonce));
  margin: 14px auto 0;
}

/* ─── 34.4 Hover : élévation cards + glow d'accent ─────────── */
.card,
.service-card,
.svc-card,
.tarif-card,
.zone-card,
.suisse-offer,
.suisse-swisscard,
.suisse-audience,
.suisse-step,
.suisse-faq-item,
.ch-card,
.ch-step {
  position: relative;
  overflow: hidden;
}
.card::after,
.service-card::after,
.tarif-card::after,
.suisse-offer::after,
.suisse-swisscard::after,
.suisse-audience::after,
.suisse-step::after,
.ch-card::after,
.ch-step::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(229,103,28,.08), transparent 55%);
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease;
  z-index: 0;
}
.card:hover::after,
.service-card:hover::after,
.tarif-card:hover::after,
.suisse-offer:hover::after,
.suisse-swisscard:hover::after,
.suisse-audience:hover::after,
.suisse-step:hover::after,
.ch-card:hover::after,
.ch-step:hover::after { opacity: 1; }

/* ─── 34.5 Boutons : effet "shine" au survol ──────────────── */
.btn-primary,
.btn-outline-light,
.btn-outline-dark,
.btn-secondary,
.btn-tel {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.btn-primary::before,
.btn-outline-light::before,
.btn-outline-dark::before,
.btn-tel::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
  transform: translateX(-110%);
  transition: transform .65s cubic-bezier(.22,1,.36,1);
  z-index: -1;
  pointer-events: none;
}
.btn-primary:hover::before,
.btn-outline-light:hover::before,
.btn-outline-dark:hover::before,
.btn-tel:hover::before { transform: translateX(110%); }

/* ─── 34.6 Liens "fléchés" (read more) ─────────────────────── */
.link-arrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-weight: 700; color: var(--orange);
  font-size: .92rem;
  transition: gap var(--t-fast), color var(--t-fast);
}
.link-arrow::after {
  content: "→";
  display: inline-block;
  transition: transform var(--t-fast);
}
.link-arrow:hover { gap: 12px; color: var(--orange-fonce); }
.link-arrow:hover::after { transform: translateX(2px); }

/* ─── 34.7 Section "stat band" alternative claire ──────────── */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  max-width: var(--max);
  margin: 0 auto;
  padding: 36px 24px;
}
.kpi-strip .kpi-item {
  background: var(--blanc);
  border: 1px solid var(--gris-bordure);
  border-radius: var(--r-l);
  padding: 22px 20px;
  box-shadow: var(--shadow-s);
  text-align: left;
  transition: transform var(--t-med), box-shadow var(--t-med);
}
.kpi-strip .kpi-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-m);
}
.kpi-strip .kpi-num {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.95rem; font-weight: 700;
  color: var(--bleu);
  line-height: 1; margin-bottom: 6px;
  letter-spacing: -.02em;
}
.kpi-strip .kpi-num em {
  font-style: normal;
  color: var(--orange);
}
.kpi-strip .kpi-label {
  font-size: .82rem;
  color: var(--texte-doux);
  line-height: 1.55;
}
@media (max-width: 900px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); padding: 24px 16px; gap: 12px; }
}
@media (max-width: 480px) {
  .kpi-strip { grid-template-columns: 1fr; }
}

/* ─── 34.8 Image hover zoom (galeries) ─────────────────────── */
.img-zoom {
  overflow: hidden;
  border-radius: var(--r-l);
  position: relative;
}
.img-zoom img {
  transition: transform .8s cubic-bezier(.22,1,.36,1);
}
.img-zoom:hover img {
  transform: scale(1.06);
}

/* ─── 34.9 Floating "particles" ambiance hero ──────────────── */
.float-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  z-index: 0;
}
.float-orb.orb-orange {
  background: radial-gradient(circle, rgba(229,103,28,.36), transparent 70%);
}
.float-orb.orb-blue {
  background: radial-gradient(circle, rgba(35,88,140,.40), transparent 70%);
}
@keyframes orbFloat1 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(20px,-30px); } }
@keyframes orbFloat2 { 0%,100% { transform: translate(0,0); } 50% { transform: translate(-25px,18px); } }
.float-orb.f1 { animation: orbFloat1 14s ease-in-out infinite; }
.float-orb.f2 { animation: orbFloat2 18s ease-in-out infinite; }

/* ─── 34.10 Scroll indicator subtil dans hero ──────────────── */
.scroll-hint {
  position: absolute;
  bottom: 24px; left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.55);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: flex; flex-direction: column;
  align-items: center; gap: 8px;
  z-index: 2;
}
.scroll-hint::after {
  content: "";
  width: 1px; height: 36px;
  background: linear-gradient(180deg, rgba(255,255,255,.6), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%   { opacity: 0; transform: scaleY(.3); transform-origin: top; }
  50%  { opacity: 1; transform: scaleY(1);  transform-origin: top; }
  100% { opacity: 0; transform: scaleY(.3); transform-origin: bottom; }
}
@media (max-width: 768px) { .scroll-hint { display: none; } }

/* ─── 34.11 Header "scrolled" — un peu plus dense ──────────── */
header.is-scrolled {
  height: 64px;
  box-shadow: 0 2px 0 rgba(255,255,255,.04), 0 14px 32px rgba(10,29,53,.28);
  background: rgba(15,39,68,.96);
  backdrop-filter: saturate(1.2) blur(8px);
}
header.is-scrolled .site-logo-img {
  width: 40px !important; height: 40px !important;
}

/* ─── 34.12 Pages SUISSE — extensions premium ──────────────── */
.suisse-cover-photo {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  min-height: 460px;
  box-shadow: 0 26px 50px rgba(6,18,31,.32);
  border: 1px solid rgba(255,255,255,.10);
}
.suisse-cover-photo img {
  width: 100%; height: 100%;
  object-fit: cover; position: absolute; inset: 0;
}
.suisse-cover-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,29,53,0) 30%, rgba(10,29,53,.78) 100%);
}
.suisse-cover-overlay {
  position: absolute; left: 24px; right: 24px; bottom: 22px;
  z-index: 2; color: #fff;
}
.suisse-cover-overlay .pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  margin-bottom: 12px;
}
.suisse-cover-overlay h3 {
  color: #fff; font-size: 1.35rem;
  font-weight: 700; line-height: 1.2;
}

/* Galerie d'images responsive façon mosaïque */
.suisse-gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 180px;
  gap: 12px;
}
.suisse-gallery .gimg {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid #e6ecf2;
  background: #f4f7fb;
}
.suisse-gallery .gimg img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.22,1,.36,1);
}
.suisse-gallery .gimg:hover img { transform: scale(1.07); }
.suisse-gallery .gimg.tall { grid-row: span 2; }
.suisse-gallery .gimg.wide { grid-column: span 2; }
@media (max-width: 900px) {
  .suisse-gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .suisse-gallery .gimg.tall { grid-row: span 1; }
  .suisse-gallery .gimg.wide { grid-column: span 2; }
}

/* Carte tarif Suisse (CHF) */
.ch-pricing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1100px;
  margin: 0 auto;
}
.ch-pricing .ch-price {
  background: #fff;
  border: 1px solid #e2ebf2;
  border-radius: 24px;
  padding: 32px 28px;
  box-shadow: 0 14px 30px rgba(26,60,94,.07);
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  transition: transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s, border-color .35s;
}
.ch-pricing .ch-price:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(26,60,94,.12);
  border-color: #c9d8e6;
}
.ch-pricing .ch-price.featured {
  background: linear-gradient(180deg, #143452 0%, #0e2945 100%);
  color: #fff;
  border-color: transparent;
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(15,34,55,.24);
}
.ch-pricing .ch-price.featured::before {
  content: "Le plus demandé";
  position: absolute; top: 16px; right: 16px;
  background: var(--orange);
  color: #fff; font-size: .7rem;
  font-weight: 800; letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 12px; border-radius: 999px;
  box-shadow: 0 6px 16px rgba(229,103,28,.36);
}
.ch-price h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.15rem; font-weight: 700;
  color: var(--bleu); margin-bottom: 6px;
}
.ch-price.featured h3 { color: #fff; }
.ch-price .ch-price-sub {
  color: var(--texte-doux);
  font-size: .88rem; line-height: 1.6;
  margin-bottom: 22px;
}
.ch-price.featured .ch-price-sub { color: rgba(255,255,255,.78); }
.ch-price .ch-price-amount {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 2.4rem; font-weight: 700;
  color: var(--bleu); line-height: 1;
  display: flex; align-items: baseline; gap: 6px;
  letter-spacing: -.02em;
}
.ch-price.featured .ch-price-amount { color: #fff; }
.ch-price .ch-price-amount small {
  font-family: 'Inter', sans-serif;
  font-size: .82rem; font-weight: 600;
  color: var(--gris);
}
.ch-price.featured .ch-price-amount small { color: rgba(255,255,255,.65); }
.ch-price .ch-price-from {
  font-size: .78rem; color: var(--gris);
  margin-bottom: 22px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.ch-price.featured .ch-price-from { color: rgba(255,255,255,.6); }
.ch-price ul {
  list-style: none; margin: 0 0 26px;
  display: flex; flex-direction: column; gap: 10px;
  flex: 1;
}
.ch-price li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: .92rem; color: var(--texte-doux);
  line-height: 1.55;
}
.ch-price.featured li { color: rgba(255,255,255,.84); }
.ch-price li::before {
  content: "✓";
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; min-width: 20px;
  background: var(--orange-pale); color: var(--orange);
  border-radius: 50%; font-weight: 700; font-size: .72rem;
  margin-top: 2px;
}
.ch-price.featured li::before {
  background: rgba(229,103,28,.22);
  color: #FFCBA4;
}
.ch-price .btn-primary,
.ch-price .btn-outline-dark {
  width: 100%; justify-content: center;
}
.ch-price.featured .btn-outline-dark {
  background: transparent; color: #fff;
  border-color: rgba(255,255,255,.4);
}
.ch-price.featured .btn-outline-dark:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.7);
}
@media (max-width: 900px) {
  .ch-pricing { grid-template-columns: 1fr; }
  .ch-pricing .ch-price.featured { transform: none; }
}

/* Section "process" image-driven */
.ch-process-illustrated {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 56px;
  align-items: center;
  max-width: 1100px;
  margin: 0 auto;
}
.ch-process-illustrated .ch-process-img {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  min-height: 460px;
  box-shadow: 0 22px 44px rgba(15,34,55,.18);
}
.ch-process-illustrated .ch-process-img img {
  width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0;
}
.ch-process-illustrated .ch-process-img::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,39,68,.0), rgba(15,39,68,.32));
}
.ch-process-illustrated .ch-process-list {
  display: flex; flex-direction: column; gap: 16px;
}
.ch-process-illustrated .ch-process-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px; align-items: flex-start;
  padding: 18px 0;
  border-bottom: 1px solid #e6ecf2;
}
.ch-process-illustrated .ch-process-item:last-child { border-bottom: none; }
.ch-process-illustrated .ch-process-num {
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #fff2e8, #ffd9bd);
  color: var(--orange);
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 700; font-size: 1.15rem;
  border-radius: 14px;
}
.ch-process-illustrated .ch-process-item h4 {
  color: var(--bleu);
  font-size: 1.08rem; font-weight: 700;
  margin-bottom: 4px;
  font-family: 'Fraunces', Georgia, serif;
}
.ch-process-illustrated .ch-process-item p {
  color: var(--texte-doux);
  font-size: .94rem; line-height: 1.65;
}
@media (max-width: 900px) {
  .ch-process-illustrated { grid-template-columns: 1fr; gap: 28px; }
  .ch-process-illustrated .ch-process-img { min-height: 280px; }
}

/* Témoignage Suisse "premium" */
.ch-testimonials {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px;
  max-width: 1100px; margin: 0 auto;
}
.ch-testimonial {
  background: #fff;
  border: 1px solid #e2ebf2;
  border-radius: 22px;
  padding: 26px 24px;
  box-shadow: 0 12px 26px rgba(26,60,94,.06);
  position: relative;
  transition: transform var(--t-med), box-shadow var(--t-med);
}
.ch-testimonial:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(26,60,94,.12);
}
.ch-testimonial .stars { color: var(--orange); margin-bottom: 12px; letter-spacing: 2px; }
.ch-testimonial blockquote {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 1rem; line-height: 1.7;
  color: var(--texte);
  margin-bottom: 18px;
}
.ch-testimonial-author {
  display: flex; align-items: center; gap: 12px;
}
.ch-testimonial-author .avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ffd9bd, #ffb380);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 700; font-size: 1rem;
}
.ch-testimonial-author strong {
  display: block; color: var(--bleu);
  font-weight: 700; font-size: .94rem;
}
.ch-testimonial-author span {
  font-size: .82rem; color: var(--gris);
}
@media (max-width: 900px) {
  .ch-testimonials { grid-template-columns: 1fr; }
}

/* CTA bandeau riche Suisse */
.ch-cta-rich {
  position: relative;
  border-radius: 32px;
  overflow: hidden;
  padding: 48px 40px;
  background: linear-gradient(135deg, #0a1d35 0%, #143b5e 60%, #235a8a 100%);
  color: #fff;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(280px, .7fr);
  gap: 36px;
  align-items: center;
  box-shadow: 0 26px 60px rgba(15,34,55,.25);
}
.ch-cta-rich::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 90% 10%, rgba(229,103,28,.28), transparent 40%),
    radial-gradient(circle at 5% 90%, rgba(35,88,140,.4), transparent 40%);
  pointer-events: none;
}
.ch-cta-rich > * { position: relative; z-index: 1; }
.ch-cta-rich h2 {
  color: #fff;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  margin-bottom: 14px;
}
.ch-cta-rich p {
  color: rgba(255,255,255,.82);
  line-height: 1.7;
  font-size: 1rem;
  margin-bottom: 24px;
  max-width: 580px;
}
.ch-cta-rich .ch-cta-card-inner {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 22px;
  padding: 24px;
  backdrop-filter: blur(12px);
}
.ch-cta-rich .ch-cta-card-inner strong {
  display: block;
  font-family: 'Fraunces', Georgia, serif;
  color: #fff; font-size: 1.05rem;
  margin-bottom: 14px;
}
.ch-cta-rich .ch-cta-card-inner .tel-big {
  display: block;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.65rem; color: #FFCBA4;
  font-weight: 700; margin-bottom: 6px;
}
.ch-cta-rich .ch-cta-card-inner .small-mail {
  color: rgba(255,255,255,.7);
  font-size: .88rem; margin-bottom: 14px;
  display: block;
}
@media (max-width: 900px) {
  .ch-cta-rich {
    grid-template-columns: 1fr;
    padding: 32px 24px;
  }
}

/* ─── 34.13 Footer : amélioration sociale + contact direct ── */
.site-footer-premium .site-footer-card.footer-cta {
  background: linear-gradient(135deg, rgba(229,103,28,.18), rgba(229,103,28,.04));
  border-color: rgba(229,103,28,.28);
}
.site-footer-premium .footer-cta strong {
  display: block;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 1.05rem;
  color: #fff;
  margin-bottom: 8px;
}
.site-footer-premium .footer-cta a.tel {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--orange);
  color: #fff;
  padding: 10px 16px;
  border-radius: var(--r-s);
  font-weight: 700;
  font-size: .92rem;
  margin-top: 8px;
  transition: background var(--t-fast), transform var(--t-fast);
}
.site-footer-premium .footer-cta a.tel:hover {
  background: var(--orange-fonce);
  transform: translateY(-1px);
}

/* ─── 34.14 Compteur animé (helper) ────────────────────────── */
.count-up { font-variant-numeric: tabular-nums; }

/* ─── 34.15 Image avec effet glissière dans coin de hero ──── */
.hero-photo-card,
.service-photo-card,
.suisse-cover-photo,
.ch-process-illustrated .ch-process-img {
  transform: translateZ(0);
}
.hero-photo-card img,
.service-photo-card img {
  transition: transform 1.4s cubic-bezier(.22,1,.36,1);
}
.hero-photo-card:hover img,
.service-photo-card:hover img {
  transform: scale(1.04);
}

/* ─── 34.16 Map de la Suisse (SVG container) ───────────────── */
.swiss-map {
  position: relative;
  background: linear-gradient(180deg, #f7faff 0%, #eef4fa 100%);
  border-radius: 24px;
  padding: 28px;
  border: 1px solid #dbe6f0;
  box-shadow: 0 14px 30px rgba(26,60,94,.08);
}
.swiss-map h3 {
  color: var(--bleu);
  font-size: 1.15rem; font-weight: 700;
  margin-bottom: 14px;
  font-family: 'Fraunces', Georgia, serif;
}
.swiss-map .city-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.swiss-map .city-pill {
  display: flex; align-items: center; gap: 8px;
  background: #fff;
  border: 1px solid #d8e3ed;
  border-radius: 12px;
  padding: 10px 14px;
  font-size: .88rem; font-weight: 600;
  color: var(--bleu);
  transition: border-color var(--t-fast), transform var(--t-fast), background var(--t-fast);
}
.swiss-map .city-pill::before {
  content: "📍";
  font-size: .92rem;
  filter: grayscale(.4);
}
.swiss-map .city-pill:hover {
  border-color: var(--orange);
  background: var(--orange-pale);
  transform: translateY(-2px);
}
@media (max-width: 600px) {
  .swiss-map .city-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ================================================================ */
/* === OPTIMISATIONS MOBILE-FIRST — Pages FR & CH (hero + sections) */
/* ================================================================ */

/* Hero: padding réduit + typo fluide cohérente <768px */
@media (max-width: 768px) {
  .ch-v2-hero, .ab-hero, .cn-hero, .dg-hero, .nl-hero {
    min-height: auto;
  }
  .ch-v2-hero-inner,
  .ab-hero-inner,
  .cn-hero-inner,
  .dg-hero-inner,
  .nl-hero-inner {
    padding: 72px 18px 56px !important;
    gap: 28px !important;
  }
  .ch-v2-hero h1,
  .ab-hero h1,
  .cn-hero h1,
  .dg-hero h1,
  .nl-hero h1 {
    font-size: clamp(1.9rem, 6.5vw, 2.4rem) !important;
    line-height: 1.15 !important;
  }
  .ch-v2-hero .lead,
  .ab-hero .lead,
  .cn-hero .lead,
  .dg-hero .lead,
  .nl-hero .lead {
    font-size: .98rem !important;
    line-height: 1.65 !important;
  }
  /* Boutons hero : pleine largeur + hauteur tactile */
  .hero-btns {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .hero-btns .btn-primary,
  .hero-btns .btn-outline-light,
  .hero-btns .btn-outline-dark {
    width: 100%;
    justify-content: center;
    min-height: 48px;
    padding: 14px 20px !important;
    font-size: .98rem !important;
  }
  /* Badge hero CH/FR */
  .ch-v2-badge {
    font-size: .7rem !important;
    padding: 6px 12px !important;
  }
  /* Cards flottantes / sidebars → padding réduit */
  .ch-v2-hero-card,
  .ab-hero-side,
  .cn-hero-side,
  .dg-hero-side,
  .nl-hero-side {
    padding: 18px !important;
    border-radius: 22px !important;
  }
  .ch-v2-hero-card { min-height: 260px; }
  .ch-v2-hero-card .overlay { left: 16px; right: 16px; bottom: 16px; }
  .ch-v2-hero-card .overlay strong { font-size: 1.05rem; }

  /* Sections génériques : padding vertical réduit */
  .ch-v2-services, .ch-v2-why, .ch-v2-process, .ch-v2-pricing-section,
  .ch-v2-gallery, .ch-v2-testimonials, .ch-v2-zones, .ch-v2-faq-section, .ch-v2-final,
  .ab-services, .ab-showcase,
  .cn-services, .cn-formula, .cn-promise,
  .dg-empathy, .dg-scope, .dg-process, .dg-guarantees,
  .nl-sectors, .nl-freq {
    padding: 56px 18px !important;
  }

  /* Titres de section réduits */
  .section-title h3 { font-size: clamp(1.45rem, 5vw, 1.7rem) !important; line-height: 1.2 !important; }
  .section-title p { font-size: .95rem !important; }

  /* CTA final mobile : 1 colonne */
  .ch-cta-rich { grid-template-columns: 1fr !important; gap: 24px !important; padding: 24px !important; border-radius: 20px !important; }

  /* Galerie : 2 colonnes au lieu de masonry */
  .suisse-gallery {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: auto !important;
    gap: 8px !important;
  }
  .suisse-gallery .gimg,
  .suisse-gallery .gimg.tall,
  .suisse-gallery .gimg.wide {
    grid-column: span 1 !important;
    grid-row: span 1 !important;
    height: 180px !important;
  }

  /* Process illustré : image au-dessus puis liste */
  .ch-process-illustrated {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .ch-process-img { min-height: 220px !important; }
  .ch-process-item { gap: 14px !important; }
  .ch-process-num { width: 44px !important; height: 44px !important; font-size: 1rem !important; }

  /* Pricing : 1 colonne pleine largeur */
  .ch-pricing { grid-template-columns: 1fr !important; gap: 16px !important; }
  .ch-price { padding: 26px 22px !important; }
  .ch-price-amount { font-size: 2.2rem !important; }

  /* Testimonials & zones pleine largeur */
  .ch-testimonials { grid-template-columns: 1fr !important; gap: 16px !important; }
  .ch-v2-regions { grid-template-columns: 1fr !important; }
  .dg-g-grid { grid-template-columns: 1fr !important; }

  /* FAQ : padding interne resserré */
  .faq-item button { padding: 16px 14px !important; font-size: .96rem !important; }
  .faq-a { padding: 0 14px 16px !important; }

  /* KPI strip : 2 colonnes */
  .kpi-strip { grid-template-columns: repeat(2, 1fr) !important; gap: 14px !important; }
  .kpi-num { font-size: 1.8rem !important; }
  .kpi-label { font-size: .82rem !important; }

  /* Trust bar : scroll horizontal si besoin */
  .trust-bar {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    padding: 12px 14px !important;
  }
  .trust-bar .trust-item { flex-shrink: 0; font-size: .82rem; }

  /* Footer compact */
  .site-footer-premium { padding: 40px 16px 24px !important; }
  .site-footer-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .site-footer-bottom {
    flex-direction: column !important;
    gap: 8px !important;
    text-align: center !important;
  }

  /* Images lazy-friendly */
  img { max-width: 100%; height: auto; }
}

/* Très petits écrans (<480px) : ajustements supplémentaires */
@media (max-width: 480px) {
  .ch-v2-hero h1, .ab-hero h1, .cn-hero h1, .dg-hero h1, .nl-hero h1 {
    font-size: clamp(1.7rem, 7vw, 2rem) !important;
  }
  .suisse-gallery { grid-template-columns: 1fr !important; }
  .suisse-gallery .gimg,
  .suisse-gallery .gimg.tall,
  .suisse-gallery .gimg.wide { height: 200px !important; }
  .kpi-strip { grid-template-columns: 1fr !important; }
  .nl-sect-grid { grid-template-columns: 1fr !important; }
  /* Hero card overlay compacte */
  .ch-v2-hero-card .overlay .chip { font-size: .64rem !important; padding: 4px 10px !important; }
  /* Header : logo plus petit */
  header .logo .logo-text h1 { font-size: 1.15rem !important; }
  header .logo .logo-text small { font-size: .68rem !important; }
  /* Nav-overlay liens taille tactile */
  .nav-overlay a { padding: 14px 24px !important; font-size: 1.1rem !important; }
}

/* Respect prefers-reduced-motion : désactive Ken Burns + reveal */
@media (prefers-reduced-motion: reduce) {
  .ch-v2-hero-bg, .ab-hero-bg, .cn-hero-bg, .dg-hero-bg, .nl-hero-bg,
  .ch-v2-hero-card img {
    animation: none !important;
    transform: none !important;
  }
  .reveal-up, .reveal-left, .reveal-right, .stagger > * {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Optim performances mobile : désactive backdrop-filter coûteux < 768px */
@media (max-width: 768px) {
  .ab-hero-side, .cn-hero-side, .dg-hero-side, .nl-hero-side {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(255,255,255,.08) !important;
  }
}

/* Lien Espace pro (footer) : discret mais cliquable */
.site-footer-bottom .espace-pro {
  opacity: .55;
  font-size: .82em;
  transition: opacity .25s ease, color .25s ease;
}
.site-footer-bottom .espace-pro::before {
  content: "🔒 ";
  font-size: .9em;
}
.site-footer-bottom .espace-pro:hover,
.site-footer-bottom .espace-pro:focus {
  opacity: 1;
  color: var(--orange, #e5671c);
}

/* ╔══════════════════════════════════════════════════════════════╗ */
/* ║                                                              ║ */
/* ║   MOBILE PREMIUM — Polish global pour mobile / tablette      ║ */
/* ║   Surcharge propre des règles existantes pour un rendu net.  ║ */
/* ║                                                              ║ */
/* ╚══════════════════════════════════════════════════════════════╝ */

/* Safe-area iPhone notch + home indicator */
@supports (padding: max(0px)) {
  header {
    padding-left: max(16px, env(safe-area-inset-left)) !important;
    padding-right: max(16px, env(safe-area-inset-right)) !important;
  }
  .nav-overlay,
  .site-footer-premium,
  .ch-v2-final,
  section[id="contact"] {
    padding-left: max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
  .site-footer-bottom { padding-bottom: max(12px, env(safe-area-inset-bottom)); }
}

/* Empêche le zoom auto iOS sur les inputs */
@media (max-width: 768px) {
  input, select, textarea { font-size: 16px !important; }
}

/* ═══════════════ TABLETTE & DESKTOP ÉTROIT (1000–769px) ═══════════════ */
@media (max-width: 1000px) and (min-width: 769px) {
  .ch-v2-services-grid.three { grid-template-columns: repeat(2, 1fr) !important; }
  .ch-v2-why-grid,
  .ab-show-grid,
  .cn-promise-grid,
  .nl-freq-grid,
  .dg-empathy-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
}

/* ═══════════════ MOBILE PREMIUM (≤ 768px) ═══════════════ */
@media (max-width: 768px) {

  /* ─── Reset général : respiration ─── */
  body { -webkit-text-size-adjust: 100%; }

  /* ─── HEADER : sticky avec glassmorphism au scroll ─── */
  header {
    position: sticky !important;
    top: 0; left: 0; right: 0;
    z-index: 100;
    height: 62px !important;
    padding: 0 14px !important;
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: saturate(180%) blur(18px);
    -webkit-backdrop-filter: saturate(180%) blur(18px);
    border-bottom: 1px solid rgba(15,39,68,.06);
    box-shadow: 0 2px 12px rgba(15,39,68,.04);
    transition: background .3s, box-shadow .3s;
  }
  header .logo .site-logo-img {
    width: 38px !important;
    height: 38px !important;
  }
  header .logo .logo-text h1 {
    font-size: 1.05rem !important;
    margin: 0;
    line-height: 1;
  }
  header .logo .logo-text small {
    font-size: .64rem !important;
    letter-spacing: .06em;
  }
  /* Cache les nav-links classiques sur mobile (overlay s'en charge) */
  header .nav-links { display: none !important; }

  /* ─── BURGER : 3 traits animés en X ─── */
  .hamburger {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
    width: 44px; height: 44px;
    border-radius: 10px;
    background: var(--orange, #E5671C);
    border: none;
    cursor: pointer;
    transition: background .25s, transform .25s;
    box-shadow: 0 4px 10px rgba(229,103,28,.3);
  }
  .hamburger:hover { background: var(--orange-fonce, #C24E0C); transform: scale(1.05); }
  .hamburger span {
    display: block;
    width: 20px; height: 2.5px;
    background: #fff;
    border-radius: 2px;
    margin: 0 auto;
    transition: transform .35s cubic-bezier(.22,1,.36,1), opacity .25s, background .25s;
  }
  .hamburger.active { background: #0a1d35; }
  .hamburger.active span:nth-child(1) { transform: translateY(7.5px) rotate(45deg); }
  .hamburger.active span:nth-child(2) { opacity: 0; transform: translateX(-10px); }
  .hamburger.active span:nth-child(3) { transform: translateY(-7.5px) rotate(-45deg); }

  /* ─── NAV OVERLAY : pleine page, glass, animations ─── */
  .nav-overlay {
    position: fixed !important;
    top: 62px !important;
    left: 0; right: 0; bottom: 0;
    height: calc(100vh - 62px);
    background: linear-gradient(160deg, #0F2744 0%, #0A1D35 100%) !important;
    padding: 32px 26px 40px !important;
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform .42s cubic-bezier(.65,0,.35,1);
    display: flex !important;
    flex-direction: column;
    gap: 4px !important;
    z-index: 99;
  }
  .nav-overlay.active {
    transform: translateX(0);
  }
  .nav-overlay::before {
    content: "";
    position: absolute; inset: 0;
    background:
      radial-gradient(circle at 90% 10%, rgba(229,103,28,.18), transparent 50%),
      radial-gradient(circle at 10% 90%, rgba(35,88,140,.25), transparent 55%);
    pointer-events: none;
    z-index: 0;
  }
  .nav-overlay > * { position: relative; z-index: 1; }
  .nav-overlay a {
    display: flex !important;
    align-items: center;
    padding: 18px 18px !important;
    margin: 0 !important;
    border-radius: 14px;
    color: rgba(255,255,255,.92) !important;
    font-size: 1.12rem !important;
    font-weight: 600;
    background: transparent !important;
    border: none !important;
    transition: background .25s, transform .25s, color .25s;
  }
  .nav-overlay a::before {
    content: "→";
    color: var(--orange, #E5671C);
    margin-right: 14px;
    opacity: 0;
    transform: translateX(-8px);
    transition: opacity .25s, transform .25s;
    font-weight: 700;
  }
  .nav-overlay a:hover,
  .nav-overlay a:active {
    background: rgba(255,255,255,.06) !important;
    transform: translateX(4px);
  }
  .nav-overlay a:hover::before,
  .nav-overlay a:active::before {
    opacity: 1;
    transform: translateX(0);
  }
  /* Bouton devis dans overlay */
  .nav-overlay .btn-tel {
    margin-top: auto !important;
    margin-bottom: 12px;
    background: linear-gradient(135deg, #E5671C 0%, #C24E0C 100%) !important;
    border: 1px solid rgba(255,255,255,.2) !important;
    color: #fff !important;
    padding: 16px 22px !important;
    font-size: 1.08rem !important;
    min-height: 56px !important;
    border-radius: 14px !important;
    box-shadow: 0 12px 26px rgba(229,103,28,.5) !important;
    width: 100%;
    justify-content: center;
  }
  .nav-overlay .btn-tel::before { content: ""; }

  /* Empêche le scroll du body quand l'overlay est ouvert */
  body.nav-open { overflow: hidden; }

  /* ─── HERO : meilleure respiration ─── */
  .ch-v2-hero, .ab-hero, .cn-hero, .dg-hero, .nl-hero, .loc-hero {
    min-height: auto;
  }
  .ch-v2-hero-inner, .ab-hero-inner, .cn-hero-inner,
  .dg-hero-inner, .nl-hero-inner, .loc-hero-inner {
    padding: 56px 18px 64px !important;
    gap: 24px !important;
  }
  /* Badge hero plus discret */
  .ch-v2-badge,
  .ch-v2-hero-inner > div > div[style*="border-radius:999px"],
  .ab-hero-inner > div > div[style*="border-radius:999px"],
  .cn-hero-inner > div > div[style*="border-radius:999px"],
  .dg-hero-inner > div > div[style*="border-radius:999px"],
  .nl-hero-inner > div > div[style*="border-radius:999px"],
  .loc-hero-inner > div > div[style*="border-radius:999px"] {
    font-size: .65rem !important;
    padding: 5px 10px !important;
    margin-bottom: 14px !important;
    letter-spacing: .06em !important;
  }
  /* Titres hero : forte hiérarchie mobile */
  .ch-v2-hero h1, .ab-hero h1, .cn-hero h1,
  .dg-hero h1, .nl-hero h1, .loc-hero h1 {
    font-size: clamp(1.85rem, 7.5vw, 2.4rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -.025em !important;
    margin-bottom: 14px !important;
  }
  /* Lead hero : plus lisible */
  .ch-v2-hero .lead, .ab-hero .lead, .cn-hero .lead,
  .dg-hero .lead, .nl-hero .lead, .loc-hero .lead {
    font-size: .96rem !important;
    line-height: 1.6 !important;
    margin-bottom: 22px !important;
  }
  /* Boutons hero : pleine largeur, tactiles */
  .hero-btns {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    margin-bottom: 22px !important;
  }
  .hero-btns .btn-primary,
  .hero-btns .btn-outline-light,
  .hero-btns .btn-outline-dark {
    width: 100% !important;
    justify-content: center !important;
    min-height: 50px !important;
    padding: 14px 18px !important;
    font-size: .98rem !important;
    border-radius: 12px !important;
  }
  /* Carte hero (image immersive) */
  .ch-v2-hero-card {
    min-height: 240px !important;
    border-radius: 18px !important;
  }
  .ch-v2-hero-card .overlay {
    left: 14px !important; right: 14px !important; bottom: 14px !important;
  }
  .ch-v2-hero-card .overlay strong { font-size: 1rem !important; }
  .ch-v2-hero-card .overlay span  { font-size: .82rem !important; }
  /* Sidebars hero (FR + CH) : padding réduit, glass discret */
  .ab-hero-side, .cn-hero-side, .dg-hero-side, .nl-hero-side, .loc-hero-side {
    padding: 18px !important;
    border-radius: 18px !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: rgba(255,255,255,.07) !important;
  }
  .cn-hero-side h3, .dg-hero-side h3, .nl-hero-side h3, .loc-hero-side h3 {
    font-size: .96rem !important;
    margin-bottom: 10px !important;
  }
  .nl-hero-side .chk, .loc-hero-side .chk {
    font-size: .86rem !important;
    padding: 8px 0 !important;
  }
  /* Trust mini hero */
  .ch-v2-trust-mini { padding-top: 16px !important; gap: 12px !important; }
  .ch-v2-trust-mini small { font-size: .8rem !important; line-height: 1.45 !important; }

  /* ─── SECTIONS GÉNÉRIQUES ─── */
  .ch-v2-services, .ch-v2-why, .ch-v2-process,
  .ch-v2-pricing-section, .ch-v2-gallery,
  .ch-v2-testimonials, .ch-v2-zones, .ch-v2-faq-section, .ch-v2-final,
  .ab-services, .ab-showcase,
  .cn-services, .cn-formula, .cn-promise,
  .dg-empathy, .dg-scope, .dg-process, .dg-guarantees,
  .nl-sectors, .nl-freq,
  .loc-cats, .loc-process, .loc-standards {
    padding: 48px 18px !important;
  }
  /* Titres section */
  .section-title { margin-bottom: 24px !important; }
  .section-title h3 {
    font-size: clamp(1.35rem, 5.2vw, 1.65rem) !important;
    line-height: 1.2 !important;
    letter-spacing: -.015em !important;
  }
  .section-title p {
    font-size: .92rem !important;
    line-height: 1.6 !important;
  }
  .section-title .eyebrow {
    font-size: .68rem !important;
    padding: 4px 10px !important;
  }

  /* ─── KPI strip : 2 colonnes propres ─── */
  .ch-v2-metrics { padding: 28px 16px !important; }
  .kpi-strip {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
    max-width: 100% !important;
  }
  .kpi-item {
    padding: 16px 12px !important;
    border-radius: 14px !important;
  }
  .kpi-num {
    font-size: 1.65rem !important;
    line-height: 1.1 !important;
  }
  .kpi-label {
    font-size: .76rem !important;
    line-height: 1.4 !important;
    margin-top: 4px;
  }

  /* ─── SERVICES : cartes en 1 colonne pleine ─── */
  .ch-v2-services-grid,
  .ch-v2-services-grid.three {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .ch-v2-card {
    grid-template-rows: 200px auto !important;
    border-radius: 18px !important;
  }
  .ch-v2-card-media h3 { font-size: 1.1rem !important; }
  .ch-v2-card-body { padding: 20px !important; }
  .ch-v2-card-body p { font-size: .92rem !important; }
  .ch-v2-card-body li { font-size: .86rem !important; }
  .ch-v2-card-footer .price { font-size: 1rem !important; }

  /* Désactive le hover lift sur touch (pas tactile) */
  @media (hover: none) {
    .ch-v2-card:hover, .loc-cat:hover, .cn-card:hover,
    .nl-sect-card:hover, .dg-scope-card:hover, .ab-step:hover {
      transform: none !important;
      box-shadow: 0 14px 28px rgba(18,41,66,.08) !important;
    }
  }

  /* ─── POURQUOI BATIYS : badge flottant repositionné ─── */
  .ch-v2-why-grid { gap: 28px !important; }
  .ch-v2-why-image {
    min-height: 280px !important;
    border-radius: 18px !important;
  }
  .ch-v2-why-image .badge-float {
    right: 12px !important; bottom: 12px !important;
    max-width: 240px !important;
    padding: 16px 18px !important;
    border-radius: 14px !important;
  }
  .ch-v2-why-image .badge-float .big { font-size: 1.7rem !important; }
  .ch-v2-why-image .badge-float small { font-size: .76rem !important; line-height: 1.4 !important; }
  .ch-v2-why-points { gap: 16px !important; }
  .ch-v2-why-point {
    grid-template-columns: 44px 1fr !important;
    gap: 12px !important;
  }
  .ch-v2-why-point .ic {
    width: 40px !important; height: 40px !important;
    font-size: 1rem !important;
  }
  .ch-v2-why-point h4 { font-size: .96rem !important; margin-bottom: 4px !important; }
  .ch-v2-why-point p  { font-size: .88rem !important; line-height: 1.55 !important; }

  /* ─── PROCESS : pile verticale propre ─── */
  .ch-process-illustrated {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
  .ch-process-img {
    min-height: 200px !important;
    border-radius: 18px !important;
    order: -1;
  }
  .ch-process-list { gap: 16px !important; }
  .ch-process-item {
    grid-template-columns: 50px 1fr !important;
    gap: 14px !important;
  }
  .ch-process-num {
    width: 46px !important; height: 46px !important;
    font-size: 1rem !important;
    border-radius: 12px !important;
  }
  .ch-process-item h4 { font-size: .98rem !important; margin-bottom: 4px !important; }
  .ch-process-item p  { font-size: .88rem !important; line-height: 1.55 !important; }

  /* ─── PRICING : 1 colonne, focus sur featured ─── */
  .ch-pricing {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .ch-price {
    padding: 24px 20px !important;
    border-radius: 18px !important;
  }
  .ch-price h3 { font-size: 1.1rem !important; }
  .ch-price-amount { font-size: 1.9rem !important; }
  .ch-price-from { font-size: .8rem !important; }
  .ch-price ul li { font-size: .88rem !important; padding: 6px 0 !important; }
  .ch-price.featured {
    transform: none !important;
    border-color: var(--orange, #E5671C) !important;
    box-shadow: 0 18px 36px rgba(229,103,28,.18) !important;
  }
  .tarif-note { font-size: .82rem !important; line-height: 1.55 !important; padding: 12px 14px !important; }

  /* ─── GALERIE : scroll snap horizontal premium ─── */
  .suisse-gallery {
    grid-template-columns: none !important;
    grid-auto-rows: none !important;
    display: flex !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    scroll-padding: 18px;
    gap: 12px !important;
    padding: 4px 4px 18px !important;
    margin: 0 -18px !important;
    -webkit-overflow-scrolling: touch;
  }
  .suisse-gallery::-webkit-scrollbar { height: 4px; }
  .suisse-gallery::-webkit-scrollbar-thumb { background: rgba(229,103,28,.4); border-radius: 2px; }
  .suisse-gallery .gimg,
  .suisse-gallery .gimg.tall,
  .suisse-gallery .gimg.wide {
    flex: 0 0 78% !important;
    grid-column: auto !important;
    grid-row: auto !important;
    height: 220px !important;
    scroll-snap-align: center;
    border-radius: 14px !important;
  }
  .suisse-gallery .gimg:first-child { margin-left: 14px; }
  .suisse-gallery .gimg:last-child { margin-right: 14px; }

  /* ─── TÉMOIGNAGES : pile + accent ─── */
  .ch-testimonials {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .ch-testimonial {
    padding: 22px 20px !important;
    border-radius: 18px !important;
  }
  .ch-testimonial blockquote { font-size: .96rem !important; line-height: 1.6 !important; }
  .ch-testimonial-author { gap: 10px !important; padding-top: 12px !important; }
  .ch-testimonial-author .avatar { width: 40px !important; height: 40px !important; font-size: .82rem !important; }
  .ch-testimonial-author strong { font-size: .9rem !important; }
  .ch-testimonial-author span { font-size: .78rem !important; }

  /* ─── ZONES D'INTERVENTION ─── */
  .ch-v2-regions {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .ch-v2-region {
    padding: 18px !important;
    border-radius: 14px !important;
  }
  .ch-v2-region h4 { font-size: .98rem !important; }
  .ch-v2-region .cities { font-size: .82rem !important; line-height: 1.55 !important; }

  /* ─── FAQ : tactile + propre ─── */
  .faq-list { gap: 8px !important; }
  .faq-item {
    border-radius: 12px !important;
    overflow: hidden;
  }
  .faq-q {
    padding: 16px 16px !important;
    font-size: .94rem !important;
    min-height: 56px;
    text-align: left;
    line-height: 1.4;
  }
  .faq-icon {
    width: 28px !important; height: 28px !important;
    font-size: 1.1rem !important;
  }
  .faq-a { padding: 0 16px 18px !important; }
  .faq-a p { font-size: .9rem !important; line-height: 1.6 !important; }

  /* ─── CTA FINAL : pile, plein contraste ─── */
  .ch-cta-rich {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
    padding: 28px 22px !important;
    border-radius: 22px !important;
  }
  .ch-cta-rich h2 { font-size: clamp(1.45rem, 5.5vw, 1.85rem) !important; line-height: 1.2 !important; }
  .ch-cta-rich p  { font-size: .94rem !important; }
  .ch-cta-card-inner { padding: 22px 18px !important; border-radius: 16px !important; }
  .ch-cta-card-inner .tel-big { font-size: 1.3rem !important; }

  /* ─── SECTIONS SPÉCIFIQUES PAGES SERVICES ─── */
  /* Diogène scope cards & guarantees */
  .dg-scope-cards { grid-template-columns: 1fr !important; gap: 14px !important; }
  .dg-scope-card { border-radius: 18px !important; }
  .dg-scope-media { height: 170px !important; }
  .dg-scope-body { padding: 18px !important; }
  .dg-g-grid { grid-template-columns: 1fr !important; gap: 12px !important; margin-top: 22px !important; }
  .dg-g-card { padding: 22px 18px !important; border-radius: 16px !important; }
  .dg-g-card .ic { width: 46px !important; height: 46px !important; font-size: 1.25rem !important; }
  .dg-g-card h4 { font-size: 1rem !important; }
  .dg-g-card p { font-size: .85rem !important; }

  /* Nettoyage sectors & options */
  .nl-sect-grid { grid-template-columns: 1fr !important; gap: 12px !important; }
  .nl-sect-card { border-radius: 16px !important; }
  .nl-sect-img { height: 150px !important; }
  .nl-sect-body { padding: 18px !important; }
  .nl-options { gap: 10px !important; }
  .nl-option {
    grid-template-columns: 70px 1fr !important;
    grid-template-rows: auto auto !important;
    gap: 8px 12px !important;
    padding: 14px !important;
  }
  .nl-option .freq { font-size: .92rem !important; }
  .nl-option .txt { grid-column: 2; }
  .nl-option .price {
    grid-column: 1 / -1;
    font-size: .98rem !important;
    text-align: right;
    padding-top: 6px;
    border-top: 1px solid #eef2f7;
  }
  .nl-option:hover { transform: none !important; }

  /* Conciergerie cards */
  .cn-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .cn-card { border-radius: 18px !important; }
  .cn-card-img { height: 180px !important; }
  .cn-card-body { padding: 20px !important; }
  .cn-promise-points { gap: 12px !important; }
  .cn-promise-points li { grid-template-columns: 40px 1fr !important; gap: 12px !important; }
  .cn-promise-points .ic { width: 36px !important; height: 36px !important; font-size: 1rem !important; }
  .cn-promise-points strong { font-size: .95rem !important; }
  .cn-promise-points span  { font-size: .85rem !important; }

  /* Airbnb steps */
  .ab-steps { grid-template-columns: 1fr !important; gap: 12px !important; }
  .ab-step { padding: 22px 18px !important; border-radius: 16px !important; }
  .ab-step .ic { width: 42px !important; height: 42px !important; font-size: 1.2rem !important; }
  .ab-step h4 { font-size: .98rem !important; }
  .ab-step p  { font-size: .86rem !important; }
  .ab-show-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .ab-show-img { min-height: 240px !important; border-radius: 18px !important; }
  .ab-show-copy h2 { font-size: clamp(1.4rem, 5.2vw, 1.7rem) !important; }
  .ab-show-copy .list li { font-size: .9rem !important; }

  /* Location cats */
  .loc-cats-grid { grid-template-columns: 1fr !important; gap: 14px !important; }
  .loc-cat { border-radius: 18px !important; }
  .loc-cat-img { height: 180px !important; }
  .loc-cat-body { padding: 20px !important; }
  .loc-cat-footer { padding: 12px 20px 18px !important; }
  .loc-std-grid { grid-template-columns: 1fr !important; gap: 12px !important; margin-top: 22px !important; }
  .loc-std-card { padding: 20px 18px !important; border-radius: 16px !important; }
  .loc-std-card .ic { width: 46px !important; height: 46px !important; font-size: 1.3rem !important; }
  .loc-std-card h4 { font-size: 1rem !important; }

  /* ─── FOOTER : compact, lisible ─── */
  .site-footer-premium {
    padding: 36px 18px 16px !important;
  }
  .site-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 22px !important;
  }
  .site-footer-card { padding: 18px !important; border-radius: 14px !important; }
  .site-footer-brand img { width: 48px !important; height: 48px !important; }
  .site-footer-title { font-size: 1rem !important; }
  .site-footer-text { font-size: .86rem !important; line-height: 1.55 !important; }
  .site-footer-heading { font-size: .76rem !important; margin-bottom: 12px !important; }
  .site-footer-links a {
    padding: 8px 0 !important;
    font-size: .9rem !important;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .site-footer-links a:last-child { border-bottom: none; }
  .site-footer-bottom {
    flex-direction: column !important;
    gap: 8px !important;
    text-align: center !important;
    font-size: .78rem !important;
    line-height: 1.55 !important;
    padding: 18px 8px !important;
  }

  /* ─── HEADERS / SECTIONS EYEBROW : meilleure hiérarchie ─── */
  .eyebrow { font-size: .68rem !important; padding: 4px 10px !important; }

  /* ─── BTN-TEL en header : adapté à la nav-overlay ─── */
  /* (déjà géré par .nav-overlay .btn-tel plus haut) */

  /* ─── TRUST BAR : scroll horizontal ─── */
  .trust-bar {
    overflow-x: auto !important;
    flex-wrap: nowrap !important;
    padding: 14px 16px !important;
    gap: 14px !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }
  .trust-bar::-webkit-scrollbar { display: none; }
  .trust-bar .trust-item {
    flex-shrink: 0;
    font-size: .82rem !important;
    scroll-snap-align: start;
    white-space: nowrap;
  }

  /* ─── BOUTONS GLOBAUX : taille tactile ─── */
  .btn-primary, .btn-secondary, .btn-outline-light, .btn-outline-dark {
    min-height: 50px !important;
    padding: 14px 22px !important;
    font-size: .96rem !important;
    border-radius: 12px !important;
  }

  /* ─── IMAGES : éviter dépassements ─── */
  img { max-width: 100%; height: auto; }
}

/* ═══════════════ TRÈS PETIT MOBILE (≤ 380px) ═══════════════ */
@media (max-width: 380px) {
  header { height: 58px !important; }
  .nav-overlay { top: 58px !important; height: calc(100vh - 58px); padding: 24px 18px 32px !important; }
  header .logo .site-logo-img { width: 34px !important; height: 34px !important; }
  header .logo .logo-text h1 { font-size: .98rem !important; }
  header .logo .logo-text small { font-size: .58rem !important; }
  .ch-v2-hero h1, .ab-hero h1, .cn-hero h1,
  .dg-hero h1, .nl-hero h1, .loc-hero h1 {
    font-size: clamp(1.65rem, 8vw, 2rem) !important;
  }
  .kpi-strip { grid-template-columns: 1fr !important; }
}

/* ═══════════════ ORIENTATION PAYSAGE MOBILE ═══════════════ */
@media (max-width: 920px) and (orientation: landscape) {
  .ch-v2-hero, .ab-hero, .cn-hero, .dg-hero, .nl-hero, .loc-hero { min-height: auto; }
  .ch-v2-hero-inner, .ab-hero-inner, .cn-hero-inner,
  .dg-hero-inner, .nl-hero-inner, .loc-hero-inner {
    padding: 40px 22px !important;
  }
  .nav-overlay { padding: 20px 26px !important; }
  .nav-overlay a { padding: 12px 16px !important; font-size: 1rem !important; }
}

/* ─── Header au scroll : ombre un peu plus marquée ──────── */
header.scrolled {
  box-shadow: 0 4px 18px rgba(15,39,68,.08);
  background: rgba(255,255,255,.96) !important;
}

/* ─── Liens de navigation actifs (remplace les styles inline JS) ── */
.nav-links a[data-active="true"],
.nav-overlay a[data-active="true"] {
  color: var(--orange, #E5671C) !important;
  font-weight: 700;
}
.nav-links a[data-active="true"]::after {
  content: "";
  display: block;
  height: 2px;
  margin-top: 4px;
  background: var(--orange, #E5671C);
  border-radius: 2px;
}
.nav-overlay a[data-active="true"] {
  background: rgba(229,103,28,.12) !important;
  color: #fff !important;
}
.nav-overlay a[data-active="true"]::before {
  opacity: 1 !important;
  transform: translateX(0) !important;
}

/* ─── Désactive le scroll body quand overlay ouvert ─── */
body.nav-open { overflow: hidden; touch-action: none; }

/* ─── Pages légales : meilleure lisibilité mobile ─── */
@media (max-width: 768px) {
  .legal-page,
  .legal-content,
  .mentions-content,
  article.cgv,
  main > article {
    padding: 28px 18px !important;
    font-size: .94rem !important;
    line-height: 1.65 !important;
  }
  .legal-page h1, .legal-content h1, main > article h1 {
    font-size: clamp(1.5rem, 5.5vw, 1.85rem) !important;
    line-height: 1.2 !important;
    margin-bottom: 18px !important;
  }
  .legal-page h2, .legal-content h2, main > article h2 {
    font-size: clamp(1.15rem, 4.6vw, 1.35rem) !important;
    margin-top: 24px !important;
    margin-bottom: 12px !important;
  }
  .legal-page p, .legal-content p, main > article p { margin-bottom: 12px !important; }

  /* Vide-maison : breadcrumb compact, pill-link tactile */
  .breadcrumb { font-size: .82rem !important; padding: 10px 0 !important; }
  .pill-link a {
    display: flex !important;
    padding: 14px 16px !important;
    font-size: .94rem !important;
    border-radius: 12px !important;
    min-height: 50px;
  }
  .service-tag {
    font-size: .76rem !important;
    padding: 6px 12px !important;
  }
}

/* ╔══════════════════════════════════════════════════════════════╗ */
/* ║   FIX BANDE BLANCHE AU SCROLL (overscroll iOS + header)      ║ */
/* ╚══════════════════════════════════════════════════════════════╝ */

/* Le hero étant sombre, on évite que l'overscroll iOS révèle un fond blanc.
   On colore html/body en bleu marine (= couleur du hero) en haut, et le contenu
   après le hero garde son propre background. */
html, body {
  background-color: #0a1d35;
  overscroll-behavior-y: none;
}
body {
  /* Force un repaint propre + safe pour les ancres */
  position: relative;
}

/* Header transparent au-dessus du hero, blanc seulement après scroll */
header {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-bottom-color: transparent !important;
  box-shadow: none !important;
  transition: background .3s ease, backdrop-filter .3s ease, box-shadow .3s ease, border-color .3s ease;
}
header.scrolled {
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid rgba(15,39,68,.08) !important;
  box-shadow: 0 4px 18px rgba(15,39,68,.08) !important;
}

/* Tant que header transparent : logo + burger en blanc pour bonne lisibilité */
header:not(.scrolled) .logo .logo-text h1 { color: #fff !important; }
header:not(.scrolled) .logo .logo-text small { color: rgba(255,255,255,.78) !important; }
header:not(.scrolled) .logo .logo-text h1 span { color: var(--orange, #E5671C) !important; }

/* Sur les pages sans hero sombre (mentions, CGV, vide-maison après hero…),
   on remet le body blanc immédiatement après le header */
body.has-light-page {
  background-color: #ffffff;
}
body.has-light-page header { background: rgba(255,255,255,.96) !important; backdrop-filter: saturate(180%) blur(18px); -webkit-backdrop-filter: saturate(180%) blur(18px); border-bottom: 1px solid rgba(15,39,68,.08) !important; }
body.has-light-page header .logo .logo-text h1 { color: var(--bleu, #0F2744) !important; }
body.has-light-page header .logo .logo-text small { color: var(--gris, #6B7684) !important; }
