/*
Theme Name: Electricien Pro
Author: Ton nom
Description: Thème WordPress inspiré de brplomberie.fr pour un électricien
Version: 1.0
*/

/* === DESIGN TOKENS ===
   Identité GMElec (relevée sur le camion + kakémono) :
   cyan lumineux + bleu soutenu en dégradé diagonal, sur anthracite/noir.
   Pas d'orange. Slogan : « Allumez l'innovation, éteignez la routine ». */
:root {
  --color-primary: #1ca0d4;        /* cyan GMElec (camion / kakémono) */
  --color-primary-dark: #1480ab;   /* cyan foncé : hover */
  --color-primary-deep: #0e6da3;   /* bleu soutenu (bas du dégradé) */
  --color-ink: #2b3947;            /* anthracite GMElec (carrosserie) */
  --color-ink-deep: #1c2731;       /* anthracite profond (fonds sombres) */
  --color-text: #1f2933;
  --color-muted: #52606d;
  --color-bg: #ffffff;
  --color-bg-alt: #f4f8fb;
  --radius: 12px;
  --shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.08);
  --shadow-md: 0 6px 24px rgba(15, 23, 42, 0.12);
  --shadow-lg: 0 20px 50px rgba(15, 23, 42, 0.16);
  --container: 1200px;
  /* Dégradé de marque réutilisable (diagonale comme le flocage) */
  --gradient-brand: linear-gradient(135deg, #1ca0d4 0%, #0e6da3 60%, #1c2731 100%);
  /* Polices : Archivo (titres, proche du logo) + Montserrat (texte) */
  --font-heading: "Archivo", "Montserrat", system-ui, sans-serif;
  --font-body: "Montserrat", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* === BASE === */
html, body {
  margin: 0;
  max-width: 100%;
}
/* Garde-fou anti-débordement horizontal SANS casser position:sticky du header.
   `overflow-x: hidden` sur <html> casse le sticky → on utilise `clip` (idem
   visuellement mais ne crée pas de conteneur de défilement). */
html { overflow-x: clip; }
body { overflow-x: clip; }
body {
  font-family: var(--font-body);
  color: #333;
  line-height: 1.6;
}

*, *::before, *::after { box-sizing: border-box; }  /* largeurs prévisibles partout */

img, svg, iframe { max-width: 100%; }               /* aucun média ne dépasse */

/* Sécurité : aucune section ne peut être plus large que l'écran */
.section, .hero, .site-footer, .site-header { max-width: 100%; }

h1, h2, h3, .hero-title, .site-logo a {
  font-family: var(--font-heading);
  letter-spacing: -0.01em;
}

/* Icône SVG générique */
.gm-icon {
  width: 1.4em;
  height: 1.4em;
  display: inline-block;
  vertical-align: middle;
}

/* === SCROLL REVEAL ===
   N'est actif que si JS est présent (classe .js sur <html>) : sans JS,
   le contenu reste visible. Désactivé si l'utilisateur préfère moins d'animation. */
.js [data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
  will-change: opacity, transform;
}

.js [data-reveal].is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .js [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* Apparition en cascade des cartes d'une grille quand la section devient visible.
   Chaque enfant entre avec un léger décalage (effet « stagger »). */
.js [data-reveal].is-visible .services > *,
.js [data-reveal].is-visible .advantage-list > *,
.js [data-reveal].is-visible .stats-grid > *,
.js [data-reveal].is-visible .marques-logos > * {
  animation: gmelec-rise 0.5s ease both;
}
.js [data-reveal] .services > *,
.js [data-reveal] .advantage-list > *,
.js [data-reveal] .stats-grid > *,
.js [data-reveal] .marques-logos > * { opacity: 0; }
.js [data-reveal].is-visible .services > *:nth-child(1),
.js [data-reveal].is-visible .advantage-list > *:nth-child(1),
.js [data-reveal].is-visible .stats-grid > *:nth-child(1),
.js [data-reveal].is-visible .marques-logos > *:nth-child(1) { animation-delay: 0.04s; }
.js [data-reveal].is-visible .services > *:nth-child(2),
.js [data-reveal].is-visible .advantage-list > *:nth-child(2),
.js [data-reveal].is-visible .stats-grid > *:nth-child(2),
.js [data-reveal].is-visible .marques-logos > *:nth-child(2) { animation-delay: 0.10s; }
.js [data-reveal].is-visible .services > *:nth-child(3),
.js [data-reveal].is-visible .advantage-list > *:nth-child(3),
.js [data-reveal].is-visible .stats-grid > *:nth-child(3),
.js [data-reveal].is-visible .marques-logos > *:nth-child(3) { animation-delay: 0.16s; }
.js [data-reveal].is-visible .services > *:nth-child(4),
.js [data-reveal].is-visible .advantage-list > *:nth-child(4),
.js [data-reveal].is-visible .stats-grid > *:nth-child(4),
.js [data-reveal].is-visible .marques-logos > *:nth-child(4) { animation-delay: 0.22s; }
.js [data-reveal].is-visible .services > *:nth-child(n+5),
.js [data-reveal].is-visible .marques-logos > *:nth-child(n+5) { animation-delay: 0.28s; }
@keyframes gmelec-rise {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: none; }
}
@media (prefers-reduced-motion: reduce) {
  .js [data-reveal] .services > *,
  .js [data-reveal] .advantage-list > *,
  .js [data-reveal] .stats-grid > *,
  .js [data-reveal] .marques-logos > * { opacity: 1; animation: none; }
}

a {
  color: var(--color-primary);
  text-decoration: none;
}
a:hover {
  color: var(--color-primary-dark);
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;  /* empêche le navigateur mobile de réajuster le texte */
  text-size-adjust: 100%;
}

/* H2 en bleu */
h2 {
  color: var(--color-primary);
  text-align: center;
}

/* === LOGO SITE === */
.site-logo img {
  max-height: 72px;
  width: auto;
  display: block;
  transition: transform 0.2s ease;
}
.site-logo a:hover img { transform: scale(1.03); }
/* Plus gros sur mobile/tablette (le header y a plus de place en hauteur) */
@media (max-width: 1180px) {
  .site-logo img { max-height: 88px; }
}

/* === HEADER / MENU === */
header.site-header {
  background: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
  padding: 12px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 999;
  gap: 16px;
  transition: box-shadow 0.25s ease;
}

/* Ombre plus marquée une fois scrollé (le header reste toujours présent) */
header.site-header.is-scrolled {
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

.site-logo a {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-ink);
  text-decoration: none;
}

/* Conteneur nav + réseaux (regroupé pour le burger) */
.header-collapse {
  display: flex;
  align-items: center;
  gap: 24px;
  flex: 1;
  justify-content: space-between;
}

/* La nav occupe le centre et centre ses liens */
.main-nav {
  flex: 1;
  display: flex;
  justify-content: center;
}

.main-nav .menu {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 0;
  padding: 0;
}

.main-nav .menu li {
  position: relative;
}

.main-nav .menu li a {
  position: relative;
  color: var(--color-ink);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.88rem;
  padding: 6px 2px;
  transition: color 0.2s;
  white-space: nowrap;
}

/* Soulignement animé au survol / sur la section active */
.main-nav .menu li a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  background: var(--color-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.22s ease;
}
.main-nav .menu li a:hover,
.main-nav .menu li a.is-active {
  color: var(--color-primary);
}
.main-nav .menu li a:hover::after,
.main-nav .menu li a.is-active::after {
  transform: scaleX(1);
}


.social-links {
  display: flex;
  gap: 10px;
}

/* Badge « Certifié » à côté du bouton Devis (redirige vers Électricien Certifié) */
.nav-certif { display: inline-flex; align-items: center; flex-shrink: 0; text-decoration: none; }
/* Badge « Certifié » : style contour (secondaire, ne concurrence pas le Devis plein) */
.nav-certif-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(28, 160, 212, 0.08);
  color: var(--color-primary-deep);
  border: 1.5px solid rgba(28, 160, 212, 0.4);
  font-weight: 700;
  font-size: 0.85rem;
  padding: 8px 15px;
  border-radius: 999px;
  white-space: nowrap;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}
.nav-certif:hover .nav-certif-badge {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  transform: translateY(-1px);
}
.nav-certif-badge .gm-icon { width: 17px; height: 17px; }

/* Mobile/tablette : le badge Certifié est dans le menu déroulant → centré, aéré */
@media (max-width: 1180px) {
  .nav-certif {
    justify-content: center;
    padding: 14px 24px 4px;
    width: 100%;
  }
}


/* Bouton burger : caché sur desktop */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 8px;
  background: none;
  border: none;
  cursor: pointer;
}

.nav-toggle-bar {
  display: block;
  width: 26px;
  height: 3px;
  background: var(--color-ink);
  border-radius: 2px;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.social-links a { display: inline-flex; }
.social-links img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  border-radius: 4px;
  transition: transform 0.2s ease, opacity 0.2s ease;
  opacity: 0.9;
}
.social-links a:hover img { transform: translateY(-2px); opacity: 1; }

/* Responsive Header — burger sous 980px (8 entrées de menu) */
@media (max-width: 1180px) {
  .nav-toggle { display: flex; }

  .header-collapse {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    background: #fff;
    box-shadow: 0 8px 20px rgba(0,0,0,0.12);
    padding: 8px 0;
    /* Replié par défaut */
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    visibility: hidden;
    transition: max-height 0.3s ease, opacity 0.25s ease, visibility 0.25s;
  }

  .site-header.nav-open .header-collapse {
    max-height: 80vh;
    overflow-y: auto;
    opacity: 1;
    visibility: visible;
  }

  .main-nav {
    display: block;
    flex: none;
  }

  .main-nav .menu {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }

  .main-nav .menu li + li::before { display: none; } /* pas de séparateur vertical en colonne */

  .main-nav .menu li a {
    display: block;
    padding: 14px 24px;
    font-size: 1.05rem;
    border-bottom: 1px solid #eef2f5;
  }

  .social-links {
    justify-content: center;
    padding: 16px 24px;
  }

  /* Animation burger → croix */
  .site-header.nav-open .nav-toggle-bar:nth-child(1) { transform: translateY(8px) rotate(45deg); }
  .site-header.nav-open .nav-toggle-bar:nth-child(2) { opacity: 0; }
  .site-header.nav-open .nav-toggle-bar:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }
}

/* === HERO (fond dégradé de marque, pas de slider) === */
.hero {
  position: relative;
  width: 100%;
  margin: 0;
  overflow: hidden;
  background: var(--color-ink-deep);
}

/* Fond dégradé diagonal façon flocage GMElec */
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--gradient-brand);
}

/* Grille « schéma électrique » subtile, fondue vers la droite */
.hero-grid {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 44px 44px;
  -webkit-mask-image: radial-gradient(ellipse 80% 75% at 72% 28%, #000 38%, transparent 76%);
          mask-image: radial-gradient(ellipse 80% 75% at 72% 28%, #000 38%, transparent 76%);
  pointer-events: none;
}

/* Glow cyan diffus en haut à droite */
.hero-glow {
  position: absolute;
  top: -25%; right: -8%;
  width: 55%; height: 130%;
  z-index: 0;
  background: radial-gradient(circle, rgba(28,160,212,0.55), transparent 60%);
  filter: blur(45px);
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: var(--container);
  margin: 0 auto;
  min-height: clamp(300px, 40vh, 460px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: left;
  padding: clamp(40px, 7vw, 84px) 24px clamp(32px, 5vw, 56px);
  color: #fff;
  box-sizing: border-box;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #bfe6f5;
  margin: 0 0 18px;
}
.hero-eyebrow::before {
  content: "";
  width: 28px; height: 2px;
  background: var(--color-primary);
  display: inline-block;
}

.hero-title {
  font-size: clamp(2rem, 5vw, 3.4rem);
  line-height: 1.1;
  font-weight: 800;
  margin: 0 0 16px;
  max-width: 820px;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}

.hero-subtitle {
  font-size: clamp(1.05rem, 2.2vw, 1.3rem);
  max-width: 640px;
  margin: 0 0 32px;
  color: #e6f3fa;
}

/* CTA hero */
.hero-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  margin-bottom: 28px;
}
.hero-tels { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 8px; }
/* Numéros cliquables : présentés comme des « chips » tactiles évidentes */
.hero-tel {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #eaf6fc;
  text-decoration: none;
  font-size: 0.98rem;
  padding: 10px 16px;
  min-height: 46px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.15s ease;
}
.hero-tel .gm-icon {
  width: 20px; height: 20px;
  color: #9fe0fb;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.hero-tel b { font-family: var(--font-heading); letter-spacing: 0.01em; }
.hero-tel:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.6);
  color: #fff;
  transform: translateY(-2px);
}
.hero-tel:hover .gm-icon { color: #fff; transform: scale(1.1); }

/* Tablette/mobile : hero CENTRÉ, boutons sur 2 lignes pleine largeur —
   (1) « Demander un devis » ; (2) David + Enzo côte à côte (50/50). */
@media (max-width: 1180px) {
  .hero-content {
    align-items: center;     /* centre le bloc */
    text-align: center;      /* centre titre + sous-titre */
  }
  .hero-title, .hero-subtitle { max-width: 100%; }

  .hero-cta {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 560px;        /* la colonne de boutons reste contenue et centrée */
    margin-left: auto;
    margin-right: auto;
    gap: 12px;
  }
  .hero-cta .btn-primary {
    width: 100%;
    min-height: 58px;
    font-size: 1.15rem;
  }
  .hero-tels {
    display: flex;
    width: 100%;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    gap: 12px;
  }
  .hero-tel {
    flex: 1 1 0;            /* chaque tél prend exactement la moitié */
    min-width: 0;          /* CLÉ : empêche le débordement du texte */
    min-height: 56px;
    justify-content: center;
    padding: 10px 12px;
    font-size: 0.95rem;
    text-align: center;
  }
}

/* Petit écran : les 2 numéros s'empilent */
@media (max-width: 480px) {
  .hero-tels { flex-direction: column; }
}

/* === BANDEAU DE CONFIANCE (bas du hero) === */
.trustbar {
  position: relative;
  z-index: 1;
  margin-top: clamp(28px, 5vw, 56px);
  background: rgba(255, 255, 255, 0.07);
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}
.trustbar-list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: var(--container);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.trustbar-list li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  text-align: center;
  padding: 20px 12px;
  color: #d5e6f0;
  font-size: 0.84rem;
  border-left: 1px solid rgba(255, 255, 255, 0.1);
}
.trustbar-list li:first-child { border-left: 0; }
.trustbar-ic { color: #9fe0fb; display: inline-flex; }
.trustbar-ic .gm-icon { width: 24px; height: 24px; }
.trustbar-list b { font-family: var(--font-heading); color: #fff; font-size: 0.92rem; }

@media (max-width: 860px) {
  .trustbar-list { grid-template-columns: repeat(3, 1fr); }
  .trustbar-list li:nth-child(3n+1) { border-left: 0; }
  .trustbar-list li:nth-child(-n+3) { border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
}
@media (max-width: 520px) {
  .trustbar-list { grid-template-columns: repeat(2, 1fr); }
  .trustbar-list li { border-left: 1px solid rgba(255, 255, 255, 0.1); }
  .trustbar-list li:nth-child(odd) { border-left: 0; }
  .trustbar-list li:nth-child(3n+1) { border-left: 0; }
  .trustbar-list li:nth-child(-n+4) { border-bottom: 1px solid rgba(255, 255, 255, 0.1); }
}

/* === BANDE DE STATS === */
.section.stats { background: var(--color-bg-alt); padding: clamp(36px, 5vw, 56px) 0; }
.stats-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  text-align: center;
}
.stat { display: flex; flex-direction: column; gap: 4px; }
.stat-n {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1;
  color: var(--color-primary-deep);
  font-variant-numeric: tabular-nums;
}
.stat-l { color: var(--color-muted); font-weight: 600; font-size: 0.95rem; }
@media (max-width: 560px) {
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 28px 20px; }
}

/* === BANDE CTA / RÉASSURANCE (avant le formulaire) === */
/* Fond anthracite : contraste avec la section contact (dégradé bleu) qui suit.
   .section.cta-band (0,2,0) pour battre .section{background:#fff} (0,1,0). */
.section.cta-band { text-align: center; background: var(--color-ink-deep); }
.section.cta-band h2 { color: #fff; }
.section.cta-band h2::after { background: #fff; }
.cta-band-eyebrow {
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 700;
  color: #9fe0fb;
  margin: 0 0 6px;
}
.cta-band-text { color: #d5e6f0; max-width: 52ch; margin: 0 auto 26px; font-size: 1.05rem; }
.cta-reassure {
  list-style: none;
  margin: 26px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px 24px;
}
.cta-reassure li {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #eaf6fc;
  font-size: 0.92rem;
}
.cta-reassure .gm-icon { width: 18px; height: 18px; color: #9fe0fb; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border: 2px solid transparent; /* même boîte que .btn-secondary (border-box) */
  border-radius: var(--radius);
  font-weight: 700;
  font-size: 1.05rem;
  text-decoration: none;
  white-space: nowrap;        /* le libellé n'est jamais coupé */
  box-sizing: border-box;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  min-height: 52px;            /* cible tactile confortable (mobile) */
}

.btn:hover { transform: translateY(-2px); }
.btn:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 2px;
}

.btn-primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-md);
}
.btn-primary:hover { background: var(--color-primary-dark); color: #fff; }

.btn-secondary {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(2px);
}
.btn-secondary:hover { background: rgba(255, 255, 255, 0.22); color: #fff; }

/* Bouton secondaire « fantôme » sur fond foncé (hero, bande CTA) */
.btn-ghost {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  border: 2px solid rgba(255, 255, 255, 0.4);
}
.btn-ghost:hover { background: rgba(255, 255, 255, 0.2); color: #fff; }

.btn-icon { display: inline-flex; }
.btn-icon .gm-icon { width: 1.2em; height: 1.2em; }

/* CTA dans le header — bouton « Devis gratuit » bien présent */
.nav-cta {
  padding: 11px 22px;
  font-size: 0.95rem;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(28, 160, 212, 0.35);
}
.nav-cta:hover { box-shadow: 0 8px 22px rgba(28, 160, 212, 0.45); }
.nav-cta .btn-icon .gm-icon { width: 1.05em; height: 1.05em; }

/* === BARRE D'ACTION PERSISTANTE : [tél] [devis] [remonter] ===
   DESKTOP : pastilles flottantes en bas à droite.
   MOBILE/TABLETTE : barre pleine largeur ancrée en bas, une seule ligne. */
.floating-cta {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1000;
  display: flex;
  align-items: center;
  gap: 10px;
}

.floating-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: transform 0.18s ease, background 0.2s ease, box-shadow 0.25s ease;
}
.floating-btn:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }

.floating-devis {
  background: linear-gradient(135deg, #1ca0d4, #0e6da3);
  color: #fff;
  padding: 14px 24px;
  border-radius: 999px;
  font-size: 1rem;
  box-shadow: 0 6px 20px rgba(28, 160, 212, 0.45);
}
.floating-devis:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(28, 160, 212, 0.55);
}

/* Léger halo pulsé pour attirer l'œil (respecte reduced-motion) */
@media (prefers-reduced-motion: no-preference) {
  .floating-phone { animation: gmelec-pulse 2.6s ease-out infinite; }
}
@keyframes gmelec-pulse {
  0%   { box-shadow: var(--shadow-md), 0 0 0 0 rgba(28,160,212,0.45); }
  70%  { box-shadow: var(--shadow-md), 0 0 0 12px rgba(28,160,212,0); }
  100% { box-shadow: var(--shadow-md), 0 0 0 0 rgba(28,160,212,0); }
}

.floating-phone {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  flex-shrink: 0;
}
.floating-phone .gm-icon { width: 26px; height: 26px; }
.floating-phone:hover { transform: translateY(-2px); background: var(--color-primary-dark); }

/* Bouton remonter : sur desktop il est dans la barre, à droite, anthracite */
.floating-top {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-ink);
  color: #fff;
  flex-shrink: 0;
}
.floating-top .gm-icon { width: 24px; height: 24px; transform: rotate(-90deg); }
.floating-top:hover { transform: translateY(-2px); background: var(--color-ink-deep); }
.floating-top[hidden] { display: none; }

/* MOBILE + TABLETTE : barre d'action pleine largeur ancrée en bas (bandeau
   blanc). Le body reçoit un padding-bottom pour ne jamais masquer le contenu. */
@media (max-width: 1180px) {
  .floating-cta {
    left: 0;
    right: 0;
    bottom: 0;
    gap: 10px;
    align-items: stretch;
    padding: 10px 14px;
    padding-bottom: calc(10px + env(safe-area-inset-bottom));
    background: #fff;
    box-shadow: 0 -4px 16px rgba(15, 23, 42, 0.12);
  }
  .floating-devis {
    flex: 1 1 auto;            /* « Devis » occupe le centre */
    min-width: 0;              /* autorise la réduction sans déborder */
    min-height: 56px;
    padding: 0 14px;
    font-size: 1.05rem;
    border-radius: 12px;
    box-shadow: none;
    white-space: nowrap;       /* jamais sur 2 lignes */
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .floating-phone,
  .floating-top,
  .floating-cookies {
    width: 52px;
    height: 56px;
    border-radius: 12px;
    flex-shrink: 0;
    box-shadow: none;
  }
  .floating-phone .gm-icon { width: 25px; height: 25px; }
  .floating-top .gm-icon { width: 23px; height: 23px; }
  .floating-cookies svg { width: 23px; height: 23px; }
  /* « Devis » reste prioritaire ; sur très petit écran on raccourcit son padding */
  .floating-devis { padding: 0 12px; }
}
@media (max-width: 400px) {
  .floating-cta { gap: 7px; padding-left: 8px; padding-right: 8px; }
  .floating-phone, .floating-top, .floating-cookies { width: 46px; }
  .floating-devis { font-size: 1rem; }
}

/* Réserve la place sous tout le contenu pour la barre (≈ 76px + safe-area) */
@media (max-width: 1180px) {
  body { padding-bottom: calc(82px + env(safe-area-inset-bottom)); }
}

/* === FAQ (accordéon) === */
.faq-list {
  max-width: 820px;
  margin: 8px auto 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.faq-item {
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.faq-item summary {
  cursor: pointer;
  list-style: none;
  padding: 18px 52px 18px 20px;
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--color-ink);
  position: relative;
  transition: color 0.2s ease;
}
.faq-item summary::-webkit-details-marker { display: none; }
/* Chevron + qui pivote */
.faq-item summary::after {
  content: "+";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem;
  font-weight: 400;
  color: var(--color-primary);
  transition: transform 0.25s ease;
  line-height: 1;
}
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item summary:hover { color: var(--color-primary); }
.faq-item summary:focus-visible { outline: 3px solid var(--color-primary); outline-offset: -3px; border-radius: 12px; }
.faq-answer {
  padding: 0 20px 18px;
  color: var(--color-muted);
  line-height: 1.65;
}
.faq-answer p { margin: 0; }

/* === À PROPOS / CARROUSEL CARTE === */
.apropos { text-align: center; }

.carousel {
  position: relative;
  max-width: 1040px;
  margin: 0 auto;
  outline: none;
}

/* Zone des cartes : on empile et on fait un fondu enchaîné */
.carousel-track {
  position: relative;
}

.carousel-card {
  position: absolute;
  inset: 0;
  margin: 0;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  opacity: 0;
  transform: scale(0.98);
  transition: opacity 0.5s ease, transform 0.5s ease;
  pointer-events: none;
}

.carousel-card.active {
  position: relative;   /* la carte active donne sa hauteur au track */
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

/* L'image s'affiche EN ENTIER (contain) : aucun rognage, l'article texte
   comme les photos restent lisibles. Fond clair doux + léger flou de l'image
   en arrière-plan pour combler élégamment les côtés (plus de bandes vides). */
.carousel-img {
  width: 100%;
  height: clamp(360px, 56vh, 600px);
  background: #eef3f7;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

/* Arrière-plan : la même image, agrandie et floutée, pour combler les côtés
   sans bandes vides — élégant quel que soit le ratio (photo ou article). */
.carousel-img::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  filter: blur(22px) brightness(0.9);
  transform: scale(1.15);
  z-index: 0;
}

.carousel-img img {
  position: relative;
  z-index: 1;
  box-shadow: 0 6px 28px rgba(0,0,0,0.28);
  border-radius: 4px;
}

.carousel-img img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

.carousel-card figcaption {
  padding: 16px 20px;
  font-weight: 600;
  color: var(--color-ink);
  background: #fff;
  border-top: 3px solid var(--color-primary);
}

/* Flèches rondes de marque : centrées sur l'IMAGE (pas la légende),
   posées à l'intérieur des bords de l'image, bien contrastées. */
.carousel-btn {
  position: absolute;
  top: clamp(180px, 28vh, 300px); /* moitié de la hauteur d'image */
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border: none;
  border-radius: 50%;
  background: rgba(28, 39, 49, 0.55);
  color: #fff;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(3px);
  transition: background 0.2s ease, transform 0.15s ease;
  z-index: 3;
}

.carousel-btn:hover { background: var(--color-primary); transform: translateY(-50%) scale(1.06); }
.carousel-btn:focus-visible { outline: 3px solid #fff; outline-offset: 2px; }
.carousel-btn.prev { left: 14px; }
.carousel-btn.next { right: 14px; }

/* Points */
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 20px;
}

.carousel-dot {
  width: 11px;
  height: 11px;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: #cdd9e1;
  cursor: pointer;
  position: relative;
  transition: background 0.25s ease, width 0.25s ease;
}
/* Zone tactile étendue (44px) sans changer le visuel du point */
.carousel-dot::before {
  content: "";
  position: absolute;
  inset: -16px -10px;
}

.carousel-dot:hover { background: var(--color-primary-dark); }
/* Point actif : barre allongée (style « pill » plus premium) */
.carousel-dot.active { background: var(--color-primary); width: 28px; }
.carousel-dot:focus-visible { outline: 2px solid var(--color-ink); outline-offset: 2px; }


/* === SECTIONS === */
/* Chaque section respire et est visuellement distincte */
.section {
  padding: 72px 0;
  background-color: #fff;
}

/* Alternance de fond : gris très léger une section sur deux */
.section--alt {
  background-color: var(--color-bg-alt);
}

/* Sections « marque » : fond dégradé du hero, titres en blanc */
.section--brand {
  background-color: var(--color-ink-deep);
  background-image: var(--gradient-brand);
}
.section--brand .section-intro { color: #e6f3fa; }

.section > .section-content {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}

/* Titres de section : plus gros, plus présents, avec trait décoratif */
.section h2 {
  color: var(--color-ink);
  text-align: center;
  font-size: clamp(2rem, 6vw, 2.5rem);
  font-weight: 800;
  margin: 0 0 14px;
  position: relative;
  padding-bottom: 18px;
}

.section h2::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 64px;
  height: 4px;
  border-radius: 2px;
  background: var(--gradient-brand);
}

/* Sections « marque » (fond dégradé bleu) : titres + intro en blanc.
   Placé APRÈS .section h2 pour gagner en cascade. */
.section--brand h2 { color: #fff; }
.section--brand h2::after { background: #fff; }

/* Intro de section, centrée et lisible */
.section-intro {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 36px;
  color: var(--color-muted);
  font-size: 1.05rem;
}

/* === SERVICES === */
.services {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 8px;
}

.service-item {
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: var(--radius);
  padding: 28px 24px;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.service-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary);
}

.service-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--gradient-brand);
  color: #fff;
  margin-bottom: 16px;
}
.service-icon .gm-icon { width: 28px; height: 28px; }

.service-item h3 {
  font-size: 1.2rem;
  margin: 0 0 8px;
  color: var(--color-ink);
}

.service-item p {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.97rem;
}

/* Relief plus net au survol */
.service-item:hover { box-shadow: var(--shadow-lg); }

/* Carte mise en avant (dépannage urgence) */
.service-item { position: relative; }
.service-item.is-featured {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 1px var(--color-primary), var(--shadow-sm);
}
/* Badge urgence : posé en haut À DROITE, l'icône est à gauche → pas de chevauchement.
   On réserve aussi de l'espace en haut de la carte featured pour qu'il ne touche rien. */
.service-item.is-featured { padding-top: 44px; }
.service-badge {
  position: absolute;
  top: 14px; right: 14px;
  background: var(--color-primary);
  color: #fff;
  font-family: var(--font-heading);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: 20px;
  z-index: 2;
}
/* Sur la carte urgence, l'icône démarre sous le badge (centrée comme les autres) */
.service-item.is-featured .service-icon { margin-top: 0; }

/* Prestations repliables */
.prestations {
  max-width: 900px;
  margin: 36px auto 0;
  border-top: 1px solid #e7eef3;
  padding-top: 20px;
}

.prestations summary {
  cursor: pointer;
  font-weight: 700;
  color: var(--color-primary);
  text-align: center;
  list-style: none;
}
.prestations summary::-webkit-details-marker { display: none; }
.prestations summary::after { content: " ▾"; }
.prestations[open] summary::after { content: " ▴"; }

.prestations-list {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px 24px;
  margin: 20px 0 0;
  padding: 0;
}

.prestations-list li {
  position: relative;
  padding-left: 22px;
  color: var(--color-text);
  font-size: 0.95rem;
}

.prestations-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 800;
}

/* === AVANTAGES === */
/* Badge certification Legrand — fond bleu de marque, logo blanc + texte structuré */
.certif-badge {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  margin: 0 auto 32px;
  padding: 12px 24px 12px 12px;
  background: var(--gradient-brand);
  border-radius: 999px;
  box-shadow: var(--shadow-md);
  text-decoration: none;
  transition: transform 0.15s ease, box-shadow 0.2s ease;
}
.certif-badge:hover { transform: translateY(-2px); }
.certif-badge-logo {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: contain;
  background: #fff;
  padding: 4px;
}
.certif-badge-text { display: flex; flex-direction: column; gap: 1px; text-align: left; }
.certif-badge-text strong { color: #fff; font-size: 1.02rem; line-height: 1.2; }
.certif-badge-text span { color: #e6f3fa; font-size: 0.88rem; }

@media (max-width: 480px) {
  .certif-badge { gap: 12px; padding: 10px 18px 10px 10px; border-radius: var(--radius); }
  .certif-badge-logo { width: 46px; height: 46px; }
  .certif-badge-text strong { font-size: 0.95rem; }
}

/* Section atouts sur fond anthracite profond (contraste fort, sérieux).
   .section.advantages (0,2,0) pour battre .section{background:#fff} (0,1,0). */
.section.advantages {
  text-align: center;
  background: var(--color-ink-deep);
}
.section.advantages h2 { color: #fff; }
.section.advantages h2::after { background: #fff; }
.section.advantages .section-intro { color: #aebccc; }

.advantage-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 8px;
}

/* 2 colonnes sur tablette, 1 sur mobile : jamais d'orpheline mal centrée */
@media (max-width: 1180px) {
  .advantage-list { grid-template-columns: repeat(2, 1fr); }
}

.advantage-item {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius);
  padding: 28px 22px;
  text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.advantage-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(28, 160, 212, 0.5);
}

/* Icône d'atout : trait cyan sur fond sombre (pas de pastille pleine) */
.advantage-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  color: var(--color-primary);
  margin-bottom: 12px;
}
.advantage-icon .gm-icon { width: 42px; height: 42px; }

.advantage-item h3 {
  margin: 0 0 8px;
  font-size: 1.1rem;
  color: #fff;
}

.advantage-item p {
  margin: 0;
  color: #aebccc;
  font-size: 0.95rem;
}

/* === CONTACT (fond dégradé via .section--brand) === */
.contact { text-align: center; }

.contact-grid {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 32px;
  text-align: left;
  margin-top: 8px;
  align-items: start;
}

/* Colonne coordonnées — compacte, posée sur le fond dégradé de la section */
.contact-info {
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-self: start;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(4px);
  color: #fff;
  border-radius: var(--radius);
  padding: 22px;
}

.contact-info-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.95rem;
  line-height: 1.35;
}

.contact-info-item .contact-ic {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #fff;
  color: var(--color-primary-deep);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.contact-info-item .contact-ic .gm-icon { width: 22px; height: 22px; }
.contact-info-item strong { color: #fff; }
.contact-info-item small { color: #cdeaf6; }
.contact-info a { color: #fff; text-decoration: none; }
.contact-info a:hover { color: #cdeaf6; text-decoration: underline; }

/* Formulaire : carte blanche qui se détache du fond dégradé */
.contact-form {
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: 16px;
  padding: clamp(24px, 3vw, 34px);
  box-shadow: var(--shadow-lg);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.form-field { margin-bottom: 16px; }

.contact-form label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--color-ink);
}

.req { color: var(--color-primary); }

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  padding: 13px 15px;
  border: 1px solid #cdd9e1;
  border-radius: 10px;
  font-size: 1rem;
  font-family: inherit;
  box-sizing: border-box;
  background: var(--color-bg-alt);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  min-height: 48px;
}
.contact-form input:hover,
.contact-form select:hover,
.contact-form textarea:hover { border-color: #aebfcb; }

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  background: #fff;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(28, 160, 212, 0.18);
}

.contact-form textarea { resize: vertical; }

/* Consentement RGPD */
.rgpd-consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 0.88rem;
  font-weight: 400;
  color: var(--color-muted);
  margin: 4px 0 20px;
  cursor: pointer;
}
.rgpd-consent input { width: auto; margin-top: 3px; flex-shrink: 0; }
.rgpd-consent a { color: var(--color-primary); }

.form-submit {
  width: 100%;
  justify-content: center;
  border: none;
  cursor: pointer;
  font-size: 1.1rem;
  min-height: 56px;
  margin-top: 4px;
}

/* Mobile + tablette : formulaire confortable (taille raisonnable, pas énorme).
   font-size 16px évite le zoom auto iOS au focus. */
@media (max-width: 1180px) {
  .contact-form input,
  .contact-form select,
  .contact-form textarea {
    font-size: 16px;       /* lisible + pas de zoom iOS, sans être démesuré */
    box-sizing: border-box;
  }

  /* TOUT en une seule colonne (contact, formulaire, footer) */
  .contact-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .footer-grid { grid-template-columns: 1fr; gap: 28px; }
}

.success-msg {
  margin: 0 auto 24px;
  max-width: 700px;
  padding: 14px 18px;
  font-weight: 600;
  color: #0f7b3f;
  background: #e8f6ee;
  border-radius: 8px;
}

.error-msg {
  margin: 0 auto 24px;
  max-width: 700px;
  padding: 14px 18px;
  font-weight: 600;
  color: #b3261e;
  background: #fdeceb;
  border-radius: 8px;
}

/* Honeypot anti-spam : retiré du flux, invisible et non focusable */
.gmelec-hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* === SECTION SECTEURS === */
.section.secteurs { text-align: center; padding: clamp(48px, 7vw, 72px) 0; }

/* Bloc périmètre + villes — sur le fond dégradé */
.secteurs-info {
  max-width: 820px;
  margin: 0 auto 24px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(4px);
  border-radius: var(--radius);
  padding: 26px 24px;
  color: #fff;
}

/* Badge périmètre : pastille forte avec le ~100 km en avant */
.secteurs-badge {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 999px;
  padding: 10px 22px;
  margin-bottom: 16px;
}

.secteurs-phrase {
  max-width: 580px;
  margin: 0 auto 18px;
  color: #e6f3fa;
  font-size: 1rem;
}

.secteurs-badge-num {
  font-family: var(--font-heading);
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1;
  color: #fff;
}
.secteurs-badge > span:last-child { color: #e6f3fa; font-size: 0.92rem; }

.villes-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  justify-content: center;
  margin: 0;
  padding: 0;
}

.villes-list li {
  background: rgba(255, 255, 255, 0.16);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  padding: 7px 15px;
  font-size: 0.88rem;
  font-weight: 600;
  color: #fff;
  transition: background 0.2s ease, transform 0.15s ease;
}
.villes-list li:hover { background: rgba(255, 255, 255, 0.28); transform: translateY(-1px); }

/* Carte interactive (une ligne), façon brplomberie — compacte */
.map-container {
  max-width: 880px;
  margin: 0 auto;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  line-height: 0;
}
.map-container iframe {
  width: 100%;
  height: 300px;
  display: block;
}
/* ===================================================================
   MOBILE (≤ 600px) — bloc unique et cohérent. Tablette/PC non touchés.
   =================================================================== */
@media (max-width: 600px) {
  /* Padding latéral réduit → le contenu utilise toute la largeur */
  .section { padding: 44px 0; }
  .section > .section-content { padding: 0 14px; }

  /* Hero plus compact sur mobile (hauteur réduite) */
  .hero-content { min-height: auto; padding: 24px 18px; }
  .hero-title { font-size: 1.7rem; margin-bottom: 10px; }
  .hero-subtitle { font-size: 1rem; margin-bottom: 20px; }
  .hero-eyebrow { font-size: 0.85rem; margin-bottom: 10px; }
  .hero-cta { margin-bottom: 18px; }

  /* Carte */
  .map-container iframe { height: 240px; }

  /* Services + atouts : 2 colonnes pleine largeur (!important pour battre
     le minmax(280px) de base des services qui casserait sinon) */
  .section .services,
  .section .advantage-list { grid-template-columns: 1fr 1fr !important; gap: 10px; }
  .service-item, .advantage-item { padding: 16px 10px; }
  /* Mobile/tablette : on masque le badge « 24h/24 · 7j/7 » (info déjà dans le titre
     de la carte) et on ne réserve donc plus d'espace en haut. */
  .service-badge { display: none; }
  .service-item.is-featured { padding-top: 16px; }
  .service-icon, .advantage-icon { width: 46px; height: 46px; margin-bottom: 10px; }
  .service-item h3, .advantage-item h3 { font-size: 1rem; }
  .service-item p, .advantage-item p { font-size: 0.9rem; }

  /* Formulaire + bandeau infos : padding réduit (déjà 1 colonne via 1180px) */
  .contact-form { padding: 18px 14px; }
  .contact-info { padding: 18px 14px; }

  /* Footer mobile : 1 colonne centrée, compact (la place pour la barre
     flottante est gérée par body{padding-bottom}, pas ici). */
  footer.site-footer { padding: 40px 16px 28px; }
  .footer-grid { grid-template-columns: 1fr !important; gap: 26px; text-align: center; }
  .footer-logo { margin-left: auto; margin-right: auto; }
  .footer-social, .footer-contact { align-items: center; }
  .footer-social a, .footer-contact li { justify-content: center; }
  .footer-bottom { flex-direction: column; align-items: center; text-align: center; padding-right: 0; gap: 8px; }
}

/* === FOOTER === */
footer.site-footer {
  background: var(--color-ink-deep);
  color: #c7d2dc;
  padding: 56px 24px 28px;
  border-top: 3px solid var(--color-primary);
}

.footer-grid {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
  gap: 40px;
}

.footer-villes-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 16px;
  font-size: 0.9rem;
}

.footer-col h3 {
  color: #fff;
  font-size: 1.05rem;
  margin: 0 0 14px;
}

.footer-col p { margin: 0 0 8px; }

.footer-logo {
  display: block;
  max-height: 72px;
  width: auto;
  background: #fff;
  border-radius: 12px;
  padding: 10px 14px;
  margin-bottom: 14px;
}

.footer-name {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 6px;
}

.footer-baseline { font-style: italic; color: var(--color-primary); margin: 0 0 12px; }

footer.site-footer a { color: #c7d2dc; text-decoration: none; }
footer.site-footer a:hover { color: var(--color-primary); }

.footer-social {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-social a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.footer-social img {
  width: 30px;
  height: 30px;
  object-fit: contain;
  border-radius: 8px;
  background: #fff;
  padding: 3px;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.footer-social a:hover img { transform: translateY(-2px); }

/* Coordonnées du footer avec icônes */
.footer-contact {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer-contact li {
  display: flex;
  align-items: center;
  gap: 10px;
}
.footer-contact .gm-icon {
  width: 30px;
  height: 30px;
  padding: 6px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.10);
  color: var(--color-primary);
  flex-shrink: 0;
}

.footer-bottom {
  max-width: var(--container);
  margin: 36px auto 0;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.12);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  font-size: 0.88rem;
  color: #94a3b0;
}

.footer-legal a { color: #94a3b0; }

/* Desktop : les boutons flottants flottent en bas à droite. On réserve de la
   place SOUS le footer ET on empêche les liens légaux de passer dessous. */
@media (min-width: 1181px) {
  .site-footer { padding-bottom: 110px; }
  .footer-bottom { padding-right: 440px; padding-left: 80px; } /* droite: barre devis+tél ; gauche: pastille cookies */
}


/* === MARQUES === */
.marques {
  text-align: center;
}

/* Marques : TOUJOURS sur une seule ligne, les cadres se réduisent selon l'écran */
.marques-logos {
  list-style: none;
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  gap: clamp(6px, 1.2vw, 18px);
  max-width: 1080px;
  margin: 8px auto 0;
  padding: 0;
}

.marque-item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 0;           /* chaque cadre prend une part égale, se réduit sur petit écran */
  min-width: 0;          /* autorise la réduction sous la largeur de contenu */
  height: clamp(58px, 9vw, 78px);
  padding: clamp(8px, 1.4vw, 16px);
  box-sizing: border-box;
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--color-ink);
  transition: transform 0.2s ease, box-shadow 0.25s ease, border-color 0.2s ease;
}
.marque-item img {
  height: clamp(26px, 5vw, 40px);
  width: auto;
  max-width: 100%;
  object-fit: contain;
  display: block;
  /* Logos en niveaux de gris au repos, couleur au survol (effet « ils nous font confiance ») */
  filter: grayscale(1);
  opacity: 0.7;
  transition: filter 0.25s ease, opacity 0.25s ease;
}
.marque-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: #cfe6f3;
}
.marque-item:hover img { filter: grayscale(0); opacity: 1; }
/* Marque affichée en texte (logo absent) : pas de filtre */
.marque-item.is-text img { display: none; }
.marque-item.is-text { font-size: clamp(0.62rem, 1.6vw, 0.95rem); }

/* Mobile/tablette : les marques peuvent passer sur PLUSIEURS lignes (sinon trop
   petites sur une seule ligne). 3 par ligne, cadres plus lisibles. */
@media (max-width: 1180px) {
  .marques-logos { flex-wrap: wrap; gap: 12px; }
  .marque-item { flex: 0 1 calc(33.333% - 12px); height: 72px; }
  .marque-item img { height: 36px; }
}
@media (max-width: 560px) {
  .marque-item { flex: 0 1 calc(50% - 10px); }  /* 2 par ligne sur petit mobile */
}

/* Tablette/mobile : cadres un peu plus petits pour tenir sur la largeur */

/* === RESPONSIVE GLOBAL === */
@media (max-width: 768px) {
  .carousel-img { height: clamp(280px, 52vh, 420px); }
  /* Mobile/tablette : on masque les flèches (elles cachaient la photo).
     La navigation se fait au DOIGT (swipe) + via les points sous le carrousel. */
  .carousel-btn { display: none; }
  .carousel-dots { margin-top: 14px; }
}

/* === ACTUALITÉ === */
.actualite { text-align: center; }

/* Façade Facebook (avant chargement du Page Plugin au clic) */
.fb-facade {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  max-width: 460px;
  margin: 0 auto;
  padding: 36px 28px;
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.2s ease;
}
.fb-facade:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.fb-facade:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; }

.fb-facade-logo {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: #1877f2;
  color: #fff;
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.fb-facade-title { font-weight: 700; font-size: 1.15rem; color: var(--color-ink); }
.fb-facade-hint { font-size: 0.88rem; color: var(--color-muted); }
.fb-facade-link a { font-size: 0.88rem; color: var(--color-primary); }

/* === AVIS CLIENTS === */
.avis { text-align: center; }

.avis-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin: 8px 0 32px;
}

.avis-stars { color: #f5b301; font-size: 2rem; letter-spacing: 2px; }
.avis-score { font-size: 1.6rem; font-weight: 800; color: var(--color-ink); }
.avis-label { color: var(--color-muted); font-size: 0.95rem; }

.avis-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}

.avis-card {
  margin: 0;
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: var(--radius);
  padding: 26px 24px;
  text-align: left;
  box-shadow: var(--shadow-sm);
}

.avis-card-stars { color: #f5b301; font-size: 1.1rem; letter-spacing: 2px; margin-bottom: 12px; }

.avis-card blockquote {
  margin: 0 0 16px;
  font-style: italic;
  color: var(--color-text);
  line-height: 1.5;
}

.avis-card figcaption {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.avis-author { font-weight: 700; color: var(--color-ink); }
.avis-source { font-size: 0.85rem; color: var(--color-muted); }

.avis-fallback {
  max-width: 600px;
  margin: 0 auto;
  color: var(--color-muted);
}


/* === MESSAGE DE REMERCIEMENT (après envoi formulaire) === */
.thanks-box {
  max-width: 640px;
  margin: 0 auto 8px;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: 36px 28px;
  text-align: center;
}
.thanks-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--gradient-brand);
  color: #fff;
  margin-bottom: 16px;
}
.thanks-icon .gm-icon { width: 34px; height: 34px; }
.thanks-box h3 { margin: 0 0 10px; font-size: 1.4rem; color: var(--color-ink); }
.thanks-box p { margin: 0 0 8px; color: var(--color-text); }
.thanks-urgent { color: var(--color-muted); font-size: 0.95rem; }
.thanks-urgent a { color: var(--color-primary); font-weight: 700; }

/* === PAGES INTÉRIEURES (mentions légales, confidentialité…) === */
.page-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-ink-deep);
}
.page-hero-content {
  position: relative;
  z-index: 1;
  max-width: var(--container);
  margin: 0 auto;
  padding: 56px 24px;
  color: #fff;
}
.page-hero-logo {
  display: block;
  max-height: 64px;
  width: auto;
  background: #fff;
  border-radius: 12px;
  padding: 8px 12px;
  margin-bottom: 16px;
}

.page-hero-content h1 {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  margin: 0 0 8px;
  color: #fff;
}
.page-hero-crumb { margin: 0; font-size: 0.92rem; color: #cdeaf6; }
.page-hero-crumb a { color: #fff; }
.page-hero-crumb span { margin: 0 6px; opacity: 0.6; }

.page-content .section-content { max-width: 820px; }

.page-article {
  background: #fff;
  border: 1px solid #e7eef3;
  border-radius: 16px;
  box-shadow: var(--shadow-md);
  padding: clamp(28px, 4vw, 48px);
  line-height: 1.75;
}
.page-article h2 {
  text-align: left;
  color: var(--color-ink);
  font-size: 1.35rem;
  margin: 36px 0 12px;
  padding: 0 0 0 14px;
  border-left: 4px solid var(--color-primary);
  line-height: 1.25;
}
.page-article h2:first-child { margin-top: 0; }
.page-article h2::after { display: none; }
.page-article h3 { color: var(--color-ink); font-size: 1.08rem; margin: 24px 0 8px; }
.page-article p { margin: 0 0 16px; color: var(--color-text); }
.page-article a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 2px; }
.page-article ul { margin: 0 0 16px; padding-left: 22px; color: var(--color-text); }
.page-article li { margin-bottom: 8px; }
.page-article strong { color: var(--color-ink); }
/* Séparateur léger entre grands blocs */
.page-article hr { border: none; border-top: 1px solid #e7eef3; margin: 28px 0; }

.page-back { text-align: center; margin-top: 32px; }

/* === MOBILE UNIQUEMENT (≤ 600px) — LISIBILITÉ MAXIMALE (papy/mamie) ===
   On augmente la RACINE → tout le texte en rem grossit d'un coup, partout.
   Le hero et le footer sont neutralisés (taille px) pour ne pas exploser. */
/* Mobile (≤ 600px) : tailles par défaut, juste un layout plus dense. */

/* === PAGE 404 === */
.error-404 { text-align: center; }
.error-404-code {
  font-family: var(--font-heading);
  font-size: clamp(4rem, 14vw, 8rem);
  font-weight: 800;
  line-height: 1;
  margin: 0;
  color: rgba(255, 255, 255, 0.85);
}
.error-404 h1 { color: #fff; margin: 8px 0 14px; }
.error-404-text { color: #e6f3fa; max-width: 540px; margin: 0 auto 28px; }
.error-404-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.error-404 .btn-secondary { background: rgba(255,255,255,0.15); border-color: rgba(255,255,255,0.7); }

/* ===================================================================
   CONSENTEMENT COOKIES — Tarte au Citron, thème complet charte GMElec
   Objectif : lisible partout (bandeau + panneau), couleurs cyan/anthracite,
   bandeau bien visible avec voile sombre derrière.
   =================================================================== */

/* Voile sombre derrière le bandeau (le visiteur voit qu'il doit choisir) */
#tarteaucitronRoot #tarteaucitronAlertBig::before { content: none; }
#tarteaucitron, #tarteaucitronAlertBig, #tarteaucitronAlertSmall { font-family: var(--font-body) !important; }

/* --- Bandeau principal (bas, large, voile) --- */
#tarteaucitronRoot #tarteaucitronAlertBig {
  background: var(--color-ink-deep) !important;
  box-shadow: 0 0 0 100vmax rgba(15,23,42,0.55) !important; /* voile sombre */
  border-top: 4px solid var(--color-primary) !important;
  max-width: 680px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  border-radius: 16px 16px 0 0 !important;
  padding: 26px 28px !important;
}
#tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert,
#tarteaucitronRoot #tarteaucitronAlertBig #tarteaucitronDisclaimerAlert strong {
  color: #fff !important;
  font-size: 1rem !important;
  line-height: 1.5 !important;
}
/* Le lien « Politique de confidentialité » dans le bandeau → BLANC (bug corrigé) */
#tarteaucitronRoot #tarteaucitronAlertBig a,
#tarteaucitronRoot #tarteaucitronPrivacyUrl,
#tarteaucitronRoot #tarteaucitronPrivacyUrlDialog {
  color: #9fe0fb !important;
  text-decoration: underline !important;
}

/* --- Boutons du bandeau --- */
#tarteaucitronRoot #tarteaucitronAlertBig button {
  border-radius: 9px !important;
  font-weight: 700 !important;
  padding: 12px 22px !important;
  font-family: var(--font-heading) !important;
}
/* Boutons du BANDEAU = .tarteaucitronCTAButton (Accepter/Refuser/Personnaliser).
   « Tout accepter » (.tarteaucitronAllow) MIS EN AVANT : cyan plein, gras, ombre. */
#tarteaucitronRoot #tarteaucitronAlertBig .tarteaucitronCTAButton.tarteaucitronAllow {
  background: var(--color-primary) !important;
  color: #fff !important;
  font-size: 1.08rem !important;
  font-weight: 800 !important;
  padding: 15px 34px !important;
  box-shadow: 0 6px 20px rgba(28,160,212,0.55) !important;
  border: 1px solid var(--color-primary) !important;
}
/* « Tout refuser » (.tarteaucitronDeny) : secondaire, contour discret (PAS blanc plein). */
#tarteaucitronRoot #tarteaucitronAlertBig .tarteaucitronCTAButton.tarteaucitronDeny {
  background: transparent !important;
  color: #cfe0ea !important;
  border: 1px solid rgba(255,255,255,0.45) !important;
  font-size: 0.92rem !important;
  font-weight: 600 !important;
  padding: 12px 20px !important;
}
/* « Personnaliser » du bandeau = bouton avec UNIQUEMENT la classe .tarteaucitronCTAButton
   (ni .tarteaucitronAllow ni .tarteaucitronDeny), id #tarteaucitronCTAButton.
   Style discret (lien-bouton). NB : #tarteaucitronPersonalize2 est en réalité ACCEPTER. */
#tarteaucitronRoot #tarteaucitronAlertBig button#tarteaucitronCTAButton {
  background: transparent !important;
  color: #aebccc !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  font-size: 0.9rem !important;
  font-weight: 600 !important;
  padding: 12px 20px !important;
}
#tarteaucitronRoot #tarteaucitronCloseAlert,
#tarteaucitronRoot #tarteaucitronPersonalize,
#tarteaucitronRoot #tarteaucitronPersonalize2 {
  background: transparent !important;
  color: #cfe0ea !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
}

/* ===========================================================
   PANNEAU « gérer les cookies » — refonte soignée charte GMElec
   =========================================================== */
/* Cadre général du panneau : coins arrondis, ombre douce */
#tarteaucitronRoot #tarteaucitron {
  border-radius: 18px !important;
  overflow: hidden !important;
  box-shadow: 0 30px 80px rgba(15,23,42,0.45) !important;
  color: var(--color-text) !important;
  font-family: var(--font-body) !important;
}
#tarteaucitronRoot #tarteaucitronServices { color: var(--color-text) !important; }

/* En-tête du panneau : le bloc d'intro (#tarteaucitronInfo) ne doit PAS être un
   encadré blanc inline — on le rend pleine largeur, transparent, centré, lisible. */
#tarteaucitronRoot #tarteaucitron #tarteaucitronInfo {
  background: transparent !important;
  color: var(--color-text) !important;
  display: block !important;
  width: auto !important;
  max-width: none !important;
  position: static !important;
  margin: 0 auto 4px !important;
  padding: 0 !important;
  font-size: 0.98rem !important;
  font-weight: 500 !important;
  text-align: center !important;
}
#tarteaucitronRoot #tarteaucitron #tarteaucitronInfo p { color: var(--color-text) !important; }
/* Les filets (hr) au-dessus/dessous de l'intro : discrets ou masqués */
#tarteaucitronRoot #tarteaucitron hr { border: none !important; border-top: 1px solid #e1e9ef !important; margin: 14px 0 !important; }
#tarteaucitronRoot #dialogTitle,
#tarteaucitronRoot #tarteaucitron #dialogTitle {
  color: var(--color-ink) !important;  /* anthracite : le haut du panneau est clair */
  opacity: 1 !important;
  font-family: var(--font-heading) !important;
  font-weight: 800 !important;
}
/* Bouton « Fermer » en haut : pastille cyan lisible */
#tarteaucitronRoot #tarteaucitron #tarteaucitronClosePanel {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-radius: 0 0 0 10px !important;
  font-weight: 700 !important;
}

/* Titres des catégories (+ Cookies obligatoires / + APIs / + Réseaux sociaux) :
   barres pleine largeur anthracite, propres et alignées */
#tarteaucitronRoot #tarteaucitronServices .tarteaucitronTitle { margin: 0 !important; }
#tarteaucitronRoot #tarteaucitronServices .tarteaucitronTitle button {
  background: var(--color-ink) !important;
  color: #fff !important;
  font-family: var(--font-heading) !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  width: 100% !important;
  text-align: left !important;
  padding: 13px 18px !important;
  border-radius: 0 !important;
  border: none !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
}

/* Ligne « tout autoriser/refuser » d'une catégorie : fond clair, texte foncé */
#tarteaucitronRoot #tarteaucitronServices .tarteaucitronMainLine {
  background: var(--color-bg-alt) !important;
  border: none !important;
  border-bottom: 1px solid #e7eef3 !important;
}
#tarteaucitronRoot #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName,
#tarteaucitronRoot #tarteaucitronServices .tarteaucitronMainLine .tarteaucitronName * {
  color: var(--color-ink) !important;
  font-weight: 700 !important;
}

/* Chaque service : carte blanche aérée, texte foncé lisible */
#tarteaucitronRoot .tarteaucitronLine {
  border: none !important;
  border-bottom: 1px solid #eef3f7 !important;
  padding: 16px 18px !important;
  background: #fff !important;
}
#tarteaucitronRoot .tarteaucitronLine .tarteaucitronName,
#tarteaucitronRoot .tarteaucitronLine .tarteaucitronName *,
#tarteaucitronRoot .tarteaucitronLine .tarteaucitronAsk { color: var(--color-text) !important; }
#tarteaucitronRoot .tarteaucitronLine .tarteaucitronName strong { color: var(--color-ink) !important; }

/* === Boutons Autoriser / Interdire (panneau ET bandeau) — charte forcée ===
   On reprend les sélecteurs EXACTS de TAC (très spécifiques) + !important pour
   écraser le jaune/bleu natif (#fbd600). « Autoriser »/actif = cyan, « Interdire » = gris. */
#tarteaucitronRoot .tarteaucitronAllow,
#tarteaucitronRoot button.tarteaucitronAllow,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronAllow,
#tarteaucitron #tarteaucitronServices #tarteaucitronServices_mandatory .tarteaucitronLine button.tarteaucitronAllow,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsAllowed .tarteaucitronAllow,
.tac_activate .tarteaucitronAllow {
  background: var(--color-primary) !important;
  background-color: var(--color-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  font-family: var(--font-heading) !important;
  box-shadow: none !important;
  opacity: 1 !important;
}
#tarteaucitronRoot .tarteaucitronAllow:hover,
#tarteaucitronRoot button.tarteaucitronAllow:hover { background: var(--color-primary-dark) !important; }
/* Bouton « Tout accepter » du panneau (#tarteaucitronAllAllowed) + état sélectionné :
   forcer le cyan charte (TAC met du bleu/jaune par défaut). */
#tarteaucitronRoot #tarteaucitronAllAllowed,
#tarteaucitronRoot #tarteaucitron #tarteaucitronServices #tarteaucitronAllAllowed,
#tarteaucitronRoot #tarteaucitronAllAllowed.tarteaucitronIsSelected,
#tarteaucitronRoot .tarteaucitronAllow.tarteaucitronIsSelected {
  background: var(--color-primary) !important;
  background-color: var(--color-primary) !important;
  color: #fff !important;
}
#tarteaucitronRoot .tarteaucitronDeny,
#tarteaucitronRoot button.tarteaucitronDeny,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine .tarteaucitronAsk .tarteaucitronDeny,
#tarteaucitron #tarteaucitronServices .tarteaucitronLine.tarteaucitronIsDenied .tarteaucitronDeny {
  background: #e3eaef !important;
  background-color: #e3eaef !important;
  color: var(--color-ink) !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 700 !important;
  font-family: var(--font-heading) !important;
  opacity: 1 !important;
}
#tarteaucitronRoot .tarteaucitronDeny:hover,
#tarteaucitronRoot button.tarteaucitronDeny:hover { background: #d4dde4 !important; }
/* « Tout refuser » du panneau + état sélectionné : gris charte (pas jaune TAC). */
#tarteaucitronRoot #tarteaucitronAllDenied,
#tarteaucitronRoot #tarteaucitronAllDenied2,
#tarteaucitronRoot #tarteaucitron #tarteaucitronServices #tarteaucitronAllDenied.tarteaucitronIsSelected,
#tarteaucitronRoot .tarteaucitronDeny.tarteaucitronIsSelected {
  background: #cdd9e1 !important;
  background-color: #cdd9e1 !important;
  color: var(--color-ink) !important;
}
/* La coche d'état (carré coché) suit la charte */
#tarteaucitronRoot .tarteaucitronCheck::before,
#tarteaucitronRoot .tarteaucitronCross::before { color: #fff !important; }

/* Bouton « engage » affiché à la place d'un contenu bloqué (carte, avis) */
.tac_activate .tarteaucitronAllow { font-family: var(--font-heading) !important; }

/* Conteneur carte (rempli par Tarte au Citron après consentement) */
.map-embed { min-height: 320px; background: var(--color-bg-alt); border-radius: var(--radius); overflow: hidden; }
.map-embed iframe { display: block; width: 100%; border: 0; }
/* Le bloc « engage » de la carte : centré et lisible */
.map-embed .tac_activate,
.map-embed > div { color: var(--color-text); padding: 24px; text-align: center; }

/* Lien « Gérer mes cookies » dans le pied de page */
.footer-cookie-link {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: #94a3b0;
  cursor: pointer;
  text-decoration: none;
}
.footer-cookie-link:hover { color: var(--color-primary); }

/* === Bouton « cookies » ===
   PC : pastille fixe en bas à GAUCHE (séparée de la barre tél/devis en bas à droite).
   Mobile/tablette : intégré dans la barre flottante du bas avec les autres. */
.floating-cookies {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--color-ink);
  color: #fff;
  flex-shrink: 0;
}
.floating-cookies svg { width: 24px; height: 24px; }
@media (hover: hover) {
  .floating-cookies:hover { transform: translateY(-2px); background: var(--color-ink-deep); }
}

/* PC : on détache la pastille cookies de la barre et on l'ancre en bas à gauche. */
@media (min-width: 1181px) {
  .floating-cookies {
    position: fixed;
    left: 18px;
    bottom: 18px;
    z-index: 1000;
    box-shadow: var(--shadow-md);
  }
}
