/* ============================================================
   EliteGuêpe — Redesign CSS
   Chargé APRÈS eliteguepe-2023-*.webflow.css
   Principe : surcharges ciblées, pas de refonte du layout Webflow
   ============================================================ */

/* --- Variables --- */
:root {
  --eg-or:       #fe9e24;
  --eg-or-dk:    #e58a0a;
  --eg-or-lt:    #fff4e6;
  --eg-or-soft:  #fff4e6;
  --eg-or-mid:   #fde4bc;
  --eg-dk:       #222125;
  --eg-dk2:      #2e2b32;
  --eg-tx:       #1a1b1f;
  --eg-tx2:      #5f5f5f;
  --eg-mu:       #5f5f5f;
  --eg-su:       #9a9a9a;
  --eg-bg:       #ffffff;
  --eg-bg2:      #f7f7f5;
  --eg-bd:       #e8e8e4;
  --eg-bd-lt:    #f0f0ec;
  --eg-r:        12px;
  --eg-r-lg:     20px;
  --eg-sh-sm:    0 1px 3px rgba(0,0,0,.04);
  --eg-sh:       0 4px 20px rgba(0,0,0,.06);
  --eg-sh-lg:    0 12px 40px rgba(0,0,0,.10);
  --eg-tr:       all .24s cubic-bezier(.4,0,.2,1);
  --eg-pad-x:    48px;
  --eg-pad-y:    96px;
}

/* --- Reset léger --- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
body { margin: 0; padding: 0; overflow-x: hidden; line-height: 1.7; }
::selection { background: rgba(254,158,36,.2); color: var(--eg-dk); }

/* --- Typographie --- */
body {
  font-family: Montserrat, sans-serif !important;
  color: var(--eg-tx) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.7 !important;
  background: var(--eg-bg) !important;
}

h1, h1.heading {
  font-size: clamp(1.75rem, 4vw, 3rem) !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.025em !important;
  margin: 0 0 1rem !important;
  color: inherit;
}
h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 .5rem !important;
  color: var(--eg-dk);
}
h3 {
  font-size: 1.125rem !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  letter-spacing: -0.01em !important;
  margin: 0 0 .5rem !important;
  color: var(--eg-dk);
}

/* --- Label "eyebrow" (petit texte orange au-dessus des titres) --- */
.label, .label.cc-light, .label.cc-blog-date {
  display: block !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--eg-or) !important;
  opacity: 1 !important;
  margin-bottom: 12px !important;
  line-height: 1.4 !important;
}

/* ============================================================
   NAVIGATION  (sticky glass)
   ============================================================ */
.navigation.w-nav {
  background: #ffffff !important;
  border-bottom: 1px solid var(--eg-bd-lt) !important;
  padding: 0 !important;
  margin: 0 !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  width: 100% !important;
  transition: box-shadow .3s ease !important;
  display: block !important;
}
.navigation.w-nav.scrolled {
  background: #ffffff !important;
  box-shadow: 0 1px 0 var(--eg-bd), 0 4px 16px rgba(0,0,0,.05) !important;
}

.navigation-wrap {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 0 48px !important;
  height: 68px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: relative !important;
  flex: initial !important;
}

/* Logo */
.logo-link, .logo-link.w-nav-brand {
  display: flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  z-index: 10 !important;
  position: relative !important;
  padding: 0 !important;
}
.logo-image {
  height: 34px !important;
  width: auto !important;
  display: block !important;
}

/* Container du menu — retire position:absolute qui écrasait la page */
.menu {
  position: static !important;
  inset: auto !important;
  display: flex !important;
  align-items: center !important;
  flex: 1 !important;
  justify-content: center !important;
  z-index: auto !important;
}
.navigation-items.w-nav-menu {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  position: static !important;
  background: none !important;
  flex: none !important;
}
.navigation-item.w-nav-link {
  display: inline-block !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  text-transform: none !important;
  color: var(--eg-tx) !important;
  opacity: 1 !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  transition: var(--eg-tr) !important;
  line-height: 1.4 !important;
}
.navigation-item.w-nav-link:hover {
  background: var(--eg-bg2) !important;
  color: var(--eg-dk) !important;
  opacity: 1 !important;
}
.navigation-item.w-nav-link.w--current {
  color: var(--eg-or) !important;
  font-weight: 600 !important;
  opacity: 1 !important;
}
.navigation-item.w-nav-link br { display: none !important; }

/* Bouton téléphone navigation (desktop) */
.button.cc-contact-us.w-inline-block {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  background: var(--eg-or) !important;
  color: #222 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-transform: none !important;
  padding: 9px 18px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  flex-shrink: 0 !important;
  transition: var(--eg-tr) !important;
  position: relative !important;
  z-index: 10 !important;
  border: none !important;
}
.button.cc-contact-us.w-inline-block:hover {
  background: var(--eg-or-dk) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(254,158,36,.35) !important;
  color: #222 !important;
}
.button.cc-contact-us.w-inline-block:active { transform: translateY(0); }
.button.cc-contact-us .image-6 { width: 16px !important; height: 16px !important; }
.button.cc-contact-us .text-block { font-size: 13px !important; font-weight: 700 !important; }

/* Menu burger caché sur desktop */
.menu-button.w-nav-button { display: none !important; }

/* ============================================================
   HERO
   ============================================================ */
.section.cc-store-home-wrap {
  margin: 0 !important;
  padding: 0 !important;
}

.intro-header {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: auto !important;
  min-height: 620px !important;
  padding: 112px 48px 96px !important;
  margin: 0 !important;
  background-color: var(--eg-dk) !important;
  background-image:
    radial-gradient(ellipse 75% 55% at 65% 40%, rgba(254,158,36,.13) 0%, transparent 58%),
    radial-gradient(ellipse 45% 45% at 12% 85%, rgba(254,158,36,.07) 0%, transparent 52%) !important;
  color: #fff !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: none !important;
  filter: none !important;
}

.intro-content.cc-homepage {
  text-align: center !important;
  max-width: 780px !important;
  width: 100% !important;
  margin: 0 auto !important;
  position: relative !important;
  z-index: 1 !important;
}

.intro-text { margin-bottom: 0 !important; }

/* Badge "Intervention 7j/7" */
.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(254,158,36,.14);
  border: 1px solid rgba(254,158,36,.3);
  border-radius: 100px;
  padding: 6px 16px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--eg-or);
  margin-bottom: 28px;
  animation: eg-fade-up .6s ease both;
}
.hero-badge-dot {
  width: 6px; height: 6px;
  background: var(--eg-or);
  border-radius: 50%;
  animation: eg-blink 2s ease-in-out infinite;
}
@keyframes eg-blink { 0%,100% { opacity: 1; } 50% { opacity: .4; } }

/* H1 hero */
.intro-header .heading {
  color: #fff !important;
  font-size: clamp(1.85rem, 4vw, 3rem) !important;
  font-weight: 700 !important;
  letter-spacing: -.03em !important;
  line-height: 1.1 !important;
  margin: 0 0 20px !important;
  animation: eg-fade-up .7s .05s ease both;
}

/* Sous-titre hero */
.intro-content .paragraph-bigger.cc-bigger-white-light {
  color: rgba(255,255,255,.68) !important;
  font-size: 1.05rem !important;
  font-weight: 400 !important;
  line-height: 1.7 !important;
  opacity: 1 !important;
  margin: 0 0 8px !important;
  animation: eg-fade-up .7s .15s ease both;
}
.intro-content .paragraph-bigger.cc-bigger-white-light strong { color: var(--eg-or); font-weight: 600; }

/* Zone des boutons hero */
.hero-ctas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 32px;
  animation: eg-fade-up .7s .25s ease both;
}

/* CTA principal orange (hero + CTA final) */
.button.cc-jumbo-button,
.button.cc-jumbo-button.cc-jumbo-white {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  background: var(--eg-or) !important;
  color: #222 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  text-transform: none !important;
  padding: 14px 30px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  border: none !important;
  flex: initial !important;
  margin: 0 !important;
  line-height: 1.3 !important;
  transition: var(--eg-tr) !important;
  white-space: nowrap !important;
}
.button.cc-jumbo-button:hover,
.button.cc-jumbo-button.cc-jumbo-white:hover {
  background: var(--eg-or-dk) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(254,158,36,.38) !important;
  color: #222 !important;
}
.button.cc-jumbo-button:active { transform: translateY(0); }
.button.cc-jumbo-button img { width: 18px !important; height: 18px !important; }
.button.cc-jumbo-button > div,
.button.cc-jumbo-button .text-block-2 { font-size: 14px !important; font-weight: 700 !important; color: #222 !important; }
.button.cc-jumbo-button strong { font-weight: 700 !important; }

/* Bouton secondaire outline (hero) */
.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.92) !important;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 14px 26px;
  border-radius: 100px;
  border: 1px solid rgba(255,255,255,.2);
  text-decoration: none;
  transition: var(--eg-tr);
}
.btn-outline:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.3);
  color: #fff !important;
}

/* Stats hero */
.hero-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  margin-top: 56px;
  padding-top: 36px;
  border-top: 1px solid rgba(255,255,255,.1);
  flex-wrap: wrap;
  animation: eg-fade-up .7s .35s ease both;
}
.hero-stat { text-align: center; }
.hero-stat-num {
  font-size: 1.65rem;
  font-weight: 700;
  color: var(--eg-or);
  line-height: 1;
  letter-spacing: -.02em;
}
.hero-stat-label {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-top: 7px;
}
.hero-stat-divider {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,.1);
  flex-shrink: 0;
}

/* ============================================================
   SECTIONS STANDARD
   ============================================================ */
/* Annule les margin-left/right du CSS Webflow */
.section {
  margin: 0 !important;
  padding: 96px 48px !important;
  position: relative !important;
}
/* Alternance gris/blanc pilotée par classes ajoutées */
.section.eg-bg-alt { background: var(--eg-bg2); }
.section.eg-bg-white { background: var(--eg-bg); }

.container {
  max-width: 1140px !important;
  margin: 0 auto !important;
  width: 100% !important;
  text-align: left !important;
}

/* Cadrage en-tête de section */
.moto-wrap-1 {
  text-align: center !important;
  max-width: 680px !important;
  width: auto !important;
  margin: 0 auto !important;
  display: block !important;
  padding: 0 !important;
}
.moto-wrap-1 h2 { color: var(--eg-dk) !important; }

/* Divider */
.divider {
  height: 1px !important;
  background: var(--eg-bd) !important;
  border: none !important;
  margin: 32px auto !important;
  max-width: 80px !important;
}

/* Paragraphes */
.paragraph-light {
  color: var(--eg-mu) !important;
  font-size: 15.5px !important;
  line-height: 1.8 !important;
  margin-bottom: 0 !important;
}
.paragraph-light strong { color: var(--eg-dk); font-weight: 600; }

.section-heading { color: var(--eg-dk) !important; margin: 0 0 16px !important; }

/* ============================================================
   "QUI SUIS-JE ?" — About grid
   ============================================================ */
.home-content-wrap { margin-top: 56px !important; margin-bottom: 0 !important; }

.about-grid {
  display: grid !important;
  grid-template-columns: 1.1fr 1fr !important;
  gap: 64px !important;
  align-items: center !important;
  grid-row-gap: 0 !important;
  grid-column-gap: 64px !important;
}
.about-grid.cc-about-2 {
  grid-template-columns: 1fr 1fr !important;
}
.home-section-wrap {
  margin-bottom: 0 !important;
  padding: 0 !important;
}
.home-section-wrap .label { margin-bottom: 10px !important; }
.home-section-wrap h2 { margin-bottom: 20px !important; }
.home-section-wrap .paragraph-light { margin-bottom: 0 !important; }

.about-grid img.image-5 {
  border-radius: var(--eg-r-lg) !important;
  object-fit: cover !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 4/5 !important;
  max-height: 560px !important;
  box-shadow: var(--eg-sh-lg) !important;
  display: block !important;
}

/* Bouton standard (pas .cc-jumbo, pas .cc-contact-us) */
a.button:not(.cc-jumbo-button):not(.cc-contact-us):not(.cc-jumbo-white) {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: var(--eg-dk) !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  padding: 12px 26px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  border: none !important;
  margin-top: 28px !important;
  transition: var(--eg-tr) !important;
  line-height: 1.4 !important;
}
a.button:not(.cc-jumbo-button):not(.cc-contact-us):not(.cc-jumbo-white):hover {
  background: var(--eg-dk2) !important;
  transform: translateY(-1px);
  box-shadow: var(--eg-sh) !important;
  color: #fff !important;
}
a.button .text-block-9,
a.button .bold-text-2 { color: #fff !important; }

/* ============================================================
   PROCÉDURE D'INTERVENTION — liste numérotée
   ============================================================ */
ol.list {
  counter-reset: steps !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 1.5rem 0 0 !important;
}
.list li {
  counter-increment: steps !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 16px !important;
  padding: 18px 0 !important;
  border-bottom: 1px solid var(--eg-bd-lt) !important;
  margin-bottom: 0 !important;
  font-size: 15px !important;
  color: var(--eg-mu) !important;
  line-height: 1.7 !important;
  list-style: none !important;
}
.list li:last-child { border-bottom: none !important; }
.list li strong { color: var(--eg-dk) !important; }
.list li::before {
  content: counter(steps) !important;
  min-width: 30px !important;
  width: 30px !important;
  height: 30px !important;
  background: var(--eg-or-lt) !important;
  color: var(--eg-or-dk) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
  border: 1px solid rgba(254,158,36,.18);
}

/* Lottie container à droite */
[data-animation-type="lottie"] {
  width: 100% !important;
  max-width: 480px !important;
  margin: 0 auto !important;
}

/* ============================================================
   AVIS CLIENTS — Cards Apple style
   ============================================================ */
.eg-reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}
.eg-review-card {
  background: var(--eg-bg);
  border: 1px solid var(--eg-bd);
  border-radius: var(--eg-r-lg);
  padding: 28px 26px;
  transition: var(--eg-tr);
  display: flex;
  flex-direction: column;
}
.eg-review-card:hover {
  border-color: rgba(254,158,36,.35);
  box-shadow: var(--eg-sh);
  transform: translateY(-2px);
}
.eg-review-stars {
  color: var(--eg-or);
  font-size: 14px;
  letter-spacing: 3px;
  margin-bottom: 14px;
}
.eg-review-text {
  color: var(--eg-mu);
  font-size: 14.5px;
  line-height: 1.75;
  margin: 0 0 18px;
  font-style: italic;
  flex: 1;
}
.eg-review-author {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--eg-dk);
}
.eg-review-loc {
  font-size: 12.5px;
  color: var(--eg-su);
  font-weight: 400;
  margin-left: 4px;
}

/* Neutraliser les anciens avis inline (classes w-col avec style inline) */
.w-row .w-col.w-col-4[style] .paragraph-light { font-style: normal !important; }

/* ============================================================
   ZONES D'INTERVENTION
   ============================================================ */
.eg-zones-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 48px;
}
.eg-zone-card {
  background: var(--eg-bg);
  border: 1px solid var(--eg-bd);
  border-radius: var(--eg-r-lg);
  padding: 28px 26px;
  transition: var(--eg-tr);
}
.eg-zone-card:hover {
  border-color: rgba(254,158,36,.25);
  box-shadow: var(--eg-sh-sm);
}
.eg-zone-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .11em;
  text-transform: uppercase;
  color: var(--eg-or);
  margin-bottom: 18px;
  line-height: 1.4;
}
.eg-zone-dot {
  width: 8px; height: 8px;
  background: var(--eg-or);
  border-radius: 50%;
  flex-shrink: 0;
}
.eg-zone-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.eg-zone-list li {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 10px 0 !important;
  font-size: 14.5px !important;
  color: var(--eg-mu) !important;
  border-bottom: 1px solid var(--eg-bd-lt) !important;
  margin-bottom: 0 !important;
  list-style: none !important;
}
.eg-zone-list li:last-child { border-bottom: none !important; }
.eg-zone-list li::before {
  content: '' !important;
  width: 5px !important; height: 5px !important;
  background: var(--eg-or) !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  display: inline-block !important;
}
.eg-zone-list a {
  color: var(--eg-mu) !important;
  text-decoration: none !important;
  display: inline !important;
  transition: color .2s !important;
}
.eg-zone-list a:hover { color: var(--eg-or) !important; }
.eg-zone-list li strong { color: var(--eg-dk); font-weight: 600; }

.eg-zone-note {
  text-align: center;
  margin-top: 32px;
  font-size: 14.5px;
  color: var(--eg-mu);
}
.eg-zone-note strong { color: var(--eg-dk); }

/* ============================================================
   BLOG CARDS
   ============================================================ */
.blog-heading { text-align: center; margin-bottom: 0; }
.work-heading { color: var(--eg-dk); margin: 0 0 16px !important; }

/* Grid 3 colonnes pour w-row du blog */
.section .w-row {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
  margin: 48px 0 0 !important;
}
.section .w-row::before,
.section .w-row::after { display: none !important; }
.section .w-row .w-col.w-col-4 {
  background: var(--eg-bg) !important;
  border: 1px solid var(--eg-bd) !important;
  border-radius: var(--eg-r-lg) !important;
  overflow: hidden !important;
  padding: 0 !important;
  transition: var(--eg-tr) !important;
  float: none !important;
  width: auto !important;
  display: flex !important;
  flex-direction: column !important;
}
.section .w-row .w-col.w-col-4:hover {
  box-shadow: var(--eg-sh) !important;
  transform: translateY(-3px) !important;
  border-color: rgba(254,158,36,.25) !important;
}
.image-4 {
  width: 100% !important;
  height: 180px !important;
  object-fit: cover !important;
  border-radius: 0 !important;
  margin: 0 !important;
  display: block !important;
  order: 1;
}
.text-block-8 {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  color: var(--eg-or) !important;
  opacity: 1 !important;
  margin: 22px 22px 6px !important;
  order: 2;
}
a.link {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--eg-dk) !important;
  line-height: 1.4 !important;
  letter-spacing: -.01em !important;
  text-decoration: none !important;
  padding: 0 22px !important;
  display: block !important;
  transition: color .2s !important;
  margin-top: 0 !important;
  order: 3;
}
a.link:hover { color: var(--eg-or) !important; }
.text-block-5 {
  font-size: 13.5px !important;
  color: var(--eg-mu) !important;
  line-height: 1.65 !important;
  padding: 10px 22px 22px !important;
  margin-top: auto !important;
  display: block !important;
  order: 4;
}

/* ============================================================
   FAQ
   ============================================================ */
.eg-faq-list {
  max-width: 740px;
  margin: 48px auto 0;
}
.eg-faq-item {
  border-bottom: 1px solid var(--eg-bd);
  padding: 22px 0;
}
.eg-faq-item:first-child { border-top: 1px solid var(--eg-bd); }
.eg-faq-question {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 15.5px;
  font-weight: 600;
  color: var(--eg-dk);
  line-height: 1.5;
  margin: 0 0 12px;
  letter-spacing: -.01em;
}
.eg-faq-question::before {
  content: 'Q';
  min-width: 26px; height: 26px;
  background: var(--eg-or-lt);
  color: var(--eg-or-dk);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
  margin-top: 1px;
  border: 1px solid rgba(254,158,36,.18);
}
.eg-faq-answer {
  font-size: 14.5px;
  color: var(--eg-mu);
  line-height: 1.8;
  padding-left: 40px;
  margin: 0;
}
.eg-faq-answer strong { color: var(--eg-dk); font-weight: 600; }

/* ============================================================
   CTA FINAL (section sombre)
   ============================================================ */
.section.cc-cta {
  background: var(--eg-dk) !important;
  background-image: radial-gradient(ellipse 65% 75% at 82% 50%, rgba(254,158,36,.1) 0%, transparent 55%) !important;
  padding: 80px 48px !important;
  margin: 0 !important;
}
.cta-wrap {
  max-width: 1140px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 40px !important;
  padding: 0 !important;
  width: 100% !important;
}
.cta-wrap > div:first-child {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 40px !important;
  width: 100% !important;
}
.cta-text { flex: 1 !important; }
.cta-text h2 {
  color: #fff !important;
  margin: 0 0 12px !important;
  font-size: clamp(1.4rem, 2.5vw, 1.85rem) !important;
}
.paragraph-bigger.cc-bigger-light {
  color: rgba(255,255,255,.65) !important;
  opacity: 1 !important;
  font-size: 15.5px !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}
.paragraph-bigger.cc-bigger-light strong { color: var(--eg-or) !important; }

/* ============================================================
   FOOTER COMPLET
   ============================================================ */
/* Masquer le footer original minimaliste qui contient juste le logo */
.section:last-of-type:has(> .container > .footer-wrap) {
  display: none !important;
}

/* Nouveau footer */
.eg-footer {
  background: var(--eg-dk);
  color: rgba(255,255,255,.65);
  padding: 64px 48px 24px;
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
}
.eg-footer-inner {
  max-width: 1140px;
  margin: 0 auto;
}
.eg-footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1.3fr;
  gap: 40px;
  margin-bottom: 40px;
}
.eg-footer-col-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--eg-or);
  margin: 0 0 16px;
}
.eg-footer-brand img {
  height: 44px;
  width: auto;
  max-width: 100%;
  margin-bottom: 16px;
  display: block;
}
.eg-footer-tagline {
  font-size: 13.5px;
  color: rgba(255,255,255,.5);
  line-height: 1.65;
  margin: 0 0 16px;
  max-width: 240px;
}
.eg-footer-email {
  color: rgba(255,255,255,.75);
  font-size: 13.5px;
  text-decoration: none;
  transition: color .2s;
}
.eg-footer-email:hover { color: var(--eg-or); }

.eg-footer-nav { list-style: none; padding: 0; margin: 0; }
.eg-footer-nav li { margin-bottom: 10px; }
.eg-footer-nav a {
  color: rgba(255,255,255,.65);
  font-size: 14px;
  text-decoration: none;
  transition: color .2s;
  display: inline;
}
.eg-footer-nav a:hover { color: var(--eg-or); }

.eg-footer-coord { font-size: 13.5px; line-height: 1.7; color: rgba(255,255,255,.65); }
.eg-footer-coord strong { color: rgba(255,255,255,.88); font-weight: 600; display: block; margin-bottom: 2px; }
.eg-footer-coord-block { margin-bottom: 14px; }
.eg-footer-phone {
  color: var(--eg-or) !important;
  font-weight: 700;
  text-decoration: none;
  display: inline;
  font-size: 14.5px;
}
.eg-footer-phone:hover { color: var(--eg-or-dk) !important; }

.eg-footer-zones {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 16px;
}
.eg-footer-zones a {
  color: rgba(255,255,255,.6);
  font-size: 13px;
  text-decoration: none;
  transition: color .2s;
  display: inline;
}
.eg-footer-zones a:hover { color: var(--eg-or); }

.eg-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.eg-footer-copy {
  font-size: 12.5px;
  color: rgba(255,255,255,.4);
  margin: 0;
}
.eg-footer-legal {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  font-size: 12.5px;
}
.eg-footer-legal a {
  color: rgba(255,255,255,.55);
  text-decoration: none;
  transition: color .2s;
  display: inline;
}
.eg-footer-legal a:hover { color: var(--eg-or); }

/* ============================================================
   BOUTON TÉLÉPHONE FLOTTANT (mobile uniquement)
   ============================================================ */
.eg-phone-float {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 998;
  align-items: center;
  gap: 8px;
  background: var(--eg-or);
  color: #222 !important;
  padding: 14px 22px;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 6px 24px rgba(254,158,36,.45), 0 2px 8px rgba(0,0,0,.12);
  transition: var(--eg-tr);
  opacity: 0;
  transform: translateY(20px);
  pointer-events: none;
}
.eg-phone-float.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.eg-phone-float:hover {
  background: var(--eg-or-dk);
  transform: translateY(-2px);
  color: #222 !important;
}
.eg-phone-float svg {
  width: 18px;
  height: 18px;
}

/* ============================================================
   PAGES SPÉCIFIQUES — about, contact, blog
   ============================================================ */

/* Force le centrage de l'icône + titre dans moto-wrap-1 (page about) */
.moto-wrap-1 .image-2 {
  display: block !important;
  margin: 0 auto 20px !important;
  padding: 0 !important;
}
.moto-wrap-1 .heading-2 {
  text-align: center !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  font-size: 1.35rem !important;
  font-weight: 600 !important;
  color: var(--eg-dk) !important;
  line-height: 1.45 !important;
  max-width: 720px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Texte about-story-wrap bien centré et lisible */
.about-story-wrap {
  text-align: center !important;
  max-width: 780px !important;
  width: 100% !important;
  margin: 60px auto !important;
}
.about-story-wrap .paragraph-light {
  text-align: center !important;
  font-size: 15.5px !important;
  line-height: 1.75 !important;
  color: var(--eg-mu) !important;
}

/* Heading-jumbo → H1 des pages about/contact (fallback si utilisé) */
h1.heading-jumbo, .heading-jumbo {
  font-size: clamp(2rem, 5vw, 3.5rem) !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: -.03em !important;
  line-height: 1.1 !important;
  margin: 0 !important;
  text-align: center;
}

/* Formulaire contact */
.contact-form-wrap {
  background: #fff;
  padding: 36px 32px;
  border-radius: 16px;
  border: 1px solid var(--eg-bd);
  box-shadow: var(--eg-sh-sm);
}
.contact-heading {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--eg-dk) !important;
  margin: 0 0 8px !important;
}
.contact-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--eg-dk);
  margin: 16px 0 6px;
}
.contact-form .text-field.cc-contact-field,
.contact-form textarea.text-field,
.contact-form select.text-field {
  width: 100% !important;
  padding: 12px 14px !important;
  border: 1px solid var(--eg-bd) !important;
  border-radius: 10px !important;
  background: #fff !important;
  font-size: 14px !important;
  font-family: inherit !important;
  color: var(--eg-tx) !important;
  transition: var(--eg-tr) !important;
  height: auto !important;
  box-shadow: none !important;
}
.contact-form .text-field:focus {
  border-color: var(--eg-or) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(254,158,36,.15) !important;
}
.contact-form textarea.text-field {
  min-height: 120px !important;
  resize: vertical;
}
.contact-form .button,
.contact-form input[type="submit"] {
  background: var(--eg-or) !important;
  color: #222 !important;
  border-radius: 100px !important;
  padding: 14px 28px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  border: none !important;
  cursor: pointer;
  margin-top: 20px;
  transition: var(--eg-tr);
}
.contact-form .button:hover,
.contact-form input[type="submit"]:hover {
  background: var(--eg-or-dk) !important;
  color: #fff !important;
}

/* Articles de blog : typographie lisible */
.blog-post-content,
.section .container .paragraph-light {
  max-width: 720px;
}
.section .container h2 + .paragraph-light,
.section .container h3 + .paragraph-light {
  margin-top: 12px;
}



/* BUG 1 : "Intervention locale" collé au hero
   Les pages locales mettent le hero + le titre "Intervention locale"
   dans la même section .cc-store-home-wrap. On ajoute du padding
   au .container qui suit l'intro-header. */
.section.cc-store-home-wrap > .container {
  padding-top: 80px !important;
  padding-bottom: 20px !important;
}

/* BUG 2 : Icônes services trop grandes et mal placées
   Les pages locales ont des <img width="64"> dans des w-col sans wrapper.
   On contraint leur taille et on les centre proprement. */
.section .w-row .w-col-4 > img[width="64"],
.section .w-row .w-col-4 > img[alt*="destruction"],
.section .w-row .w-col-4 > img[alt*="prévention"] {
  width: 56px !important;
  height: 56px !important;
  object-fit: contain !important;
  display: block !important;
  margin: 0 auto 18px !important;
  padding: 12px !important;
  background: var(--eg-or-soft) !important;
  border-radius: 14px !important;
  border: 1px solid var(--eg-or-mid) !important;
}

/* Améliorer l'espacement interne des cards service */
.section .w-row .w-col-4[style*="padding:1rem"] {
  padding: 28px 20px !important;
  background: #fff !important;
  border: 1px solid var(--eg-bd) !important;
  border-radius: 16px !important;
  margin: 0 8px !important;
  transition: var(--eg-tr) !important;
}
.section .w-row .w-col-4[style*="padding:1rem"]:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(17,17,17,.08);
  border-color: var(--eg-or-mid);
}
.section .w-row .w-col-4[style*="padding:1rem"] h3 {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: var(--eg-dk) !important;
  margin: 4px 0 10px !important;
  line-height: 1.3 !important;
}
.section .w-row .w-col-4[style*="padding:1rem"] .paragraph-light {
  font-size: 14.5px !important;
  color: var(--eg-tx2) !important;
  line-height: 1.55 !important;
  margin: 0 !important;
}

/* Container du w-row service : un vrai grid qui respire */
.section > .container > .w-row[style*="margin-top:2rem"] {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 18px !important;
  margin-top: 32px !important;
}
.section > .container > .w-row[style*="margin-top:2rem"] > .w-col {
  width: auto !important;
  max-width: none !important;
  float: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  min-height: auto !important;
}


@keyframes eg-fade-up {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.eg-fade-in { animation: eg-fade-up .6s ease both; }

/* Respecte les préférences d'accessibilité */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

/* ============================================================
   RESPONSIVE — TABLETTE (≤ 1024px)
   ============================================================ */
@media (max-width: 1024px) {
  .navigation-wrap { padding: 0 32px !important; height: 64px !important; }
  .intro-header { padding: 96px 32px 80px !important; min-height: 560px !important; }
  .section { padding: 72px 32px !important; }
  .section.cc-cta { padding: 72px 32px !important; }
  .eg-footer { padding: 56px 32px 24px; }

  .about-grid, .about-grid.cc-about-2 {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  .about-grid img.image-5 {
    aspect-ratio: 16/10 !important;
    max-height: 420px !important;
    max-width: 540px !important;
    margin: 0 auto !important;
  }
  .eg-reviews-grid { grid-template-columns: 1fr 1fr !important; }
  .section .w-row { grid-template-columns: 1fr 1fr !important; }
  .eg-zones-grid { grid-template-columns: 1fr !important; }

  .cta-wrap,
  .cta-wrap > div:first-child {
    flex-direction: column !important;
    text-align: center !important;
    gap: 28px !important;
  }
  .hero-stats { gap: 24px; margin-top: 44px; padding-top: 28px; }

  .eg-footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 40px 24px !important;
  }
}

/* ============================================================
   RESPONSIVE — MOBILE (≤ 640px)
   ============================================================ */
@media (max-width: 640px) {
  .navigation-wrap { padding: 0 16px !important; height: 58px !important; }
  .button.cc-contact-us.w-inline-block { display: none !important; }

  /* Conteneur du menu : on l'aligne à droite et on réduit sa taille */
  .menu {
    position: static !important;
    flex: 0 0 auto !important;
    justify-content: flex-end !important;
    gap: 0 !important;
  }

  /* Burger : visible et cliquable */
  .menu-button.w-nav-button {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 8px !important;
    background: #fff !important;
    border: 1px solid var(--eg-bd) !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    width: 44px !important;
    height: 44px !important;
    position: relative !important;
    z-index: 1001 !important;
    -webkit-tap-highlight-color: rgba(254,158,36,.2);
    touch-action: manipulation;
    user-select: none;
    -webkit-user-select: none;
  }
  .menu-button.w-nav-button:active {
    background: var(--eg-bg2) !important;
  }
  /* Image dans le bouton : ne doit PAS intercepter les clics */
  .menu-button.w-nav-button .menu-icon,
  .menu-button.w-nav-button img {
    width: 20px !important;
    height: auto !important;
    pointer-events: none !important;
  }

  /* Menu déroulant : fermé par défaut, ouvert via classe .eg-open */
  .navigation-items.w-nav-menu {
    display: none !important;
    position: fixed !important;
    top: 58px !important;
    left: 0 !important;
    right: 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    background: #fff !important;
    border-bottom: 1px solid var(--eg-bd) !important;
    padding: 8px 0 12px !important;
    gap: 0 !important;
    box-shadow: 0 8px 24px rgba(0,0,0,.1) !important;
    z-index: 997 !important;
    max-height: calc(100vh - 58px);
    overflow-y: auto;
  }
  /* Ouvert : on supporte les 2 classes (w--open de Webflow + eg-open custom) */
  .navigation-items.w-nav-menu.w--open,
  .navigation-items.w-nav-menu.eg-open {
    display: flex !important;
  }

  /* Items dans le menu déroulant */
  .navigation-item.w-nav-link {
    padding: 14px 20px !important;
    border-radius: 0 !important;
    text-align: left !important;
    width: 100% !important;
    font-size: 15px !important;
    border-bottom: 1px solid var(--eg-bd-lt);
  }
  .navigation-item.w-nav-link:last-child { border-bottom: none; }
  .navigation-item.w-nav-link:hover {
    background: var(--eg-bg2) !important;
  }

  /* Désactiver l'overlay Webflow qui peut bloquer les clics */
  .w-nav-overlay {
    display: none !important;
  }

  .intro-header { padding: 72px 20px 60px !important; min-height: auto !important; }
  .section { padding: 56px 20px !important; }
  .section.cc-cta { padding: 56px 20px !important; }
  .eg-footer { padding: 48px 20px 24px; }

  h1, h1.heading { font-size: 1.75rem !important; line-height: 1.15 !important; }
  h2 { font-size: 1.5rem !important; }

  .hero-ctas { flex-direction: column; width: 100%; gap: 10px; }
  .hero-ctas > a { width: 100% !important; }
  .hero-stats { gap: 12px; margin-top: 40px; padding-top: 24px; }
  .hero-stat-divider { display: none; }
  .hero-stat { flex: 1 0 40%; }
  .hero-stat-num { font-size: 1.4rem; }

  .home-content-wrap { margin-top: 40px !important; }
  .about-grid { gap: 32px !important; }
  .about-grid img.image-5 { max-height: 360px !important; aspect-ratio: 4/3 !important; }

  .eg-reviews-grid { grid-template-columns: 1fr !important; gap: 16px; margin-top: 36px; }
  .eg-zones-grid { gap: 16px; margin-top: 36px; }
  .section .w-row { grid-template-columns: 1fr !important; gap: 16px !important; margin-top: 36px !important; }

  .eg-faq-list { margin-top: 36px; }
  .eg-faq-answer { padding-left: 0; font-size: 14px; }
  .eg-faq-question { font-size: 15px; }

  /* Bouton téléphone flottant : actif mobile */
  .eg-phone-float { display: inline-flex; }

  .eg-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .eg-footer-zones { grid-template-columns: 1fr 1fr !important; }
  .eg-footer-bottom { flex-direction: column; text-align: center; gap: 8px; }
}

/* ============================================================
   Très petit mobile
   ============================================================ */
@media (max-width: 400px) {
  .navigation-wrap { padding: 0 12px !important; }
  .intro-header { padding: 60px 16px 52px !important; }
  .section { padding: 48px 16px !important; }
  h1, h1.heading { font-size: 1.55rem !important; }
  .hero-stat { flex: 1 0 100%; margin-bottom: 8px; }
  .eg-footer { padding: 40px 16px 20px; }
  .eg-footer-zones { grid-template-columns: 1fr !important; }
}
