/* =================================================================
   THERMANEX — style.css (UNE SEULE PASSE — zéro doublon)
   Chauffage · Froid · Climatisation · Ventilation · Plomberie
   ================================================================= */

/* ---------- TOKENS ---------- */
:root {
  --thx-white:#FFFFFF;
  --thx-orange:#EB692C;
  --thx-orange-600:#D2541A;
  --thx-orange-700:#B34513;
  --thx-orange-100:#FDE4D6;
  --thx-orange-50:#FEF3EB;
  --thx-blue:#2A5CBA;
  --thx-blue-700:#1F469A;
  --thx-blue-800:#173677;
  --thx-blue-900:#0F2558;
  --thx-blue-100:#D9E3F6;
  --thx-blue-50:#EEF3FB;
  --thx-ink:#0B1220;
  --thx-graphite:#1F2937;
  --thx-slate:#475569;
  --thx-steel:#94A3B8;
  --thx-mist:#CBD5E1;
  --thx-fog:#E5E7EB;
  --thx-paper:#F4F6FA;
  --thx-cloud:#F9FAFC;
  --thx-heat:#EB692C;
  --thx-cold:#2A5CBA;
  --thx-clim:#5BA8D9;
  --thx-vent:#6FB49B;
  --thx-plumb:#1D7FB8;
  --border:var(--thx-fog);
  --border-strong:var(--thx-mist);
  --fg:var(--thx-ink);
  --fg-muted:var(--thx-slate);
  --fg-subtle:var(--thx-steel);
  --font-display:'Work Sans','Helvetica Neue',Arial,sans-serif;
  --font-body:'Inter','Helvetica Neue',Arial,sans-serif;
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --ease-std:cubic-bezier(0.4,0,0.2,1);
  --shadow-xs:0 1px 2px rgba(11,18,32,.04);
  --shadow-sm:0 1px 3px rgba(11,18,32,.06),0 1px 2px rgba(11,18,32,.04);
  --shadow-md:0 4px 10px rgba(11,18,32,.08),0 1px 3px rgba(11,18,32,.04);
  --shadow-lg:0 12px 28px rgba(11,18,32,.10),0 4px 10px rgba(11,18,32,.05);
  --shadow-xl:0 28px 60px rgba(11,18,32,.14),0 10px 20px rgba(11,18,32,.06);
  --shadow-accent:0 10px 24px rgba(235,105,44,.28);
  --shadow-brand:0 10px 24px rgba(42,92,186,.22);
  --ring-focus:0 0 0 3px rgba(42,92,186,.35);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);color:var(--fg);background:#fff;-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font:inherit;border:none;background:none;cursor:pointer;color:inherit;}
input,select,textarea{font:inherit;color:inherit;}
::selection{background:var(--thx-orange-100);color:var(--thx-orange-700);}

/* ---------- CONTAINER ---------- */
.container{max-width:1216px;margin:0 auto;padding:0 48px;}
@media(max-width:1100px){.container{padding:0 32px;}}
@media(max-width:640px){.container{padding:0 20px;}}

/* ---------- TYPOGRAPHY ---------- */
.eyebrow{font-family:var(--font-body);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.14em;color:var(--thx-orange);margin:0 0 14px;display:inline-flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";display:inline-block;width:28px;height:2px;background:var(--thx-orange);}
.h1{font-family:var(--font-display);font-weight:800;font-size:clamp(34px,4.8vw,58px);line-height:1.05;letter-spacing:-.025em;color:var(--thx-blue-800);margin:0 0 20px;text-wrap:balance;}
.h2{font-family:var(--font-display);font-weight:800;font-size:clamp(26px,3.2vw,40px);line-height:1.1;letter-spacing:-.02em;color:var(--thx-blue-800);margin:0 0 16px;text-wrap:balance;}
.h3{font-family:var(--font-display);font-weight:700;font-size:clamp(18px,1.6vw,22px);line-height:1.25;color:var(--thx-blue-800);margin:0 0 8px;}
.h4{font-family:var(--font-display);font-weight:700;font-size:17px;line-height:1.3;color:var(--thx-blue-800);margin:0 0 6px;}
.lead{font-family:var(--font-body);font-size:17px;line-height:1.65;color:var(--fg-muted);margin:0 0 28px;text-wrap:pretty;}
.p{font-size:15px;line-height:1.65;color:var(--fg-muted);margin:0;text-wrap:pretty;}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:600;font-size:15px;padding:12px 22px;border-radius:10px;border:1.5px solid transparent;transition:background .18s var(--ease-std),color .18s var(--ease-std),border-color .18s var(--ease-std),transform .18s var(--ease-std),box-shadow .18s var(--ease-std);white-space:nowrap;cursor:pointer;text-decoration:none;}
.btn:focus-visible{outline:none;box-shadow:var(--ring-focus);}
.btn .arrow{display:inline-flex;transition:transform .2s var(--ease-out);}
.btn:hover .arrow{transform:translateX(4px);}
.btn.primary{background:var(--thx-orange);color:#fff;box-shadow:var(--shadow-accent);}
.btn.primary:hover{background:var(--thx-orange-600);}
.btn.primary:active{background:var(--thx-orange-700);transform:translateY(1px);}
.btn.secondary{background:var(--thx-blue);color:#fff;}
.btn.secondary:hover{background:var(--thx-blue-700);}
.btn.ghost{background:transparent;color:var(--thx-blue-800);border-color:var(--thx-mist);}
.btn.ghost:hover{background:var(--thx-blue-50);border-color:var(--thx-blue);}
.btn.inverse{background:#fff;color:var(--thx-blue-800);}
.btn.inverse:hover{background:var(--thx-blue-50);}
.btn.lg{padding:15px 28px;font-size:16px;border-radius:12px;}
.btn.block{display:flex;justify-content:center;width:100%;}

/* ---------- BADGES ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 12px;border-radius:999px;letter-spacing:.01em;}
.badge-orange{background:var(--thx-orange-100);color:var(--thx-orange-700);}
.badge-blue{background:var(--thx-blue-100);color:var(--thx-blue-800);}
.badge-outline{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;}
.badge-outline-dark{background:#fff;border:1px solid var(--border-strong);color:var(--thx-graphite);}

/* ---------- PULSE DOT ---------- */
.pulse-dot{width:9px;height:9px;border-radius:999px;background:#22c55e;position:relative;display:inline-block;flex-shrink:0;}
.pulse-dot::after{content:"";position:absolute;inset:-4px;border-radius:999px;background:#22c55e;opacity:.4;animation:pulse 1.8s var(--ease-out) infinite;}
@keyframes pulse{0%{transform:scale(.6);opacity:.6;}70%{transform:scale(1.8);opacity:0;}100%{transform:scale(1.8);opacity:0;}}

/* ---------- STARS ---------- */
.stars{display:inline-flex;gap:2px;color:var(--thx-orange);}
.stars svg{fill:currentColor;}

/* ---------- REVEAL ANIMATION ---------- */
/* opacity:0 uniquement quand JS est chargé, sinon contenu toujours visible */
.js-loaded .reveal{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out);}
.js-loaded .reveal.in{opacity:1;transform:translateY(0);}

/* ---------- CARD BASE ---------- */
.card{background:#fff;border:1px solid var(--border);border-radius:16px;transition:transform .22s var(--ease-out),box-shadow .22s var(--ease-out);}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}

/* ---------- SECTIONS ---------- */
.section{padding:88px 0;position:relative;}
.section.tight{padding:56px 0;}
.section.alt{background:var(--thx-cloud);}
.section.soft-blue{background:var(--thx-blue-50);}
.section.dark{background:var(--thx-ink);color:rgba(255,255,255,.82);}
.section.dark .h1,.section.dark .h2,.section.dark .h3,.section.dark .h4{color:#fff;}
.section.dark .lead{color:rgba(255,255,255,.72);}
@media(max-width:760px){.section{padding:60px 0;}.section.tight{padding:40px 0;}}

/* ---------- GRIDS ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:900px){.grid-2{grid-template-columns:1fr;gap:40px;}.grid-3{grid-template-columns:1fr 1fr;}.grid-4{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.grid-3,.grid-4{grid-template-columns:1fr;}}

/* ---------- SECTION HEADER ---------- */
.section-header{margin-bottom:40px;}
.section-header.center{text-align:center;}
.section-header.center .eyebrow{justify-content:center;}
.section-header.center .lead{margin-left:auto;margin-right:auto;max-width:600px;}
.section-header.with-cta{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;}
.section-header.with-cta .section-header-text{flex:1;}

/* ---------- HEADER ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);transition:box-shadow .2s var(--ease-std);}
.site-header.scrolled{box-shadow:var(--shadow-sm);}
.site-header .bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:14px 0;gap:24px;}
.site-header .logo img{height:52px;width:auto;}
.site-header nav{display:flex;gap:24px;}
.site-header nav a{font-size:14px;font-weight:500;color:var(--thx-graphite);position:relative;padding:8px 2px;transition:color .18s var(--ease-std);}
.site-header nav a:hover{color:var(--thx-blue-800);}
.site-header nav a.active{color:var(--thx-blue-800);font-weight:600;}
.site-header nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-16px;height:3px;background:var(--thx-orange);border-radius:3px 3px 0 0;}
.site-header .phone-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--thx-blue-800);}
.site-header .right{display:flex;align-items:center;gap:14px;justify-self:end;}
.menu-toggle{display:none;padding:8px;}
.has-dropdown{position:relative;}
.dropdown{position:absolute;top:calc(100% + 12px);left:-16px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px;min-width:250px;box-shadow:var(--shadow-lg);opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s var(--ease-std),transform .18s var(--ease-std);}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;transform:translateY(0);pointer-events:auto;}
.dropdown a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:14px;color:var(--thx-graphite);}
.dropdown a:hover{background:var(--thx-blue-50);color:var(--thx-blue-800);}
.dropdown a .dot{width:8px;height:8px;border-radius:999px;flex-shrink:0;}
@media(max-width:980px){.site-header nav{display:none;}.site-header .phone-link .num{display:none;}.menu-toggle{display:inline-flex;}}
.mobile-menu{display:none;position:fixed;inset:73px 0 0;background:#fff;z-index:70;padding:20px;overflow:auto;border-top:1px solid var(--border);}
.mobile-menu.open{display:block;}
.mobile-menu a{display:block;padding:13px 4px;font-size:16px;font-weight:600;color:var(--thx-blue-800);border-bottom:1px solid var(--border);}
.mobile-menu .sub{padding-left:16px;font-size:14px;font-weight:500;color:var(--thx-graphite);}

/* ---------- PHONE FAB (réductible) ---------- */
.phone-fab-wrap{position:fixed;z-index:60;right:20px;bottom:20px;}
.phone-fab{display:inline-flex;align-items:center;gap:10px;background:var(--thx-orange);color:#fff;padding:12px 13px 12px 20px;border-radius:999px;box-shadow:var(--shadow-accent),var(--shadow-lg);font-weight:700;font-size:15px;transition:background .2s var(--ease-std);animation:fab-pop .26s var(--ease-out);}
.phone-fab-link{display:inline-flex;align-items:center;gap:10px;color:#fff;}
.phone-fab:hover{background:var(--thx-orange-600);}
.phone-fab .pulse-dot{background:#fff;}
.phone-fab .pulse-dot::after{background:#fff;}
.phone-fab-close{display:grid;place-items:center;width:24px;height:24px;border-radius:999px;background:rgba(255,255,255,.22);color:#fff;flex-shrink:0;transition:background .18s,transform .18s;}
.phone-fab-close:hover{background:rgba(255,255,255,.4);transform:rotate(90deg);}
.phone-fab-mini{position:relative;display:grid;place-items:center;width:56px;height:56px;border-radius:999px;background:var(--thx-orange);color:#fff;box-shadow:var(--shadow-accent),var(--shadow-lg);transition:transform .2s var(--ease-out),background .2s;animation:fab-pop .26s var(--ease-out);}
.phone-fab-mini:hover{background:var(--thx-orange-600);transform:scale(1.06);}
.phone-fab-mini .pulse-dot{position:absolute;top:7px;right:7px;background:#22c55e;}
.phone-fab-wrap.collapsed .phone-fab{display:none;}
.phone-fab-wrap:not(.collapsed) .phone-fab-mini{display:none;}
@keyframes fab-pop{from{opacity:0;transform:scale(.6);}to{opacity:1;transform:scale(1);}}
@media(min-width:980px){.phone-fab-wrap{right:auto;left:20px;bottom:auto;top:50%;transform:translateY(-50%) rotate(-90deg);transform-origin:center;}.phone-fab{padding:11px 18px;border-radius:0 0 14px 14px;animation:none;}.phone-fab-close{display:none;}}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--thx-ink);color:rgba(255,255,255,.72);padding:72px 0 28px;position:relative;overflow:hidden;}
.site-footer::before{content:"";position:absolute;top:-100px;right:-100px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(235,105,44,.16),transparent 65%);filter:blur(30px);pointer-events:none;}
.footer-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px;}
.footer-logo{filter:brightness(0) invert(1);height:40px;width:auto;margin-bottom:14px;}
.footer-desc{font-size:14px;line-height:1.6;max-width:280px;margin-bottom:16px;}
.footer-badges{display:flex;flex-wrap:wrap;gap:8px;}
.footer-col-title{font-family:var(--font-display);font-weight:700;font-size:12px;color:#fff;margin:0 0 14px;text-transform:uppercase;letter-spacing:.12em;}
.footer-cols ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px;font-size:14px;}
.site-footer a{opacity:.75;transition:opacity .18s,color .18s;}
.site-footer a:hover{opacity:1;color:var(--thx-orange);}
.site-footer .cta-link{color:var(--thx-orange);opacity:.95;}
.site-footer .cta-link:hover{opacity:1;}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:14px;margin-bottom:10px;}
.footer-contact-item svg{flex-shrink:0;margin-top:2px;opacity:.6;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:rgba(255,255,255,.5);}
.footer-bottom a{opacity:.6;}
.footer-bottom a:hover{opacity:1;}
@media(max-width:900px){.footer-cols{grid-template-columns:1fr 1fr;gap:28px;}}
@media(max-width:560px){.footer-cols{grid-template-columns:1fr;}}

/* ---------- HERO HOME ---------- */
/* RÈGLE N°1 : grille 2 colonnes sur .hero-home-grid (wrapper commun texte+image), JAMAIS sur le conteneur de texte seul */
.hero-home{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 60%,var(--thx-blue-900) 100%);color:#fff;padding:76px 0;overflow:hidden;}
.hero-home-grid{display:grid;grid-template-columns:3fr 2fr;gap:48px;align-items:center;}
.hero-home-text{display:flex;flex-direction:column;padding-bottom:0;}
.hero-home-text .h1{color:#fff;margin-bottom:18px;}
.hero-home-text .lead{color:rgba(255,255,255,.82);max-width:520px;}
.hero-home-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;}
.hero-home-trust{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:14px;color:rgba(255,255,255,.75);}
.hero-trust-rating{font-family:var(--font-display);font-weight:800;font-size:18px;color:#fff;}
.hero-trust-sep{width:1px;height:16px;background:rgba(255,255,255,.3);display:inline-block;}
.hero-home-visual{position:relative;align-self:center;}
.hero-home-visual img{width:100%;max-height:440px;object-fit:cover;object-position:center;border-radius:18px;display:block;box-shadow:var(--shadow-xl);}
@media(max-width:900px){.hero-home-grid{grid-template-columns:1fr;}.hero-home-text{padding-bottom:48px;}.hero-home-visual{display:none;}}

/* Stat bubbles hero */
.stat-bubble{position:absolute;background:#fff;border-radius:14px;padding:11px 15px;display:flex;align-items:center;gap:11px;box-shadow:var(--shadow-lg);}
.stat-bubble.b1{top:16px;right:-16px;}
.stat-bubble.b2{bottom:80px;left:-16px;}
.stat-bubble.b3{bottom:190px;right:-16px;}
.stat-bubble-icon{width:36px;height:36px;border-radius:9px;background:var(--thx-blue-50);color:var(--thx-blue);display:grid;place-items:center;flex-shrink:0;}
.stat-bubble-value{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--thx-blue-800);line-height:1;}
.stat-bubble-label{font-size:10px;color:var(--fg-muted);}
@media(max-width:1100px){.stat-bubble{display:none;}}

/* ---------- LOGO BAR ---------- */
.logo-bar{background:var(--thx-cloud);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:22px 0;overflow:hidden;}
.logo-bar-inner{display:flex;align-items:center;gap:28px;}
.logo-bar-label{font-size:11px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;flex-shrink:0;}
.logo-bar-track{flex:1;overflow:hidden;}
.logo-bar-track-inner{display:flex;gap:44px;animation:marquee 30s linear infinite;}
.logo-bar-item{font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--thx-steel);letter-spacing:.05em;white-space:nowrap;}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ---------- HERO PAGE SIMPLE ---------- */
.hero-page{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);color:#fff;padding:72px 0;}
.hero-page .h1{color:#fff;margin-bottom:14px;}
.hero-page .lead{color:rgba(255,255,255,.8);margin-bottom:0;}
.hero-ville-ctas{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;}
/* Hero page 2 colonnes (zone : texte+CTA / carte) */
.hero-page-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
.hero-page-visual img{width:100%;border-radius:18px;background:#fff;padding:10px;box-shadow:var(--shadow-lg);display:block;}
@media(max-width:900px){.hero-page-grid{grid-template-columns:1fr;}.hero-page-visual{display:none;}}

/* ---------- HERO SERVICE ---------- */
.hero-service{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 60%,var(--thx-blue-900) 100%);color:#fff;padding:72px 0;overflow:hidden;}
.hero-service h1{font-family:var(--font-display);font-weight:800;font-size:clamp(28px,3.6vw,46px);line-height:1.08;letter-spacing:-.025em;color:#fff;margin:0 0 18px;text-wrap:balance;}
.hero-service-back{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:22px;transition:color .18s;}
.hero-service-back:hover{color:#fff;}
/* legacy grid classes kept for backward compat */
.hero-service-grid{display:grid;grid-template-columns:3fr 2fr;gap:48px;align-items:center;}
.hero-service-text{display:flex;flex-direction:column;}
.hero-service-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px;}
.hero-service-visual img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;box-shadow:var(--shadow-xl);}
@media(max-width:900px){.hero-service-grid{grid-template-columns:1fr;}.hero-service-visual{display:none;}}

/* ---------- PRÉSENTATION ---------- */
.presentation-piliers{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;}
.presentation-pilier{padding:13px;border-radius:10px;background:var(--thx-blue-50);border:1px solid var(--border);}
.presentation-pilier-tag{width:8px;height:8px;border-radius:2px;background:var(--thx-orange);margin-bottom:5px;}
.presentation-pilier-title{font-family:var(--font-display);font-weight:700;color:var(--thx-blue-800);font-size:14px;margin-bottom:3px;}
.presentation-pilier-desc{font-size:13px;color:var(--fg-muted);line-height:1.5;}
.presentation-chiffres{display:flex;gap:24px;margin-top:28px;flex-wrap:wrap;}
.presentation-chiffre{border-left:3px solid var(--thx-orange);padding-left:13px;}
.presentation-chiffre-value{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--thx-blue-800);line-height:1;}
.presentation-chiffre-label{font-size:12px;color:var(--fg-muted);margin-top:4px;}
.presentation-visual{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-xl);}

/* ---------- SERVICES GRID ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
@media(max-width:900px){.services-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr;}}

.carte-service{position:relative;background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px;text-decoration:none;color:var(--thx-ink);display:flex;flex-direction:column;gap:13px;transition:transform .22s var(--ease-out),box-shadow .22s var(--ease-out),border-color .22s;}
.carte-service .cta-link::after{content:"";position:absolute;inset:0;z-index:1;}
.carte-service:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent,var(--thx-orange));}
.carte-service.vedette{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);border-color:transparent;color:#fff;}
.carte-service.vedette .h3,.carte-service.vedette .p{color:rgba(255,255,255,.9);}
.carte-service.vedette .cta-link{color:#fff;}
.carte-service.vedette .carte-service-icon{background:rgba(255,255,255,.15);}
.carte-service-icon{width:42px;height:42px;border-radius:10px;background:var(--accent,var(--thx-blue-50));color:#fff;display:grid;place-items:center;flex-shrink:0;}
.cta-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--accent,var(--thx-blue-800));margin-top:auto;}
.cta-link svg{transition:transform .2s var(--ease-out);}
.carte-service:hover .cta-link svg{transform:translateX(4px);}

/* ---------- RÉALISATIONS ---------- */
.realisations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.realisations-grid.auto{grid-auto-rows:minmax(260px,auto);}
@media(max-width:900px){.realisations-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.realisations-grid{grid-template-columns:1fr;}}

.carte-realisation{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--thx-ink);display:flex;flex-direction:column;transition:transform .22s var(--ease-out),box-shadow .22s;}
.carte-realisation:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.realisation-img{aspect-ratio:16/10;overflow:hidden;background:var(--thx-blue-50);}
.realisation-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s var(--ease-out);}
.carte-realisation:hover .realisation-img img{transform:scale(1.04);}
.realisation-content{padding:16px 18px;display:flex;flex-direction:column;gap:7px;flex:1;}
.realisation-meta{display:flex;gap:7px;flex-wrap:wrap;}
.realisation-tag{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--thx-blue-50);color:var(--thx-blue-800);}
.realisation-ville{font-size:11px;color:var(--fg-muted);padding:3px 0;}
.realisation-fallback{padding:26px;background:var(--thx-cloud);border-radius:14px;}
.realisation-fallback p{font-size:15px;color:var(--fg-muted);line-height:1.6;margin:0 0 14px;}

/* ---------- TÉMOIGNAGES ---------- */
.temoignages-trust{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px;margin-bottom:28px;}
.temoignages-trust-value{font-family:var(--font-display);font-weight:800;font-size:22px;color:var(--thx-blue-800);}
.temoignages-trust-meta{color:var(--fg-muted);font-size:14px;}
.temoignages-grid-top{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px;}
.temoignages-grid-bottom{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:840px;margin:0 auto;}
@media(max-width:900px){.temoignages-grid-top,.temoignages-grid-bottom{grid-template-columns:1fr;}}

.carte-temoignage{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:11px;}
.carte-temoignage.vedette{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);border:none;color:#fff;}
.carte-temoignage.vedette .temoignage-texte,.carte-temoignage.vedette .temoignage-auteur{color:rgba(255,255,255,.9);}
.temoignage-texte{font-size:14px;line-height:1.65;color:var(--thx-graphite);flex:1;font-style:italic;}
.temoignage-auteur{font-size:13px;font-weight:600;color:var(--thx-slate);}

/* ---------- ZONE ---------- */
.zone-grid-villes{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin:18px 0 22px;}
.zone-chip-item{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:14px;color:var(--thx-ink);text-decoration:none;transition:color .18s;}
.zone-chip-item .chip-dot{width:6px;height:6px;border-radius:999px;background:var(--thx-blue);flex-shrink:0;}
.zone-chip-item.main .chip-dot{background:var(--thx-orange);}
.zone-chip-item:hover{color:var(--thx-orange);}

/* ---------- AVANTAGES ---------- */
.avantages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:900px){.avantages-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.avantages-grid{grid-template-columns:1fr;}}

.carte-avantage{background:#fff;border:1px solid var(--border);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:11px;}
.carte-avantage-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--thx-orange) 0%,var(--thx-orange-600) 100%);color:#fff;display:grid;place-items:center;flex-shrink:0;box-shadow:0 5px 12px rgba(235,105,44,.28);}
.carte-avantage.cool .carte-avantage-icon{background:linear-gradient(135deg,var(--thx-blue) 0%,var(--thx-blue-700) 100%);box-shadow:0 5px 12px rgba(42,92,186,.28);}
.carte-avantage-title{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--thx-blue-800);}
.carte-avantage-desc{font-size:13px;color:var(--fg-muted);line-height:1.55;}

/* ---------- CERTIFICATIONS BADGES ---------- */
.badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:760px){.badges-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:420px){.badges-grid{grid-template-columns:1fr;}}

.badge-cert{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;}
.badge-cert-mark{width:52px;height:52px;border-radius:13px;background:var(--accent,var(--thx-blue));color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:15px;margin-bottom:3px;}
.badge-cert-name{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--thx-blue-800);}
.badge-cert-sub{font-size:12px;color:var(--fg-muted);text-align:center;}

/* ---------- MID CTA ---------- */
.mid-cta{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);border-radius:18px;padding:48px 52px;display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap;}
.mid-cta .eyebrow{color:rgba(255,255,255,.7);}
.mid-cta .eyebrow::before{background:rgba(255,255,255,.4);}
.mid-cta .h2{color:#fff;margin-bottom:8px;}
.mid-cta .lead{color:rgba(255,255,255,.78);margin-bottom:0;max-width:480px;}
.mid-cta-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;flex-shrink:0;}
.mid-cta-phone{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:600;font-size:15px;opacity:.85;transition:opacity .18s;}
.mid-cta-phone:hover{opacity:1;}
@media(max-width:760px){.mid-cta{padding:32px 24px;flex-direction:column;align-items:flex-start;}.mid-cta-actions{width:100%;}}

/* ---------- FAQ ---------- */
.faq-sticky{position:sticky;top:100px;}
@media(max-width:900px){.faq-sticky{position:static;}}
.faq-list{display:flex;flex-direction:column;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-item:first-child{border-top:1px solid var(--border);}
.faq-question{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:17px 4px;cursor:pointer;list-style:none;font-weight:600;font-size:15px;color:var(--thx-graphite);transition:color .18s;}
.faq-question::-webkit-details-marker{display:none;}
.faq-question:hover{color:var(--thx-blue-800);}
.faq-question-icon{width:22px;height:22px;flex-shrink:0;color:var(--thx-orange);transition:transform .25s var(--ease-out);}
.faq-item[open] .faq-question-icon{transform:rotate(45deg);}
.faq-answer-inner{padding:0 4px 16px;font-size:14px;line-height:1.7;color:var(--fg-muted);}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{padding:13px 0;font-size:13px;color:var(--fg-muted);}
.breadcrumb ol{display:flex;align-items:center;gap:7px;list-style:none;padding:0;margin:0;flex-wrap:wrap;}
.breadcrumb .sep{color:var(--thx-mist);}
.breadcrumb a{color:var(--fg-muted);transition:color .18s;}
.breadcrumb a:hover{color:var(--thx-orange);}

/* ---------- SERVICES ROWS (hub) ---------- */
.services-rows{display:flex;flex-direction:column;gap:18px;}
.service-row{display:grid;grid-template-columns:1.4fr 1fr;border-radius:18px;overflow:hidden;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-xs);text-decoration:none;color:var(--thx-ink);min-height:250px;transition:transform .25s var(--ease-out),box-shadow .25s;}
.service-row:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.service-row:nth-child(even){grid-template-columns:1fr 1.4fr;}
.service-row:nth-child(even) .service-row-text{order:2;}
.service-row-text{padding:34px 38px;display:flex;flex-direction:column;justify-content:center;gap:11px;}
.service-row-head{display:flex;align-items:center;gap:11px;}
.service-row-icon{width:44px;height:44px;border-radius:12px;background:var(--accent,var(--thx-orange));color:#fff;display:grid;place-items:center;flex-shrink:0;}
.service-row-tag{font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent,var(--thx-orange));}
.service-row-bullets{list-style:none;padding:0;margin:5px 0 3px;display:grid;grid-template-columns:1fr 1fr;gap:5px 18px;}
.service-row-bullets li{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--thx-graphite);}
.service-row-bullets svg{flex-shrink:0;color:var(--thx-orange);}
.service-row-cta{display:flex;align-items:center;gap:7px;font-weight:700;color:var(--accent,var(--thx-orange));margin-top:5px;}
.service-row-visual{position:relative;min-height:250px;overflow:hidden;background:var(--thx-blue-50);}
.service-row-visual img{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:900px){.service-row,.service-row:nth-child(even){grid-template-columns:1fr;min-height:auto;}.service-row:nth-child(even) .service-row-text{order:0;}.service-row-visual{min-height:160px;}.service-row-bullets{grid-template-columns:1fr;}}

/* ---------- OFFRES GRID ---------- */
.offres-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:900px){.offres-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.offres-grid{grid-template-columns:1fr;}}

.carte-offre{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:9px;}
.carte-offre-icon{width:36px;height:36px;border-radius:9px;background:var(--accent,var(--thx-blue-50));color:#fff;display:grid;place-items:center;}

/* ---------- AIDES ---------- */
.aides-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;}
.carte-aide{background:#fff;border:1px solid var(--border);border-radius:12px;padding:15px 16px;display:flex;align-items:flex-start;gap:13px;}
.carte-aide-icon{width:34px;height:34px;border-radius:9px;background:var(--thx-orange-50);color:var(--thx-orange);display:grid;place-items:center;flex-shrink:0;}
.carte-aide-title{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--thx-blue-800);margin-bottom:3px;}
.carte-aide-desc{font-size:13px;color:var(--fg-muted);line-height:1.5;}

/* ---------- PROCESS STEPS ---------- */
.process-steps-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative;}
.process-steps-grid::before{content:"";position:absolute;top:35px;left:8%;right:8%;height:2px;background:var(--border);z-index:0;}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;position:relative;z-index:1;}
.process-step-circle{width:70px;height:70px;border-radius:999px;background:var(--thx-cloud);border:2px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;transition:border-color .2s,background .2s;}
.process-step.active .process-step-circle,.process-step:hover .process-step-circle{border-color:var(--thx-orange);background:var(--thx-orange-50);}
.process-step-num{font-family:var(--font-display);font-weight:800;font-size:11px;color:var(--thx-orange);}
.process-step-title{font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--thx-blue-800);}
.process-step-desc{font-size:12px;color:var(--fg-muted);line-height:1.5;}
@media(max-width:760px){.process-steps-grid{grid-template-columns:1fr 1fr;}.process-steps-grid::before{display:none;}}
@media(max-width:420px){.process-steps-grid{grid-template-columns:1fr;}}

/* ---------- PLANS MAINTENANCE ---------- */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:900px){.plans-grid{grid-template-columns:1fr;}}

.carte-plan{background:#fff;border:2px solid var(--border);border-radius:18px;padding:26px;display:flex;flex-direction:column;gap:13px;position:relative;}
.carte-plan.vedette{border-color:var(--thx-orange);transform:scale(1.02);}
.carte-plan-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);}
.carte-plan-name{font-family:var(--font-display);font-weight:800;font-size:19px;color:var(--thx-blue-800);}
.carte-plan-price{display:flex;align-items:baseline;gap:5px;}
.carte-plan-price-value{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--thx-blue-800);}
.carte-plan-price-unit{font-size:14px;color:var(--fg-muted);}
.carte-plan-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;}
.carte-plan-list li{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--thx-graphite);}
.carte-plan-list svg{color:var(--thx-orange);flex-shrink:0;margin-top:2px;}

/* ---------- COMMENT STEPS (maintenance) ---------- */
.comment-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:900px){.comment-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.comment-grid{grid-template-columns:1fr;}}

.comment-step{padding:20px;border-radius:14px;background:#fff;border:1px solid var(--border);}
.comment-step-num{font-family:var(--font-display);font-weight:800;font-size:28px;color:var(--thx-orange);line-height:1;margin-bottom:7px;}
.comment-step-title{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--thx-blue-800);margin-bottom:5px;}
.comment-step-desc{font-size:13px;color:var(--fg-muted);line-height:1.55;}

/* ---------- AUTRES SERVICES ---------- */
.autres-services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
@media(max-width:900px){.autres-services-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.autres-services-grid{grid-template-columns:1fr;}}

.autre-service{padding:20px;text-decoration:none;display:flex;flex-direction:column;gap:10px;background:#fff;color:var(--thx-ink);}
.autre-service-icon{width:40px;height:40px;border-radius:10px;background:var(--accent,var(--thx-orange));color:#fff;display:grid;place-items:center;}
.autre-service-desc{font-size:13px;color:var(--fg-muted);line-height:1.55;flex:1;}
.autre-service-cta{display:inline-flex;align-items:center;gap:6px;color:var(--accent,var(--thx-orange));font-weight:600;font-size:14px;}

/* ---------- ZONES HUB ---------- */
.communes-chiffres{display:flex;gap:22px;margin-top:16px;flex-wrap:wrap;}
.communes-chiffre-value{font-family:var(--font-display);font-weight:800;font-size:28px;line-height:1;}
.communes-chiffre-label{font-size:13px;color:var(--fg-muted);margin-top:4px;}
.communes-list{display:grid;grid-template-columns:1fr 1fr;gap:5px 18px;}
.communes-list-item{display:flex;align-items:center;gap:8px;padding:7px 0;font-size:14px;color:var(--thx-ink);border-bottom:1px solid var(--border);text-decoration:none;transition:color .18s;}
.communes-list-item:hover{color:var(--thx-orange);}
.communes-list-item svg{color:var(--thx-orange);flex-shrink:0;}
.communes-list-item .cp{color:var(--fg-muted);font-size:12px;}

/* Limitrophes */
.limitrophes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px;}
@media(max-width:760px){.limitrophes-grid{grid-template-columns:1fr 1fr;}}
.carte-ville-limitrophe{background:#fff;border:1px solid var(--border);border-radius:12px;padding:13px 15px;display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--thx-ink);font-size:14px;transition:border-color .18s,color .18s;}
.carte-ville-limitrophe:hover{border-color:var(--thx-orange);color:var(--thx-orange);}
.carte-ville-limitrophe svg{color:var(--thx-orange);flex-shrink:0;}
.carte-ville-limitrophe .cp{color:var(--fg-muted);font-size:12px;margin-left:auto;}

/* ---------- STATIC MAP ---------- */
.static-map{background:var(--thx-blue-50);border-radius:18px;aspect-ratio:4/3;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--border);}
.static-map.big{aspect-ratio:16/7;}
.map-placeholder{color:var(--thx-blue-800);text-align:center;padding:24px;}
.map-placeholder-title{font-family:var(--font-display);font-weight:700;font-size:16px;margin-bottom:8px;}
.map-placeholder-desc{font-size:13px;color:var(--fg-muted);}

/* ---------- FILTRES PILLS ---------- */
.filtres-pills{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:6px;}
.filtres-pills button{padding:8px 17px;border-radius:999px;border:1.5px solid var(--border);font-size:14px;font-weight:500;color:var(--thx-graphite);cursor:pointer;background:#fff;transition:border-color .18s,background .18s,color .18s;}
.filtres-pills button:hover,.filtres-pills button.active{background:var(--thx-blue-800);color:#fff;border-color:var(--thx-blue-800);}

/* ---------- CONTACT FORM ---------- */
.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr;}}

.quote-form{padding:36px 40px;border-radius:18px;background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-lg);}
@media(max-width:560px){.quote-form{padding:24px 18px;}}
.form-step-title{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--thx-blue-800);margin:0 0 18px;letter-spacing:-.02em;}
.stepper{display:flex;gap:0;margin-bottom:24px;}
.stepper-step{display:flex;align-items:center;gap:9px;flex:1;}
.stepper-step-circle{width:27px;height:27px;border-radius:999px;border:2px solid var(--border);display:grid;place-items:center;font-weight:700;font-size:12px;color:var(--fg-muted);flex-shrink:0;transition:border-color .2s,background .2s,color .2s;}
.stepper-step.active .stepper-step-circle{border-color:var(--thx-orange);background:var(--thx-orange);color:#fff;}
.stepper-step-label{font-size:13px;font-weight:500;color:var(--fg-muted);}
.stepper-step.active .stepper-step-label{color:var(--thx-blue-800);font-weight:600;}
.stepper-step-rail{flex:1;height:2px;background:var(--border);margin:0 6px;}
.pills-row{display:flex;gap:7px;flex-wrap:wrap;}
.pill{padding:7px 15px;border-radius:999px;border:1.5px solid var(--border);font-size:14px;font-weight:500;color:var(--thx-graphite);cursor:pointer;background:#fff;transition:all .18s;}
.pill:hover,.pill.active{background:var(--thx-blue-800);color:#fff;border-color:var(--thx-blue-800);}
.service-picker{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
@media(max-width:480px){.service-picker{grid-template-columns:1fr;}}
.service-picker-btn{padding:9px 13px;border-radius:10px;border:1.5px solid var(--border);font-size:14px;font-weight:500;color:var(--thx-graphite);cursor:pointer;background:#fff;display:flex;align-items:center;gap:9px;transition:all .18s;}
.service-picker-btn:hover,.service-picker-btn.active{background:var(--thx-blue-50);border-color:var(--thx-blue);color:var(--thx-blue-800);}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--thx-graphite);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border-radius:10px;border:1.5px solid var(--border-strong);background:#fff;font-size:15px;color:var(--thx-ink);transition:border-color .18s,box-shadow .18s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--thx-blue);box-shadow:var(--ring-focus);}
.field.error input,.field.error select,.field.error textarea{border-color:#C4321F;}
.field .err{color:#C4321F;font-size:12px;margin-top:5px;display:none;}
.field.error .err{display:block;}
.field textarea{resize:vertical;min-height:100px;}
.required{color:var(--thx-orange);}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-row-cp{display:grid;grid-template-columns:140px 1fr;gap:14px;}
@media(max-width:560px){.form-row-2,.form-row-cp{grid-template-columns:1fr;}}
.form-actions{display:flex;justify-content:flex-end;margin-top:8px;}
.form-actions-split{justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;}
.rgpd-box{display:flex;align-items:flex-start;gap:9px;cursor:pointer;margin:14px 0;}
.rgpd-box input{margin-top:3px;accent-color:var(--thx-orange);}
.rgpd-box-text{font-size:12px;color:var(--fg-muted);line-height:1.55;}
.rgpd-box-text a{color:var(--thx-orange);}
.form-success{padding:36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;}
.form-success-icon{width:52px;height:52px;border-radius:999px;background:var(--thx-orange-50);color:var(--thx-orange);display:grid;place-items:center;}

/* Contact sidebar */
.contact-sidebar{display:flex;flex-direction:column;gap:14px;position:sticky;top:120px;align-self:start;}
@media(max-width:980px){.contact-sidebar{position:static;}}
.contact-urgence{padding:24px;border-radius:16px;background:linear-gradient(135deg,var(--thx-orange) 0%,var(--thx-orange-600) 100%);color:#fff;}
.contact-urgence-tag{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.9;margin-bottom:9px;}
.contact-urgence-title{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-.02em;margin-bottom:11px;line-height:1.2;}
.contact-urgence-phone{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-weight:800;font-size:19px;color:#fff;text-decoration:none;padding:10px 15px;background:rgba(0,0,0,.18);border-radius:10px;backdrop-filter:blur(8px);}
.contact-urgence-meta{font-size:12px;opacity:.88;margin-top:11px;line-height:1.5;}
.contact-avis{padding:20px;}
.contact-avis-head{display:flex;align-items:center;gap:8px;margin-bottom:11px;font-size:14px;color:var(--thx-blue-800);}
.contact-avis-meta{color:var(--fg-muted);font-size:12px;}
.contact-avis-quote{font-size:13px;color:var(--thx-graphite);font-style:italic;line-height:1.6;margin:0;border-left:3px solid var(--thx-orange);padding-left:11px;}
.contact-avis-author{font-size:12px;color:var(--fg-muted);margin-top:9px;}
.contact-garanties{padding:20px;border-radius:13px;background:var(--thx-blue-50);border:1px solid var(--border);}
.contact-garanties-title{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--thx-blue-800);margin-bottom:9px;}
.contact-garanties ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;}
.contact-garanties li{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--thx-graphite);}
.contact-garanties li svg{color:var(--thx-orange);flex-shrink:0;margin-top:2px;}
.agence-map{position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;background:#E5EBF2;border:1px solid var(--border);box-shadow:var(--shadow-lg);}
.agence-map iframe{width:100%;height:100%;display:block;}
.agence-infos{display:flex;flex-direction:column;gap:11px;margin-top:18px;}
.agence-info{display:flex;align-items:flex-start;gap:11px;}
.agence-info-icon{width:33px;height:33px;border-radius:9px;background:var(--thx-blue-50);color:var(--thx-blue);display:grid;place-items:center;flex-shrink:0;}
.agence-info > div,.agence-info > a{font-size:14px;color:var(--thx-graphite);font-weight:500;}
.agence-info > a:hover{color:var(--thx-orange);}

/* ---------- LEGAL ---------- */
.legal-content{font-size:15px;line-height:1.7;color:var(--thx-graphite);}
.legal-content h2{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--thx-blue-800);margin:34px 0 11px;}
.legal-content p{margin:0 0 13px;}
.legal-content ul{padding-left:20px;margin:0 0 13px;}

/* ---------- UTILITY ---------- */
.center{text-align:center;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.icon{display:inline-block;vertical-align:middle;flex-shrink:0;}
.dot-chauffage{background:var(--thx-heat);}
.dot-froid{background:var(--thx-cold);}
.dot-climatisation{background:var(--thx-clim);}
.dot-ventilation{background:var(--thx-vent);}

/* Titres natifs pages secondaires (sans classe .h1/.h2/.h3) */
main h1:not([class]){font-family:var(--font-display);font-weight:800;font-size:clamp(28px,4vw,48px);line-height:1.08;letter-spacing:-.025em;color:var(--thx-blue-800);margin:0 0 16px;text-wrap:balance;}
main h2:not([class]){font-family:var(--font-display);font-weight:800;font-size:clamp(22px,3vw,36px);line-height:1.1;letter-spacing:-.02em;color:var(--thx-blue-800);margin:0 0 14px;text-wrap:balance;}
main h3:not([class]){font-family:var(--font-display);font-weight:700;font-size:clamp(15px,1.4vw,19px);line-height:1.25;color:var(--thx-blue-800);margin:0 0 8px;}
.hero-page h1:not([class]),.hero-service h1:not([class]),.hero-page-ville h1:not([class]){color:#fff;}
/* Sous-services structure flat pages de ville */
.sous-services-grid > h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--thx-blue-800);margin:8px 0 4px;}
.sous-services-grid > p{font-size:14px;color:var(--fg-muted);line-height:1.65;margin:0 0 4px;}
/* Utilitaire manquant */
.max-w-2xl{max-width:672px;margin-left:auto;margin-right:auto;}
.dot-plomberie{background:var(--thx-plumb);}

/* ---------- COMPAT — classes pages secondaires (sans Tailwind) ---------- */

/* Tailwind resets utilisés dans le contenu */
.not-italic{font-style:normal;}
.max-w-3xl{max-width:768px;margin-left:auto;margin-right:auto;}
.text-sm{font-size:14px;}
.text-xl{font-size:1.25rem;line-height:1.75rem;}
.font-display{font-family:var(--font-display);}
.font-semibold{font-weight:600;}
.text-primary{color:var(--thx-blue-800);}
.text-white{color:#fff;}
.text-text-light{color:var(--fg-subtle);}
.text-text-body{color:var(--fg-muted);}
.mt-2{margin-top:.5rem;}.mt-3{margin-top:.75rem;}.mt-4{margin-top:1rem;}.mt-6{margin-top:1.5rem;}.mt-8{margin-top:2rem;}
.mb-3{margin-bottom:.75rem;}.mb-6{margin-bottom:1.5rem;}
.inline-block{display:inline-block;}
.block{display:block;}
.w-full{width:100%;}
.text-center{text-align:center;}

/* Hero pages secondaires */
.hero-service .hero-content,.hero-page .hero-content{max-width:700px;}
.hero-page-ville{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);color:#fff;padding:72px 0;}
.hero-page-ville h1{font-family:var(--font-display);font-weight:800;font-size:clamp(30px,3.8vw,48px);line-height:1.08;color:#fff;margin:0 0 14px;}
.hero-subtitle{font-size:17px;line-height:1.65;margin:0 0 28px;}
.hero-page-ville .hero-subtitle,.hero-page-ville p{color:rgba(255,255,255,.82);}
.hero-service .hero-subtitle{color:rgba(255,255,255,.82);}
.hero-cta-group{display:flex;gap:14px;flex-wrap:wrap;margin-top:22px;}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px;}
.badge-trust{font-size:12px;font-weight:600;padding:5px 13px;border-radius:999px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);color:#fff;}
.hero-image{display:none;}

/* Preuve bar */
.bloc-preuve{background:var(--thx-blue-800);padding:36px 0;}
.preuve-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center;}
@media(max-width:760px){.preuve-grid{grid-template-columns:repeat(3,1fr);gap:16px;}}
@media(max-width:480px){.preuve-grid{grid-template-columns:1fr 1fr;}}
.preuve-item{display:flex;flex-direction:column;gap:4px;}
.preuve-chiffre{font-family:var(--font-display);font-weight:800;font-size:clamp(20px,2.5vw,28px);color:#fff;}
.preuve-label{font-size:13px;color:rgba(255,255,255,.65);}

/* Sous-services */
.sous-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px;}
@media(max-width:760px){.sous-services-grid{grid-template-columns:1fr;}}
.sous-service-item{padding:22px;background:var(--thx-blue-50);border:1px solid var(--border);border-radius:14px;}
.sous-service-item h3{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--thx-blue-800);margin:0 0 8px;}
.sous-service-item p{font-size:14px;line-height:1.6;color:var(--fg-muted);margin:0 0 12px;}

/* Pourquoi list */
.pourquoi-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.pourquoi-list li{font-size:15px;line-height:1.65;color:var(--fg-muted);}

/* Aide compat */
.aide-item{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:10px;}
.aide-item strong{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--thx-blue-800);display:block;margin-bottom:5px;}
.aide-item p{font-size:14px;line-height:1.55;color:var(--fg-muted);margin:0;}
.aide-disclaimer{background:var(--thx-orange-50);border:1px solid var(--thx-orange-100);border-radius:10px;padding:13px 16px;}
.aide-disclaimer p{font-size:14px;color:var(--thx-graphite);margin:0;line-height:1.5;}

/* Zone chips */
.zone-chips{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px;}
.chip{display:inline-flex;align-items:center;padding:7px 14px;background:var(--thx-blue-50);border:1px solid var(--border);border-radius:999px;font-size:14px;color:var(--thx-blue-800);font-weight:500;text-decoration:none;transition:background .18s,border-color .18s;}
.chip:hover{background:var(--thx-blue-100);border-color:var(--thx-blue);}

/* Tag service */
.tag-service{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--thx-blue-50);color:var(--thx-blue-800);}
.tag-ville{font-size:11px;color:var(--fg-muted);padding:3px 0;}

/* Form compat */
.form-devis{display:flex;flex-direction:column;gap:0;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.form-group label{font-size:13px;font-weight:600;color:var(--thx-graphite);}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 13px;border-radius:10px;border:1.5px solid var(--border-strong);background:#fff;font-size:15px;color:var(--thx-ink);transition:border-color .18s,box-shadow .18s;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--thx-blue);box-shadow:var(--ring-focus);}
.form-group textarea{resize:vertical;min-height:100px;}
.form-error{font-size:12px;color:#C4321F;display:none;margin-top:3px;}
.form-group.error .form-error{display:block;}
.form-rgpd{font-size:12px;color:var(--fg-muted);line-height:1.55;margin-top:14px;}
.form-rgpd a{color:var(--thx-orange);}
.form-confirmation{background:var(--thx-blue-50);border:1px solid var(--thx-blue-100);border-radius:12px;padding:20px;text-align:center;margin-top:14px;}
.form-confirmation p{color:var(--thx-blue-800);font-size:15px;margin:0;}

/* Maillage interne */
.maillage-services{margin-bottom:24px;}
.limitrophes-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:10px;}
.limitrophes-list li{font-size:14px;}
.limitrophes-list h3{font-size:14px;font-weight:500;margin:0;display:inline;}
.limitrophes-list a{color:var(--thx-blue-800);text-decoration:none;transition:color .18s;}
.limitrophes-list a:hover{color:var(--thx-orange);}

/* Prose */
.prose p{font-size:15px;line-height:1.7;color:var(--fg-muted);margin:0 0 16px;}
.prose-lg p{font-size:16px;}

/* =================================================================
   PAGES SECONDAIRES — composants (design system unique)
   ================================================================= */
.site-grain{position:relative;}

/* Utilitaires d'espacement/typo (ex-Tailwind, sans CDN) */
.mt-10{margin-top:2.5rem;}
.mb-2{margin-bottom:.5rem;}
.text-lg{font-size:18px;}
.text-action{color:var(--thx-orange);}
.list-disc{list-style:disc;}
.list-inside{list-style-position:inside;}

/* Piliers (bureau d'étude + zone) */
.piliers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:900px){.piliers-grid{grid-template-columns:1fr;}}
.pilier-item{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;}
.pilier-item h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--thx-blue-800);margin:0 0 8px;}
.pilier-item p{font-size:14px;color:var(--fg-muted);line-height:1.6;margin:0;}

/* Étapes process (bureau d'étude) */
.etapes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.etape-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px 22px;}
.etape-num{width:36px;height:36px;border-radius:999px;background:var(--thx-orange);color:#fff;font-family:var(--font-display);font-weight:800;font-size:15px;display:grid;place-items:center;flex-shrink:0;}
.etape-item h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--thx-blue-800);margin:0 0 5px;}
.etape-item p{font-size:14px;color:var(--fg-muted);line-height:1.6;margin:0;}

/* Double parcours (bureau d'étude + maintenance) */
.double-parcours-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media(max-width:760px){.double-parcours-grid{grid-template-columns:1fr;}}
.parcours-col{background:var(--thx-blue-50);border:1px solid var(--border);border-radius:16px;padding:26px;}
.parcours-col h3{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--thx-blue-800);margin:0 0 9px;}
.parcours-col p{font-size:14px;color:var(--fg-muted);line-height:1.65;margin:0;}
.parcours-col--pro{background:linear-gradient(135deg,var(--thx-blue-800) 0%,var(--thx-blue) 100%);border-color:transparent;}
.parcours-col--pro h3,.parcours-col--pro h3:not([class]){color:#fff;}
.parcours-col--pro p{color:rgba(255,255,255,.82);}

/* Couverture maintenance */
.couverture-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:760px){.couverture-grid{grid-template-columns:1fr;}}
.couverture-item{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;}
.couverture-item h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--thx-blue-800);margin:0 0 10px;}
.couverture-item ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--fg-muted);}
.couverture-item li{line-height:1.5;}

/* Communes (zone hub) */
.communes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
@media(max-width:760px){.communes-grid{grid-template-columns:1fr;}}
.carte-ville{position:relative;background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px 20px;transition:transform .2s var(--ease-out),box-shadow .2s,border-color .2s;}
.carte-ville:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--thx-orange);}
.carte-ville h3 a::after{content:"";position:absolute;inset:0;z-index:1;}
.carte-ville h3{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--thx-blue-800);margin:0 0 6px;}
.carte-ville h3 a{color:inherit;}
.carte-ville h3 a:hover{color:var(--thx-orange);}
.carte-ville p{font-size:14px;color:var(--fg-muted);line-height:1.6;margin:0 0 10px;}
.carte-ville--principale{border-color:var(--thx-orange);box-shadow:var(--shadow-sm);}

/* Contact coordonnées */
.contact-col{font-size:14px;color:var(--thx-graphite);}
.contact-col p{margin:0 0 6px;line-height:1.6;}
.horaires-table{width:100%;border-collapse:collapse;font-size:14px;}
.horaires-table td{padding:7px 0;border-bottom:1px solid var(--border);color:var(--thx-graphite);}
.horaires-table td:last-child{text-align:right;color:var(--fg-muted);}
.map-embed{position:relative;border:1px solid var(--border);}

/* Témoignages (réalisations + villes) */
.temoignages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:900px){.temoignages-grid{grid-template-columns:1fr;}}
.temoignage-stars{color:var(--thx-orange);font-size:15px;letter-spacing:2px;margin-bottom:8px;}

/* =================================================================
   LOT 2 — comportements & responsive (2026-06-24)
   ================================================================= */
/* Dropdown : pont invisible pour combler le gap au survol */
.dropdown::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
/* Bandeau certifications : défilement plus rapide sur mobile */
@media(max-width:760px){.logo-bar-track-inner{animation-duration:14s;}}
/* FAQ : apparition douce de la réponse à l'ouverture */
.faq-item[open] .faq-answer-inner{animation:faq-reveal .3s var(--ease-out);}
@keyframes faq-reveal{from{opacity:0;transform:translateY(-7px);}to{opacity:1;transform:translateY(0);}}
/* Navbar mobile : retirer l'icône téléphone (doublon du FAB), bouton Devis compact dédié */
@media(max-width:980px){.site-header .phone-link{display:none;}}
@media(max-width:560px){
  .site-header .right .btn.primary{padding:9px 14px;font-size:13px;border-radius:9px;}
  .site-header .right .btn.primary .arrow{display:none;}
  .section-header.center .lead{max-width:none;}
}
/* Menu burger : boutons tel + devis homogènes */
.mobile-menu-actions{display:flex;flex-direction:column;gap:10px;margin-top:22px;}
.mobile-menu-actions .btn{justify-content:center;}
/* Carte SVG interactive des communes (zone hub / services / villes) */
.zone-map-wrap{background:radial-gradient(120% 120% at 50% 0%,var(--thx-blue-50),#fff 70%);border:1px solid var(--border);border-radius:20px;padding:18px;overflow:hidden;}
.zone-map{width:100%;height:auto;display:block;}
.zone-map .zm-grid line{stroke:#D7E1EF;stroke-width:1;stroke-dasharray:2 9;}
.zone-map .zm-node{cursor:pointer;}
.zone-map .zm-pin{fill:var(--thx-blue);stroke:#fff;stroke-width:1.5;transition:fill .18s;}
.zone-map .zm-pin-dot{fill:#fff;}
.zone-map .zm-label{font-family:var(--font-body);font-size:12.5px;font-weight:600;fill:var(--thx-blue-800);transition:fill .18s;paint-order:stroke;stroke:#F6F8FC;stroke-width:3.5px;stroke-linejoin:round;}
.zone-map .zm-node:hover .zm-pin{fill:var(--thx-orange);}
.zone-map .zm-node:hover .zm-label{fill:var(--thx-orange-700);}
.zone-map .zm-center .zm-pin{fill:var(--thx-orange);}
.zone-map .zm-center .zm-label{font-weight:800;font-size:14.5px;fill:var(--thx-blue-900);}
.zone-map .zm-active .zm-pin{fill:var(--thx-orange);}
.zone-map .zm-active .zm-label{fill:var(--thx-orange-700);font-weight:800;}
/* Maintenance : contraste lien sur carte bleue + polish couverture */
.parcours-col--pro .cta-link{color:#fff;}
.parcours-col--pro .cta-link:hover{color:var(--thx-orange-100);}
.couverture-item{border-top:3px solid var(--thx-orange);box-shadow:var(--shadow-xs);}
.couverture-item h3{padding-bottom:10px;border-bottom:1px solid var(--border);}
/* Aides énergétiques : grille + icônes + CTA */
.aides-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
@media(max-width:760px){.aides-grid{grid-template-columns:1fr;}}
.aides-grid .aide-item{margin-bottom:0;display:flex;flex-direction:column;gap:7px;}
.aide-icon{width:42px;height:42px;border-radius:11px;background:var(--thx-orange-50);color:var(--thx-orange);display:grid;place-items:center;margin-bottom:3px;}
.aides-cta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:22px;padding:20px 24px;background:var(--thx-blue-50);border:1px solid var(--border);border-radius:14px;}
.aides-cta .p{margin:0;flex:1;min-width:240px;}
/* Champ téléphone international (indicatif + format auto) */
.tel-group{display:flex;}
.tel-group .tel-cc{flex:0 0 auto;width:108px;border:1.5px solid var(--border-strong);border-right:none;border-radius:10px 0 0 10px;background:var(--thx-cloud);padding:11px 6px 11px 12px;font-size:14px;color:var(--thx-ink);cursor:pointer;}
.tel-group .tel-cc:focus{outline:none;border-color:var(--thx-blue);box-shadow:var(--ring-focus);position:relative;z-index:1;}
.tel-group input[type="tel"]{border-radius:0 10px 10px 0;}
