/* =======================================================
   ELAIC — MODERN 2026 EDITION
   Design tokens, bento layout, soft glows, grain, glass
   ======================================================= */

:root{
  --blue:#2C4766;
  --blue-900:#1c3150;
  --blue-700:#2c4766;
  --blue-500:#3d628d;
  --blue-100:#e4eaf2;
  --blue-50:#f1f5fa;

  --orange:#CE751E;
  --orange-600:#b4630f;
  --orange-300:#e29a50;
  --orange-100:#fbe7d1;

  --paper:#FAF8F4;
  --paper-2:#F3EEE4;
  --ink:#1b2431;
  --ink-2:#425063;
  --muted:#6b7689;

  --stroke:rgba(44,71,102,.12);
  --stroke-2:rgba(44,71,102,.22);

  --shadow-sm:0 1px 2px rgba(20,30,50,.04),0 2px 6px rgba(20,30,50,.05);
  --shadow-md:0 2px 6px rgba(20,30,50,.05),0 12px 28px rgba(20,30,50,.08);
  --shadow-lg:0 2px 8px rgba(20,30,50,.06),0 22px 50px rgba(20,30,50,.12);
  --shadow-xl:0 2px 10px rgba(20,30,50,.06),0 32px 80px rgba(20,30,50,.16);
  --glow-orange:0 0 0 1px rgba(206,117,30,.25),0 20px 40px -12px rgba(206,117,30,.45);

  --radius-xs:8px;
  --radius-sm:14px;
  --radius-md:22px;
  --radius-lg:30px;
  --radius-xl:44px;

  --ff-display:'Poppins','Inter','system-ui',sans-serif;
  --ff-body:'Inter','Roboto','system-ui',sans-serif;

  --t:cubic-bezier(.2,.7,.25,1);

  --container:1280px;
  --gap:24px;
  --gap-lg:40px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--t)}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ------- GRAIN + MESH BG overlay ------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(800px 600px at 10% -10%,rgba(206,117,30,.10),transparent 60%),
    radial-gradient(900px 700px at 110% 20%,rgba(44,71,102,.12),transparent 60%),
    radial-gradient(700px 600px at 50% 110%,rgba(206,117,30,.06),transparent 55%);
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.35;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.18 0 0 0 0 0.28 0 0 0 .45 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode:multiply;
}
main,header,footer,.mobile-cta{position:relative;z-index:1}

/* =====================================================
   HEADER (glass sticky)
   ===================================================== */
.nav2026{
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(1.15) blur(16px);
  -webkit-backdrop-filter:saturate(1.15) blur(16px);
  background:rgba(250,248,244,.78);
  border-bottom:1px solid var(--stroke);
}
.nav2026__row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 0;min-height:64px}
.nav2026__logo{display:flex;align-items:center;gap:12px}
.nav2026__logo img{height:36px;width:auto}
.nav2026__links{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav2026__links a{
  padding:9px 14px;border-radius:999px;font-weight:500;font-size:14.5px;color:var(--ink-2);
  transition:background .18s,color .18s;
}
.nav2026__links a:hover{background:rgba(44,71,102,.08);color:var(--blue)}
.nav2026__actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.nav2026__action-phone{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 16px;border-radius:999px;
  border:1.5px solid var(--stroke);background:#fff;
  font-weight:600;font-size:14px;color:var(--blue);
  transition:border-color .18s,box-shadow .18s;
}
.nav2026__action-phone:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(44,71,102,.08)}
.nav2026__action-phone i{font-size:13px}
.nav2026__action-wa{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:999px;
  background:#25d366;color:#fff;font-size:18px;
  transition:background .18s,transform .18s;
}
.nav2026__action-wa:hover{background:#1ebe5d;transform:translateY(-1px)}
.nav2026__action-devis{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;border-radius:999px;
  background:var(--orange);color:#fff;font-weight:700;font-size:14px;
  transition:background .18s,transform .18s;
}
.nav2026__action-devis:hover{background:var(--orange-dark,#b5620f);transform:translateY(-1px)}
.nav2026__action-devis i{font-size:12px}
.nav2026__burger{display:none;width:42px;height:42px;border-radius:12px;background:var(--blue-50);place-items:center}
.nav2026__burger i{color:var(--blue);font-size:18px}

/* --- Dropdown Services (desktop) --- */
.nav2026__dropdown{position:relative}
.nav2026__dropdown-trigger{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 14px;border-radius:999px;
  font-weight:500;font-size:15px;color:var(--ink-2);
  background:none;border:none;cursor:pointer;font-family:inherit;
  transition:background .2s,color .2s;
}
.nav2026__dropdown-trigger:hover,
.nav2026__dropdown.open .nav2026__dropdown-trigger{background:var(--blue-50);color:var(--blue)}
.nav2026__dropdown-trigger .fa-chevron-down{font-size:11px;transition:transform .22s var(--t)}
.nav2026__dropdown.open .nav2026__dropdown-trigger .fa-chevron-down{transform:rotate(180deg)}
.nav2026__dropdown-panel{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(-6px);
  width:460px;
  background:#fff;border:1px solid var(--stroke);border-radius:22px;
  box-shadow:var(--shadow-xl);padding:12px;
  opacity:0;pointer-events:none;
  transition:opacity .2s var(--t),transform .2s var(--t);
  z-index:60;
}
.nav2026__dropdown.open .nav2026__dropdown-panel{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
/* --- Mega menu panel --- */
.nav2026__dp-header{
  font-size:10.5px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--muted);
  padding:6px 14px 8px;display:block;
}
.nav2026__dropdown-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
}
.nav2026__dropdown-panel a{
  display:flex;flex-direction:column;gap:10px;
  padding:14px;border-radius:16px;
  border:1px solid var(--stroke);background:var(--paper);
  color:var(--ink);
  transition:border-color .18s,box-shadow .18s,transform .18s;
}
.nav2026__dropdown-panel a:hover{
  background:var(--blue-50);border-color:var(--blue-100);
  transform:translateY(-2px);box-shadow:var(--shadow-sm);
}
.nav2026__dropdown-panel a[aria-current="page"]{
  background:var(--blue-50);border-color:var(--blue-100);
}
.nav2026__dropdown-panel a[aria-current="page"] .nav2026__dp-icon{background:var(--blue);color:#fff}
.nav2026__dp-icon{
  width:42px;height:42px;border-radius:13px;
  background:var(--blue-50);display:grid;place-items:center;
  flex:0 0 auto;color:var(--blue);font-size:17px;
  transition:background .15s,color .15s;
}
.nav2026__dp-icon--orange{background:var(--orange-100)!important;color:var(--orange)!important}
.nav2026__dp-icon--green{background:#e3f5e9!important;color:#2e7d32!important}
.nav2026__dp-icon--amber{background:#fff8e1!important;color:#e65100!important}
.nav2026__dropdown-panel a:hover .nav2026__dp-icon{background:var(--blue);color:#fff}
.nav2026__dropdown-panel strong{display:block;font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.25}
.nav2026__dropdown-panel small{display:block;font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.3}
/* Footer mega menu */
.nav2026__dropdown-footer{
  margin-top:10px;padding:12px 16px;border-radius:14px;
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-500) 100%);
  display:flex;align-items:center;justify-content:space-between;
  color:rgba(255,255,255,.75);font-size:14px;font-weight:600;
}
.nav2026__dropdown-footer i{color:rgba(255,255,255,.65);margin-right:6px}
.nav2026__dp-cta{
  background:rgba(255,255,255,.15);color:#fff!important;
  padding:8px 16px;border-radius:999px;
  font-size:13px;font-weight:700;
  border:1px solid rgba(255,255,255,.22);
  transition:background .15s;flex:0 0 auto;
}
.nav2026__dp-cta:hover{background:rgba(255,255,255,.28)!important;transform:none!important;border-color:rgba(255,255,255,.4)!important}
.nav2026__dp-sep{display:none}

@media (max-width:960px){
  .nav2026__links,.nav2026__actions{display:none}
  .nav2026__burger{display:grid}
}

/* Qualifelec trust badge — mobile only (index hero) */
.hero2026__qualifelec-mobile{display:none}
@media (max-width:860px){
  .hero2026__qualifelec-mobile{
    display:flex;align-items:center;gap:12px;
    margin-top:14px;padding:10px 14px;
    background:#fff;border:1px solid var(--stroke);border-radius:16px;
    box-shadow:var(--shadow-sm);color:var(--ink);
    text-decoration:none;
  }
  .hero2026__qualifelec-mobile img{flex:0 0 auto;mix-blend-mode:multiply}
  .hero2026__qualifelec-mobile div{flex:1;min-width:0;line-height:1.25}
  .hero2026__qualifelec-mobile strong{display:block;font-size:13.5px;font-weight:700;color:var(--blue)}
  .hero2026__qualifelec-mobile small{display:block;font-size:11.5px;color:var(--muted);margin-top:2px}
  .hero2026__qualifelec-mobile i{color:var(--orange);font-size:12px;flex:0 0 auto}
}

/* =====================================================
   HERO — bento 2026
   ===================================================== */
.hero2026{padding:64px 0 40px;position:relative}
.hero2026__pin{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  background:#fff;border:1px solid var(--stroke);
  color:var(--blue);font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-sm);
}
.hero2026__pin .dot{
  width:8px;height:8px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 4px rgba(34,197,94,.18);animation:pulse 2s infinite
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.65}}

.hero2026__grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:var(--gap-lg);
  align-items:stretch;margin-top:26px
}
.hero2026__left h1{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(44px,6.2vw,88px);line-height:.98;letter-spacing:-.03em;
  color:var(--blue);margin:20px 0 10px;
}
.hero2026__left h1 .accent{
  color:var(--orange);position:relative;white-space:nowrap
}
.hero2026__left h1 .accent::after{
  content:"";position:absolute;left:0;right:8%;bottom:6%;height:8px;
  background:rgba(206,117,30,.18);border-radius:8px;z-index:-1
}
.hero2026__left p.lead{
  color:var(--ink-2);font-size:clamp(16px,1.3vw,19px);max-width:560px;margin-top:14px
}
.hero2026__ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.btn2026{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 24px;border-radius:999px;font-weight:600;font-size:15.5px;
  transition:transform .25s var(--t),box-shadow .25s var(--t),background .25s var(--t)
}
.btn2026--primary{background:var(--orange);color:#fff;box-shadow:var(--glow-orange)}
.btn2026--primary:hover{transform:translateY(-2px);background:var(--orange-600)}
.btn2026--ghost{background:#fff;color:var(--blue);border:1.5px solid var(--stroke-2)}
.btn2026--ghost:hover{border-color:var(--blue);background:var(--blue-50)}
.btn2026--dark{background:var(--ink);color:#fff}
.btn2026--dark:hover{background:var(--blue)}

.hero2026__mini{
  display:flex;gap:28px;margin-top:34px;align-items:center;flex-wrap:wrap
}
.hero2026__mini-stat{display:flex;align-items:center;gap:12px}
.hero2026__mini-num{
  font-family:var(--ff-display);font-weight:700;font-size:26px;color:var(--blue);line-height:1
}
.hero2026__mini-lbl{font-size:13px;color:var(--muted);line-height:1.25}
.hero2026__mini-sep{width:1px;height:30px;background:var(--stroke-2)}

/* Right bento */
.hero2026__right{
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1.25fr 1fr;gap:16px;
}
.bento{
  background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-lg);padding:22px;position:relative;overflow:hidden;
  box-shadow:var(--shadow-md);transition:transform .35s var(--t),box-shadow .35s var(--t)
}
.bento:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.bento--flash{
  grid-column:1/3;background:linear-gradient(135deg,#2C4766 0%,#1c3150 60%,#0f1f36 100%);color:#fff;
  border-color:transparent;min-height:280px
}
.bento--flash > .flash-label,
.bento--flash > h3,
.bento--flash > .tag-stack{position:relative;z-index:3}
.bento--flash .flash-svg{
  position:absolute;right:-50px;top:50%;
  transform:translateY(-50%) rotate(12deg);
  height:340px;width:auto;z-index:1;pointer-events:none;
  filter:drop-shadow(0 18px 40px rgba(206,117,30,.55)) drop-shadow(0 0 22px rgba(255,165,80,.3));
  animation:floatY 6s ease-in-out infinite;
  transition:transform .6s var(--t)
}
.bento--flash .flash-svg .bolt-1{fill:#ffffff;opacity:.92}
.bento--flash .flash-svg .bolt-2{fill:#CE751E}
.bento--flash .flash-glow{
  position:absolute;right:-60px;top:50%;transform:translate(0,-50%);
  width:320px;height:320px;border-radius:50%;z-index:0;
  background:radial-gradient(circle,rgba(206,117,30,.35),rgba(206,117,30,0) 60%);
  pointer-events:none;filter:blur(30px);
  transition:transform .3s var(--t)
}
@keyframes floatY{
  0%,100%{transform:translateY(-50%) rotate(12deg)}
  50%{transform:translateY(-56%) rotate(14deg)}
}
.bento--flash .flash-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;opacity:.6;font-weight:600}
.bento--flash h3{font-family:var(--ff-display);font-weight:700;font-size:34px;line-height:1;margin-top:10px;max-width:260px}
.bento--flash .tag-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;max-width:280px}
.bento--flash .tag-stack span{
  padding:6px 12px;border-radius:999px;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);font-size:12px;font-weight:500
}

.bento--cert{background:#fff}
.bento--cert .bento__badge{
  width:62px;height:62px;border-radius:18px;background:var(--blue-50);
  display:grid;place-items:center;color:var(--blue);font-size:22px
}
.bento--cert h4{font-weight:700;color:var(--blue);margin-top:14px;font-size:17px}
.bento--cert p{font-size:13.5px;color:var(--muted);margin-top:4px}

.bento--live{
  background:linear-gradient(145deg,#fff 0%,#fbe7d1 100%);
  border-color:rgba(206,117,30,.2)
}
.bento--live .live{display:flex;align-items:center;gap:8px;color:var(--orange-600);font-weight:600;font-size:13px}
.bento--live .live .dot{width:8px;height:8px;border-radius:50%;background:#ef4444;box-shadow:0 0 0 4px rgba(239,68,68,.18);animation:pulse 1.5s infinite}
.bento--live h4{font-family:var(--ff-display);color:var(--blue);font-size:22px;line-height:1.1;margin-top:8px;font-weight:700}
.bento--live p{font-size:13px;color:var(--ink-2);margin-top:6px}
.bento--live a{
  display:inline-flex;align-items:center;gap:6px;margin-top:10px;
  font-weight:600;font-size:13.5px;color:var(--orange-600)
}

@media (max-width:900px){
  .hero2026__grid{grid-template-columns:1fr}
  .hero2026__right{grid-template-rows:auto auto}
  .bento--flash{min-height:220px}
  .bento--flash .flash-svg{height:260px;right:-60px}
}

/* =====================================================
   MARQUEE (trust)
   ===================================================== */
.marquee{
  position:relative;overflow:hidden;padding:20px 0;margin:40px 0 10px;
  border-top:1px solid var(--stroke);border-bottom:1px solid var(--stroke);
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(6px)
}
.marquee__track{
  display:flex;gap:48px;animation:scroll 40s linear infinite;width:max-content
}
@keyframes scroll{to{transform:translateX(-50%)}}
.marquee__item{
  display:inline-flex;align-items:center;gap:12px;
  color:var(--blue);font-weight:600;font-size:15px;white-space:nowrap
}
.marquee__item i{color:var(--orange);font-size:14px}
.marquee__star{color:var(--orange);font-size:18px;line-height:1}

/* =====================================================
   SECTION TITLE
   ===================================================== */
.sec{padding:72px 0}
.sec-head{max-width:720px;margin:0 auto 40px;text-align:center}
.sec-label{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:var(--blue-50);color:var(--blue);font-size:12.5px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase
}
.sec-head h2{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(30px,3.6vw,48px);line-height:1.05;letter-spacing:-.02em;
  color:var(--blue);margin-top:14px
}
.sec-head p{color:var(--ink-2);font-size:17px;margin-top:10px}

/* =====================================================
   SERVICES (bento)
   ===================================================== */
.services2026{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto auto;gap:18px
}
.svc{
  background:#fff;border:1px solid var(--stroke);border-radius:var(--radius-lg);
  padding:28px;position:relative;overflow:hidden;
  transition:transform .35s var(--t),box-shadow .35s var(--t),border-color .35s var(--t)
}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--stroke-2)}
.svc__ico{
  width:64px;height:64px;border-radius:20px;overflow:hidden;
  display:grid;place-items:center;background:var(--blue-50);margin-bottom:18px
}
.svc__ico img{width:100%;height:100%;object-fit:cover}
.svc h3{font-family:var(--ff-display);font-weight:700;color:var(--blue);font-size:20px;line-height:1.2}
.svc p{color:var(--ink-2);margin-top:8px;font-size:15px}
.svc__link{
  display:inline-flex;align-items:center;gap:6px;margin-top:16px;
  color:var(--blue);font-weight:600;font-size:14px
}
.svc__link i{transition:transform .3s var(--t)}
.svc:hover .svc__link i{transform:translateX(4px)}
.svc__tag{
  position:absolute;top:22px;right:22px;
  padding:5px 10px;border-radius:999px;
  background:var(--orange);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase
}
.svc--hero{
  grid-column:1/3;grid-row:1/3;
  background:linear-gradient(140deg,#fff 0%,#fbe7d1 100%);
  border-color:rgba(206,117,30,.25);min-height:380px
}
.svc--hero .svc__ico{width:80px;height:80px;border-radius:24px}
.svc--hero h3{font-size:32px;line-height:1.1}
.svc--hero p{font-size:16.5px;max-width:420px}
.svc--hero .svc__bg{
  position:absolute;right:-40px;bottom:-30px;width:260px;height:260px;
  border-radius:50%;background:radial-gradient(circle,rgba(206,117,30,.2),transparent 65%);
  pointer-events:none
}

.svc-note{
  text-align:center;margin-top:28px;padding:16px 24px;
  background:var(--blue-50);border-radius:var(--radius-md);
  color:var(--blue);font-size:14px
}
.svc-note i{color:var(--orange);margin-right:6px}

@media (max-width:1000px){
  .services2026{grid-template-columns:repeat(2,1fr)}
  .svc--hero{grid-column:1/3;grid-row:auto}
}
@media (max-width:600px){
  .services2026{grid-template-columns:1fr}
  .svc--hero{grid-column:1}
}

/* =====================================================
   ABOUT
   ===================================================== */
.about2026{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--gap-lg);
  align-items:center;
  background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-md)
}
.about2026__img{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:1/1;max-width:460px
}
.about2026__img img{width:100%;height:100%;object-fit:cover}
.about2026__img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(160deg,transparent 60%,rgba(44,71,102,.4) 100%)
}
.about2026__img .sticker{
  position:absolute;bottom:18px;left:18px;right:18px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-radius:var(--radius-md);padding:14px 16px;
  display:flex;align-items:center;gap:12px
}
.about2026__img .sticker-bolt{
  width:40px;height:40px;border-radius:12px;background:var(--orange);
  display:grid;place-items:center;color:#fff;font-size:18px
}
.about2026__img .sticker b{color:var(--blue);font-size:14px;display:block}
.about2026__img .sticker span{color:var(--muted);font-size:12px}

.about2026__text h2{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(26px,2.8vw,40px);color:var(--blue);line-height:1.1;margin-top:14px
}
.about2026__text p{color:var(--ink-2);font-size:16px;margin-top:14px}
.creds{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.cred,.creds span{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background:var(--blue-50);color:var(--blue);font-size:13.5px;font-weight:600
}
.cred i,.creds span i{color:var(--orange)}

@media (max-width:900px){
  .about2026{grid-template-columns:1fr;padding:24px}
  .about2026__img{max-width:100%}
}

/* =====================================================
   REVIEWS
   ===================================================== */
.reviews2026__top{
  display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;
  background:linear-gradient(140deg,var(--blue) 0%,var(--blue-900) 100%);
  color:#fff;border-radius:var(--radius-xl);padding:32px;margin-bottom:28px
}
.reviews2026__score{
  font-family:var(--ff-display);font-weight:700;font-size:72px;line-height:1
}
.reviews2026__score small{font-size:24px;opacity:.6;font-weight:400}
.reviews2026__stars{color:var(--orange);font-size:22px;margin-top:6px;letter-spacing:4px}
.reviews2026__count{opacity:.7;margin-top:6px;font-size:14px}
.reviews2026__google{
  display:flex;align-items:center;gap:14px;justify-self:end;
  padding:16px 22px;border-radius:var(--radius-md);background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12)
}
.reviews2026__google i{font-size:28px}
.reviews2026__widget{
  border-radius:var(--radius-xl);overflow:hidden;background:#fff;
  border:1px solid var(--stroke);box-shadow:var(--shadow-md)
}
.reviews2026__widget iframe{display:block;width:100%;border:0}

@media (max-width:700px){
  .reviews2026__top{grid-template-columns:1fr}
  .reviews2026__google{justify-self:start}
}

/* =====================================================
   ZONE
   ===================================================== */
.zone2026__hq{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:22px 28px;border-radius:var(--radius-lg);
  background:linear-gradient(140deg,var(--orange) 0%,#b4630f 100%);
  color:#fff;box-shadow:var(--glow-orange);margin-bottom:24px;
  transition:transform .3s var(--t)
}
.zone2026__hq:hover{transform:translateY(-2px)}
.zone2026__hq-l{display:flex;align-items:center;gap:18px}
.zone2026__hq-l .pin{
  width:52px;height:52px;border-radius:16px;background:rgba(255,255,255,.15);
  display:grid;place-items:center;font-size:22px
}
.zone2026__hq-l b{font-family:var(--ff-display);font-size:22px;font-weight:700;display:block;line-height:1.1}
.zone2026__hq-l span{opacity:.85;font-size:13.5px}
.zone2026__hq-badge{
  padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.18);
  font-size:13px;font-weight:600;white-space:nowrap
}
.zone2026__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px
}
.zone2026__city{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 22px;background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-md);
  transition:transform .25s var(--t),border-color .25s var(--t),box-shadow .25s var(--t)
}
.zone2026__city:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:var(--shadow-md)}
.zone2026__city-l{display:flex;align-items:center;gap:12px}
.zone2026__city-pin{
  width:38px;height:38px;border-radius:12px;background:var(--blue-50);
  display:grid;place-items:center;color:var(--blue);flex-shrink:0
}
.zone2026__city b,.zone2026__city-name{color:var(--blue);font-weight:700;font-size:15px;display:block;line-height:1.2}
.zone2026__city-info{display:flex;flex-direction:column;flex:1;min-width:0}
.zone2026__city .dist,.zone2026__city-dist{color:var(--orange);font-weight:700;font-size:13px;display:block}

@media (max-width:800px){.zone2026__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.zone2026__grid{grid-template-columns:1fr};.zone2026__hq{flex-direction:column;align-items:flex-start}}

/* =====================================================
   FAQ
   ===================================================== */
.faq2026{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq2026__item{
  background:#fff;border:1px solid var(--stroke);border-radius:var(--radius-md);
  overflow:hidden;transition:border-color .25s var(--t),box-shadow .25s var(--t)
}
.faq2026__item[open]{border-color:var(--orange);box-shadow:var(--shadow-md)}
.faq2026__q{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:20px 24px;cursor:pointer;list-style:none;
  font-family:var(--ff-display);font-weight:600;font-size:17px;color:var(--blue)
}
.faq2026__q::-webkit-details-marker{display:none}
.faq2026__q i{
  width:36px;height:36px;border-radius:12px;background:var(--blue-50);
  display:grid;place-items:center;color:var(--blue);font-size:13px;
  transition:transform .3s var(--t),background .3s var(--t)
}
.faq2026__item[open] .faq2026__q i{background:var(--orange);color:#fff;transform:rotate(180deg)}
.faq2026__a{padding:0 24px 22px;color:var(--ink-2);font-size:15px;line-height:1.6}
.faq2026__a strong{color:var(--blue)}

/* =====================================================
   CONTACT
   ===================================================== */
.contact2026{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:30px;
}
.contact2026__info{display:flex;flex-direction:column;gap:12px}
.contact2026__card{
  display:flex;align-items:center;gap:16px;
  padding:18px 22px;background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-md);transition:all .3s var(--t)
}
.contact2026__card:hover{transform:translateY(-2px);border-color:var(--blue);box-shadow:var(--shadow-md)}
.contact2026__card i{
  width:44px;height:44px;border-radius:14px;background:var(--blue-50);
  display:grid;place-items:center;color:var(--blue);font-size:18px;flex-shrink:0
}
.contact2026__card.wa i{background:#25d36620;color:#25d366}
.contact2026__card.pho i{background:var(--orange);color:#fff}
.contact2026__card b{color:var(--blue);font-size:16px;display:block;line-height:1.2}
.contact2026__card span{color:var(--muted);font-size:13px;margin-top:2px;display:block}

.contact2026__form{
  background:#fff;border:1px solid var(--stroke);border-radius:var(--radius-xl);
  padding:32px;box-shadow:var(--shadow-md)
}
.contact2026__form h3{font-family:var(--ff-display);font-size:24px;color:var(--blue);font-weight:700;margin-bottom:6px}
.contact2026__form>p{color:var(--muted);font-size:14px;margin-bottom:22px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fld{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fld label{font-size:13px;font-weight:600;color:var(--blue)}
.fld input,.fld select,.fld textarea{
  padding:13px 16px;border-radius:14px;border:1.5px solid var(--stroke-2);
  background:var(--paper);font:inherit;color:var(--ink);
  transition:border-color .2s var(--t),background .2s var(--t)
}
.fld input:focus,.fld select:focus,.fld textarea:focus{
  outline:0;border-color:var(--orange);background:#fff
}

@media (max-width:900px){
  .contact2026{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
}

/* Case RGPD */
.rgpd-check{
  display:flex;align-items:flex-start;gap:10px;cursor:pointer;
  margin:14px 0 4px;font-size:13px;color:var(--muted);line-height:1.5
}
.rgpd-check input[type="checkbox"]{
  flex-shrink:0;width:18px;height:18px;margin-top:1px;
  accent-color:var(--blue);cursor:pointer
}
.rgpd-check a{color:var(--blue);text-decoration:underline}
.rgpd-check a:hover{color:var(--orange)}

/* =====================================================
   BIG CTA strip
   ===================================================== */
.bigcta{
  margin:60px 0 20px;position:relative;overflow:hidden;
  background:linear-gradient(140deg,var(--blue) 0%,#0f1f36 100%);
  color:#fff;border-radius:var(--radius-xl);padding:56px 40px
}
.bigcta::before{
  content:"";position:absolute;right:-60px;bottom:-60px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(206,117,30,.35),transparent 60%);pointer-events:none
}
.bigcta__inner{
  display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center;position:relative
}
.bigcta h3{font-family:var(--ff-display);font-size:clamp(26px,3.2vw,42px);font-weight:700;line-height:1.1}
.bigcta p{opacity:.85;margin-top:8px;font-size:16px;max-width:540px}
.bigcta__btns{display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:700px){.bigcta__inner{grid-template-columns:1fr}}

/* =====================================================
   FOOTER
   ===================================================== */
.footer2026{
  background:#0f1f36;color:rgba(255,255,255,.75);padding:60px 0 30px;margin-top:40px
}
.footer2026__grid{
  display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:40px
}
.footer2026__logo img{height:46px;width:auto;filter:brightness(0) invert(1);margin-bottom:18px}
.footer2026__logo p{font-size:14px;line-height:1.6;max-width:280px}
.footer2026__col h5{color:#fff;font-family:var(--ff-display);font-weight:700;font-size:15px;margin-bottom:18px}
.footer2026__col a{display:block;padding:6px 0;font-size:14px;color:rgba(255,255,255,.7);transition:color .2s var(--t)}
.footer2026__col a:hover{color:var(--orange)}
.footer2026__social{display:flex;gap:10px;margin-top:18px}
.footer2026__social a{
  width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.08);
  display:grid;place-items:center;color:#fff;transition:all .25s var(--t)
}
.footer2026__social a:hover{background:var(--orange)}
.footer2026__bottom{
  border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:13px;color:rgba(255,255,255,.55)
}
.footer2026__bottom a{color:rgba(255,255,255,.7)}
.footer2026__bottom a:hover{color:var(--orange)}
.footer2026__badges{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-top:18px}
.footer2026__badges img{height:34px;width:auto;opacity:.85}

@media (max-width:900px){.footer2026__grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer2026__grid{grid-template-columns:1fr}}

/* =====================================================
   MOBILE CTA (bottom bar)
   ===================================================== */
.mobile-cta{
  display:none;position:fixed;bottom:12px;left:12px;right:12px;z-index:40;
  padding:10px;border-radius:999px;background:rgba(250,248,244,.85);
  backdrop-filter:blur(14px);border:1px solid var(--stroke);
  box-shadow:var(--shadow-xl)
}
.mobile-cta__inner{display:grid;grid-template-columns:1fr auto 1fr;gap:8px}
.mobile-cta a{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px;border-radius:999px;font-weight:600;font-size:14.5px
}
.mobile-cta .c-phone{background:var(--blue);color:#fff}
.mobile-cta .c-whatsapp{background:#25d366;color:#fff;width:48px;flex:0 0 auto;font-size:20px;padding:14px 0}
.mobile-cta .c-quote{background:var(--orange);color:#fff}
@media (max-width:768px){.mobile-cta{display:block}}

/* =====================================================
   FADE-UP reveal
   ===================================================== */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .8s var(--t),transform .8s var(--t)}
.fade-up.in{opacity:1;transform:none}

/* =====================================================
   ACCESSIBILITÉ
   ===================================================== */
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:6px}
.skip-link{position:absolute;left:-999px;top:0}
.skip-link:focus{left:10px;top:10px;padding:10px 18px;background:var(--blue);color:#fff;border-radius:10px;z-index:100}

/* =====================================================
   TILT + MAGNETIC
   ===================================================== */
/* Tilt 3D */
.tilt{transform-style:preserve-3d;transition:transform .35s var(--t)}
.tilt-inner{transform:translateZ(30px)}

/* Magnetic buttons — transition douce */
.magnetic{transition:transform .25s var(--t)}

/* Reveal stagger bento */
.hero2026__right .bento{transition:transform .5s var(--t),box-shadow .5s var(--t),opacity .5s var(--t)}
.hero2026__right .fade-up.in .bento{opacity:1}

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion:reduce){
  .cursor-dot,.cursor-ring,.tilt,.magnetic,.flash-svg,.flash-glow{transition:none!important;animation:none!important}
  .flash-svg{transform:translateY(-50%) rotate(12deg)!important}
}

/* Scroll-to-top */
.scrtop{
  position:fixed;bottom:20px;right:20px;z-index:30;
  width:46px;height:46px;border-radius:50%;background:var(--ink);color:#fff;
  display:none;place-items:center;box-shadow:var(--shadow-lg);
  transition:all .25s var(--t)
}
.scrtop.on{display:grid}
.scrtop:hover{background:var(--orange);transform:translateY(-2px)}

/* =====================================================
   MOBILE MENU v2 — drawer redesigné 2026
   ===================================================== */
.mobile-menu{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(250,248,244,.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  overflow-y:auto;
  opacity:0;pointer-events:none;
  transition:opacity .25s var(--t);
}
.mobile-menu.on{opacity:1;pointer-events:auto}
.mobile-menu__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;height:72px;
  border-bottom:1px solid var(--stroke);
  position:sticky;top:0;
  background:rgba(250,248,244,.95);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:1;
}
.mobile-menu__close{
  width:42px;height:42px;border-radius:12px;
  background:var(--blue-50);border:none;cursor:pointer;
  display:grid;place-items:center;color:var(--blue);font-size:18px;
}
.mobile-menu__section{padding:22px 20px 0}
.mobile-menu__section-label{
  font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:12px;padding-left:4px;
}
.mobile-menu__services{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mobile-menu__svc{
  display:flex;flex-direction:column;gap:10px;
  padding:16px;background:#fff;
  border:1px solid var(--stroke);border-radius:18px;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.mobile-menu__svc:active{border-color:var(--blue);box-shadow:0 0 0 3px rgba(44,71,102,.1)}
.mobile-menu__svc-icon{
  width:44px;height:44px;border-radius:14px;
  background:var(--blue-50);display:grid;place-items:center;
  color:var(--blue);font-size:18px;
}
.mobile-menu__svc strong{display:block;font-size:14px;font-weight:700;color:var(--ink);line-height:1.2}
.mobile-menu__svc small{display:block;font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.3}
.mobile-menu__nav{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.mobile-menu__nav a{
  display:flex;align-items:center;gap:12px;
  padding:15px 18px;border-radius:16px;
  font-size:15.5px;font-weight:600;color:var(--blue);
  border:1px solid var(--stroke);background:#fff;min-height:52px;
}
.mobile-menu__nav a i{width:20px;text-align:center;color:var(--blue);font-size:15px;flex:0 0 auto}
.mobile-menu__nav a:active{background:var(--blue-50)}
.mobile-menu__bottom{
  display:flex;flex-direction:column;gap:10px;
  padding:22px 20px 48px;margin-top:20px;
}
.mobile-menu__tel{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:16px;border-radius:16px;
  font-size:17px;font-weight:700;color:var(--blue);
  background:#fff;border:1px solid var(--stroke);
}
.mobile-menu__cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:18px;border-radius:999px;
  font-size:17px;font-weight:700;color:#fff;
  background:linear-gradient(135deg,var(--orange) 0%,#e8892a 100%);
  box-shadow:0 6px 28px rgba(206,117,30,.38);
}
.mobile-menu__cta:active{background:var(--blue);box-shadow:none}

/* Barre disponibilité */
.mobile-menu__avail-bar{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 20px;
  background:linear-gradient(135deg,#eaf2f8 0%,var(--blue-50) 100%);
  border-bottom:1px solid var(--stroke);
  font-size:12.5px;font-weight:600;color:var(--blue);
}
.mobile-menu__avail-bar .dot{
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;flex:0 0 auto;
  box-shadow:0 0 0 3px rgba(34,197,94,.2);
  animation:pulse 2s infinite;
}

/* Trust strip */
.mobile-menu__trust{
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
  padding:13px 20px;margin:16px 20px 0;
  background:var(--blue-50);border-radius:16px;
  border:1px solid var(--stroke);
}
.mobile-menu__trust-item{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--ink-2)}
.mobile-menu__trust-item i{color:var(--orange);font-size:11px}
.mobile-menu__trust-sep{color:var(--muted);font-size:11px}

/* Accents couleur par service dans le menu mobile */
/* Rénovation — bleu défaut */
/* Dépannage — orange urgent */
.mobile-menu__services .mobile-menu__svc:nth-child(2){position:relative;border-color:rgba(206,117,30,.25)}
.mobile-menu__services .mobile-menu__svc:nth-child(2) .mobile-menu__svc-icon{background:var(--orange-100);color:var(--orange)}
.mobile-menu__services .mobile-menu__svc:nth-child(2)::before{
  content:"URGENT";position:absolute;top:-9px;right:10px;
  background:var(--orange);color:#fff;
  font-size:9px;font-weight:800;letter-spacing:.08em;
  padding:2px 9px;border-radius:999px;
  box-shadow:0 2px 8px rgba(206,117,30,.4);
}
/* IRVE — vert électrique */
.mobile-menu__services .mobile-menu__svc:nth-child(3) .mobile-menu__svc-icon{background:#e3f5e9;color:#2e7d32}
/* Éclairage — ambre */
.mobile-menu__services .mobile-menu__svc:nth-child(4) .mobile-menu__svc-icon{background:#fff8e1;color:#e65100}

/* Stagger animation quand le menu s'ouvre */
@keyframes mmItemIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu.on .mobile-menu__svc,
.mobile-menu.on .mobile-menu__nav a,
.mobile-menu.on .mobile-menu__tel,
.mobile-menu.on .mobile-menu__cta{animation:mmItemIn .3s var(--t) both}
.mobile-menu.on .mobile-menu__svc:nth-child(1){animation-delay:.04s}
.mobile-menu.on .mobile-menu__svc:nth-child(2){animation-delay:.09s}
.mobile-menu.on .mobile-menu__svc:nth-child(3){animation-delay:.14s}
.mobile-menu.on .mobile-menu__svc:nth-child(4){animation-delay:.19s}
.mobile-menu.on .mobile-menu__nav a:nth-child(1){animation-delay:.24s}
.mobile-menu.on .mobile-menu__nav a:nth-child(2){animation-delay:.29s}
.mobile-menu.on .mobile-menu__nav a:nth-child(3){animation-delay:.34s}
.mobile-menu.on .mobile-menu__tel{animation-delay:.39s}
.mobile-menu.on .mobile-menu__cta{animation-delay:.44s}

@media (max-width:960px){
  .mobile-menu{display:flex;flex-direction:column}
}

/* =====================================================
   MOBILE — REFONTE RESPONSIVE COMPLÈTE
   ===================================================== */
@media (max-width:960px){
  .container{padding:0 24px}
  .nav2026__row{height:64px}
  .nav2026__phone{display:none}
  .nav2026__cta{padding:10px 14px;font-size:13px}
  .nav2026__cta i{display:none}
}
@media (max-width:768px){
  :root{--gap:16px;--gap-lg:24px}
  .sec{padding:48px 0}
  .sec-head h2{font-size:clamp(26px,6vw,36px)!important;line-height:1.1}

  /* HERO — centré sur mobile (uniquement la partie texte) */
  /* padding-inline intentionnellement absent : le .container gère le padding horizontal */
  .hero2026{padding-top:28px;padding-bottom:16px}
  .hero2026__grid{grid-template-columns:1fr;gap:22px;margin-top:18px}
  .hero2026__left{display:flex;flex-direction:column;align-items:center;text-align:center}
  .hero2026__left h1{font-size:clamp(38px,10vw,52px);line-height:1;margin:14px 0 8px}
  .hero2026__left p.lead{font-size:15.5px;max-width:100%;margin-left:auto;margin-right:auto}
  .hero2026__ctas{gap:10px;margin-top:20px;justify-content:center}
  .hero2026__mini{justify-content:center}
  .hero2026__mini-stat{flex:0 1 auto}
  .hero2026__left h1 .accent::after{right:10%;left:10%}
  .hero2026__inner > .hero2026__pin{display:inline-flex}
  .hero2026__inner{text-align:center}
  /* Empêche le centre de bleed dans les bento */
  .hero2026__right,.hero2026__right *{text-align:left}

  /* Bento flash — titre plus respirant + tags alignés */
  .bento--flash h3{font-size:24px;line-height:1.12;max-width:100%}
  .bento--flash .tag-stack{justify-content:flex-start}
  .bento--flash .flash-svg{display:none}

  /* Bento cert — horizontal: badge + texte à côté */
  .bento--cert{display:flex;align-items:center;gap:16px;padding:20px}
  .bento--cert .bento__badge{flex:0 0 auto;margin-top:0}
  .bento--cert h4{margin-top:0;font-size:17px;line-height:1.2}
  .bento--cert h4 br{display:none}
  .bento--cert h4 br + *,.bento--cert h4 br{margin-left:0}
  .bento--cert h4::after{content:""}
  .bento--cert p{margin-top:4px;font-size:13px}

  /* Bento live — horizontal plus compact */
  .bento--live{padding:20px}
  .bento--live h4{font-size:20px;line-height:1.15}
  .bento--live h4 br{content:" ";display:inline;white-space:pre}
  .bento--live .live{font-size:12.5px}
  .bento--live a{margin-top:12px;min-height:44px;padding:10px 14px;background:var(--orange);color:#fff;border-radius:999px;justify-content:center}
  .btn2026{padding:14px 18px;font-size:14.5px;min-height:48px;flex:1 1 auto;justify-content:center}
  .hero2026__mini{gap:18px;margin-top:22px;justify-content:center;flex-wrap:wrap}
  .hero2026__mini-sep{display:none}
  .hero2026__mini-stat{flex:0 0 auto;min-width:0}
  .hero2026__mini-num{font-size:22px}
  .hero2026__mini-lbl{font-size:11.5px}

  /* Right bento → stack */
  .hero2026__right{grid-template-columns:1fr;grid-template-rows:auto auto auto;gap:12px}
  .bento{padding:18px;border-radius:24px}
  .bento--flash{grid-column:1;min-height:200px;padding:22px}
  .bento--flash h3{font-size:26px;max-width:100%}
  .bento--flash .tag-stack{max-width:100%;margin-top:14px}
  .bento--flash .flash-svg{height:200px;right:-50px;opacity:.7}
  .bento--cert h4{font-size:16px}
  .bento--cert .bento__badge{width:52px;height:52px;border-radius:16px;font-size:20px}
  .bento--live h4{font-size:19px}

  /* MARQUEE */
  .marquee{margin:28px 0 0;padding:14px 0}
  .marquee__item{font-size:13px;padding:0 18px}

  /* SERVICES */
  .services2026{grid-template-columns:1fr!important;gap:14px}
  .svc{padding:22px;min-height:0}
  .svc--hero{grid-column:1;min-height:260px;padding:24px}
  .svc--hero h3{font-size:24px}
  .svc--hero p{font-size:15px;max-width:100%}
  .svc__ico{width:58px;height:58px;border-radius:18px;font-size:22px}
  .svc h3{font-size:19px}
  .svc p{font-size:14.5px}

  /* ABOUT */
  .about2026{grid-template-columns:1fr;padding:22px;gap:24px;border-radius:28px}
  .about2026__img{max-width:100%;aspect-ratio:4/3}
  .about2026__text h2{font-size:26px}
  .about2026__text p{font-size:15px}
  .creds{gap:8px;margin-top:18px}
  .cred{padding:8px 12px;font-size:12.5px}

  /* REVIEWS */
  .reviews2026__top{grid-template-columns:1fr;padding:24px;gap:18px;text-align:center}
  .reviews2026__score{font-size:56px}
  .reviews2026__google{justify-self:center;padding:12px 18px;font-size:14px}
  .reviews2026__widget iframe{min-height:520px}

  /* ZONE */
  .zone2026__hq{flex-direction:column;align-items:flex-start;padding:20px;gap:14px;border-radius:24px}
  .zone2026__hq-l{gap:14px}
  .zone2026__hq-l b{font-size:19px}
  .zone2026__grid{grid-template-columns:1fr!important;gap:10px}

  /* FAQ */
  .faq2026__q{font-size:15.5px;padding:18px 20px;min-height:60px}
  .faq2026__a{font-size:14.5px;padding:0 20px 18px}

  /* BIG CTA */
  .bigcta{padding:36px 24px;margin:40px 0 16px;border-radius:32px}
  .bigcta__inner{grid-template-columns:1fr;gap:18px}
  .bigcta h3{font-size:clamp(22px,6.5vw,30px)}
  .bigcta__btns{width:100%}
  .bigcta__btns .btn2026{flex:1 1 auto;justify-content:center}

  /* CONTACT */
  .contact2026{grid-template-columns:1fr;padding:22px;gap:20px;border-radius:28px}
  .contact2026__form{padding:18px;border-radius:22px}
  .row{grid-template-columns:1fr}
  .fld input,.fld select,.fld textarea{padding:14px 14px;font-size:15px;min-height:48px}

  /* FOOTER */
  .footer2026{padding:44px 0 120px}
  .footer2026__grid{grid-template-columns:1fr;gap:28px}
  .footer2026__bottom{flex-direction:column;align-items:flex-start;gap:10px;text-align:left}

  /* MOBILE CTA bar + scroll-top cohabitent */
  .mobile-cta{bottom:10px;left:10px;right:10px;padding:10px}
  .mobile-cta__inner{gap:8px}
  .mobile-cta a{padding:13px 12px;font-size:14px;min-height:48px}
  .scrtop{bottom:84px;right:14px;width:42px;height:42px}
}
@media (max-width:480px){
  .container{padding:0 24px}
  .hero2026__right{padding:0 6px}
  .hero2026__left h1{font-size:clamp(34px,11vw,46px)}
  .hero2026__ctas{flex-direction:column;padding:0 6px;align-self:stretch}
  .hero2026__ctas .btn2026{width:100%}
  .hero2026__mini{justify-content:center;gap:14px}
  .bento--flash .flash-svg{display:none}
  .bento--flash{min-height:auto}
  .btn2026{width:100%}
  .bigcta__btns{flex-direction:column}
  .bigcta__btns .btn2026{width:100%}
}
@media (max-width:768px){.scrtop{bottom:86px}}

/* =====================================================
   HERO INNER — pages intérieures (single column)
   ===================================================== */
.hero2026--inner{padding-top:48px;padding-bottom:32px;text-align:center}
.hero2026--inner .hero2026__inner{max-width:820px;margin:0 auto}
.hero2026--inner h1{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(34px,5vw,64px);line-height:1.05;
  letter-spacing:-.025em;color:var(--blue);margin:20px 0 12px
}
.hero2026--inner h1 .accent{color:var(--orange);position:relative;white-space:nowrap}
.hero2026--inner h1 .accent::after{
  content:"";position:absolute;left:0;right:5%;bottom:5%;height:7px;
  background:rgba(206,117,30,.18);border-radius:8px;z-index:-1
}
.hero2026--inner .lead{color:var(--ink-2);font-size:clamp(16px,1.3vw,19px);max-width:640px;margin:0 auto}
.hero2026--inner .hero2026__ctas{justify-content:center;margin-top:28px}
.hero2026--inner .hero2026__mini{justify-content:center;margin-top:30px}
@media (max-width:768px){
  .hero2026--inner{padding-top:28px;padding-bottom:16px}
  .hero2026--inner h1{font-size:clamp(28px,9vw,44px)}
  .hero2026--inner .hero2026__ctas{flex-wrap:wrap}
  .hero2026--inner .hero2026__ctas .btn2026{flex:1 1 auto;min-width:200px;justify-content:center}
}

/* =====================================================
   PROSE — contenu riche en texte (pages intérieures)
   ===================================================== */
.prose-2026{max-width:820px;margin:0 auto}
.prose-2026 h2{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(22px,2.5vw,36px);color:var(--blue);
  margin-bottom:16px;line-height:1.1;margin-top:0
}
.prose-2026 h3{
  font-family:var(--ff-display);font-weight:700;
  font-size:clamp(17px,1.8vw,22px);color:var(--blue);margin:28px 0 10px
}
.prose-2026 p{color:var(--ink-2);font-size:16px;line-height:1.7;margin-bottom:14px}
.prose-2026 p:last-child{margin-bottom:0}
.prose-2026 ul{color:var(--ink-2);font-size:16px;padding-left:24px;margin-bottom:14px}
.prose-2026 ul li{margin-bottom:10px;line-height:1.65}
.prose-2026 strong{color:var(--blue)}
.prose-2026 a{color:var(--orange-600)}
.prose-2026 a:hover{color:var(--orange)}
.prose-2026 .lead{font-size:17.5px;color:var(--ink);line-height:1.65;margin-bottom:18px}

/* =====================================================
   INFO BOX — équivalent location-note
   ===================================================== */
.info-box{
  background:var(--blue-50);border-radius:var(--radius-md);
  padding:18px 22px;display:flex;gap:14px;align-items:flex-start;
  color:var(--blue);margin-top:22px;
  border-left:4px solid var(--orange)
}
.info-box i{color:var(--orange);flex-shrink:0;margin-top:3px;font-size:16px}
.info-box strong{color:var(--blue)}
.info-box a{color:var(--orange-600)}

/* =====================================================
   CARD GRID — grille de cartes thématiques
   ===================================================== */
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:24px}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card-grid--4{grid-template-columns:repeat(4,1fr)}
.card-grid__item{
  background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-md);padding:26px;
  transition:transform .3s var(--t),box-shadow .3s var(--t)
}
.card-grid__item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.card-grid__item h3{
  font-family:var(--ff-display);color:var(--blue);
  font-size:17px;margin-bottom:10px;line-height:1.25;
  display:flex;align-items:center;gap:10px
}
.card-grid__item h3 i{color:var(--orange);font-size:16px;flex-shrink:0}
.card-grid__item p{color:var(--ink-2);font-size:14.5px;line-height:1.6;margin:0}
.card-grid__item strong{color:var(--blue)}
.card-grid__item a{color:var(--orange-600)}
@media (max-width:800px){.card-grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.card-grid,.card-grid--3,.card-grid--4{grid-template-columns:1fr}}

/* =====================================================
   BREADCRUMB
   ===================================================== */
.breadcrumb,.breadcrumb2026{padding:14px 0;font-size:13px;color:var(--muted)}
.breadcrumb ol,.breadcrumb2026 ol{display:flex;gap:6px;align-items:center;list-style:none;flex-wrap:wrap}
.breadcrumb li+li::before,.breadcrumb2026 li+li::before{content:"›";margin-right:6px;color:var(--muted)}
.breadcrumb a,.breadcrumb2026 a{color:var(--blue);font-weight:500}
.breadcrumb [aria-current],.breadcrumb2026 [aria-current]{color:var(--muted)}

/* =====================================================
   CLASSES PAGES SERVICE (template nouveau)
   ===================================================== */

/* Conteneur de section — équivalent .container */
.nav2026__inner{max-width:1100px;margin:0 auto;padding:0 32px}

/* Badge hero (pastille au-dessus du H1) */
.hero2026__badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:#fff;border:1px solid var(--stroke);
  color:var(--blue);font-size:13.5px;font-weight:600;
  box-shadow:var(--shadow-sm);margin-bottom:16px
}

/* CTAs hero */
.hero2026__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;justify-content:center}

/* Mini-stats hero (version centrée) */
.hero2026__mini-stats{display:flex;gap:32px;margin-top:28px;align-items:center;justify-content:center;flex-wrap:wrap}
.mini-stat{display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}
.mini-stat__val{font-family:var(--ff-display);font-weight:700;font-size:24px;color:var(--blue);line-height:1}
.mini-stat__lbl{font-size:12.5px;color:var(--muted);line-height:1.3}

/* Badge section (alias sec-label) */
.badge2026{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:var(--blue-50);color:var(--blue);font-size:12.5px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase
}

/* Card service — alias noms de classe nouveaux */
.svc__icon{
  width:64px;height:64px;border-radius:20px;overflow:hidden;
  display:grid;place-items:center;background:var(--blue-50);
  margin-bottom:18px;font-size:1.5rem;color:var(--blue);flex-shrink:0
}
.svc__title{font-family:var(--ff-display);font-weight:700;color:var(--blue);font-size:18px;line-height:1.2;margin-bottom:8px}
.svc__body{color:var(--ink-2);font-size:14.5px;line-height:1.6;margin:0}

/* Grilles bento (2 et 3 colonnes) */
.bento--2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.bento--3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.bento--3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.bento--2,.bento--3{grid-template-columns:1fr}}

/* Card grid (alias card-grid__card → card-grid__item) */
.card-grid__card{
  background:#fff;border:1px solid var(--stroke);
  border-radius:var(--radius-md);padding:26px;
  transition:transform .3s var(--t),box-shadow .3s var(--t)
}
.card-grid__card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.card-grid__card h3{font-family:var(--ff-display);color:var(--blue);font-size:17px;margin-bottom:10px;line-height:1.25;display:flex;align-items:center;gap:10px}
.card-grid__card h3 i{color:var(--orange);font-size:16px;flex-shrink:0}
.card-grid__card p{color:var(--ink-2);font-size:14.5px;line-height:1.6;margin:0}

/* Card-grid 2 colonnes */
.card-grid--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:700px){.card-grid--2{grid-template-columns:1fr}}

/* About — classes nouvelles */
.about2026__body{display:flex;flex-direction:column;justify-content:center}
.about2026__creds{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.about2026__creds span,.about2026__creds a{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:999px;
  background:var(--blue-50);color:var(--blue);font-size:13.5px;font-weight:600;
  text-decoration:none;transition:background .2s
}
.about2026__creds span i,.about2026__creds a i{color:var(--orange)}
.about2026__creds a:hover{background:var(--blue-100)}
.about2026__sticker{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border-radius:var(--radius-sm);padding:10px 18px;
  font-family:var(--ff-display);font-weight:700;color:var(--blue);
  font-size:14px;text-align:center;white-space:nowrap;
  border:1px solid var(--stroke);box-shadow:var(--shadow-sm)
}

/* Mobile responsive — pages service */
@media(max-width:768px){
  .nav2026__inner{padding:0 20px}
  .hero2026__mini-stats{gap:20px}
  .mini-stat__val{font-size:20px}
  .bento--3{grid-template-columns:1fr}
  .hero2026__actions{justify-content:center}
  .hero2026__actions .btn2026{flex:1 1 auto;min-width:180px;justify-content:center}
}

/* =====================================================
   HERO INNER — variante avec photo côté droit
   ===================================================== */
.hero2026--photo{text-align:left}
.hero2026--photo .hero2026__inner{
  max-width:1100px;
  display:grid;
  grid-template-columns:1fr 380px;
  gap:52px;
  align-items:center;
}
.hero2026__photo{
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 8px 48px rgba(44,71,102,.22);
  line-height:0;
}
.hero2026__photo img{width:100%;height:auto;display:block}
@media(max-width:960px){
  .hero2026--photo .hero2026__inner{grid-template-columns:1fr;text-align:center}
  .hero2026--photo .hero2026__actions,
  .hero2026--photo .hero2026__ctas,
  .hero2026--photo .hero2026__mini-stats,
  .hero2026--photo .hero2026__mini{justify-content:center}
  .hero2026__photo{max-width:480px;margin:24px auto 0}
}
