/* ====================================================================
   GLOBAL.CSS — Design tokens & shared components (Électricien Plus)
   Used on every page. Page-specific layout lives in its own CSS file.
   ==================================================================== */

:root{
  --navy:#0B1F3A;
  --amber:#F5A623;
  --cream:#FAFAF8;
  --ink:#1C1C1C;
  --blue:#2D9CDB;
  --line:#E8E4DC;
  --navy-soft:#13294D;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Poppins',sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.eyebrow,.logo{font-family:'Space Grotesk',sans-serif;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;height: stretch;object-fit: cover;}
strong{color:var(--navy);font-weight:600;}

.wrap{max-width:1100px;margin:0 auto;padding:0 24px;}

/* ===== Header ===== */
header{
  position:sticky;top:0;z-index:200;
  background:rgba(250,250,248,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;max-width:1100px;margin:0 auto;
}
.logo{
  font-size:19px;font-weight:700;color:var(--navy);
  display:flex;align-items:center;gap:10px;letter-spacing:-0.01em;
}
.logo .bolt{color:var(--amber);font-size:20px;}
.header-nav{display:flex;align-items:center;gap:26px;margin-left:36px;}
.header-nav a{font-size:14px;font-weight:500;color:#3A3A3A;}
.header-nav a:hover,.header-nav a.active{color:var(--navy);font-weight:600;}
.header-actions{display:flex;align-items:center;gap:14px;}
.phone-link{
  font-size:14px;font-weight:600;color:var(--navy);
  display:flex;align-items:center;gap:7px;
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:3px;
  font-weight:600;font-size:14px;
  border:1.5px solid transparent;
  transition:all .2s ease;cursor:pointer;
}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy-soft);}
.btn-amber{background:var(--amber);color:var(--navy);}
.btn-amber:hover{background:#e2960f;}
.btn-outline{border-color:var(--navy);color:var(--navy);}
.btn-outline:hover{background:var(--navy);color:#fff;}

/* ===== Breadcrumb ===== */
.breadcrumb{
  padding:14px 24px;background:#F2EFE7;border-bottom:1px solid var(--line);
  font-size:13px;color:#666;
}
.breadcrumb .wrap{display:flex;align-items:center;gap:8px;}
.breadcrumb a{color:#666;}
.breadcrumb a:hover{color:var(--navy);}
.breadcrumb i{font-size:9px;color:#aaa;}
.breadcrumb span{color:var(--navy);font-weight:600;}

/* ===== Hero (base, shared shell) ===== */
.hero{
  position:relative;
  padding:72px 24px 88px;
  background:var(--navy);
  color:#fff;
  overflow:hidden;
}
.hero-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1.15fr 0.85fr;gap:56px;
  align-items:center;position:relative;z-index:2;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--amber);margin-bottom:22px;
}
.eyebrow::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:var(--amber);box-shadow:0 0 0 3px rgba(245,166,35,.25);
}
.hero h1{
  font-size:42px;font-weight:700;line-height:1.18;letter-spacing:-0.015em;
  margin-bottom:22px;
}
.hero p{font-size:16.5px;color:#D8DEEA;margin-bottom:30px;max-width:520px;}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px;}
.hero-phone-big{
  font-size:15px;color:#fff;display:flex;align-items:center;gap:10px;
  padding-top:6px;
}
.hero-phone-big a{font-weight:700;font-size:19px;color:var(--amber);}

.hero-visual{position:relative;}
.panel-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);
  border-radius:6px;padding:10px;backdrop-filter:blur(6px);
}
.panel-stat{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 12px 8px;margin-top:0;
}
.panel-stat strong{color:#fff;font-size:24px;font-family:'Space Grotesk';}
.panel-stat span{color:#AEB8CC;font-size:12.5px;}

/* circuit trace background in hero */
.circuit-bg{
  position:absolute;inset:0;z-index:1;opacity:.5;
  pointer-events:none;
}

/* ===== Circuit rail (signature element) ===== */
.rail-section{position:relative;}
.rail-section .wrap{position:relative;}
.rail-dot{
  position:absolute;left:-2px;top:6px;width:11px;height:11px;
  border-radius:50%;background:var(--amber);
  box-shadow:0 0 0 4px var(--cream),0 0 0 5px var(--line);
}
.rail-line{
  position:absolute;left:3px;top:0;bottom:0;width:1.5px;
  background:var(--line);
}

/* ===== Section shell ===== */
section{padding:64px 24px;}
.section-head{max-width:680px;margin-bottom:36px;padding-left:28px;}
.section-num{
  font-family:'Space Grotesk';font-size:12.5px;font-weight:600;
  color:var(--blue);letter-spacing:.06em;margin-bottom:10px;display:block;
}
h2{font-size:28px;font-weight:700;letter-spacing:-0.01em;color:var(--navy);line-height:1.3;}
.section-body{padding-left:28px;max-width:700px;}
.section-body p{font-size:15.5px;color:#3A3A3A;margin-bottom:18px;}
.alt{background:#F2EFE7;}

/* ===== Generic split layout: text left, visual right ===== */
.split-grid{
  display:grid;grid-template-columns:1fr 0.62fr;gap:40px;align-items:stretch;
  padding-left:28px;
}
.split-visual{display:flex;}
.split-img-card{
  background:#fff;border:1px solid var(--line);border-radius:8px;
  padding:14px;display:flex;flex-direction:column;width:100%;
}
.split-img-card .split-img-frame{flex:1;min-height:0;border-radius:4px;overflow:hidden;background:#F2EFE7;}
.split-img-card .split-img-frame svg{width:100%;height:100%;display:block;}
.split-img-card .split-caption{
  text-align:center;font-size:12.5px;font-weight:600;color:var(--navy);
  margin-top:10px;display:flex;align-items:center;justify-content:center;gap:7px;
  flex-shrink:0;
}
.split-img-card .split-caption i{color:var(--amber);}
.split-img-stack{display:flex;flex-direction:column;gap:14px;}

/* ===== Check list ===== */
.check-list{list-style:none;margin-top:6px;}
.check-list li{
  font-size:15px;color:#3A3A3A;padding:10px 0 10px 30px;position:relative;
  border-bottom:1px solid var(--line);
}
.check-list li:last-child{border-bottom:none;}
.check-list li::before{
  content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;
  position:absolute;left:0;top:11px;color:var(--blue);font-size:11px;
}

/* ===== Offerings two-col list ===== */
.offer-list{
  display:grid;grid-template-columns:1fr 1fr;gap:0 32px;
}
.offer-list li{
  font-size:14.5px;color:#3A3A3A;padding:10px 0 10px 24px;position:relative;
  border-bottom:1px solid var(--line);list-style:none;
}
.offer-list li::before{
  content:'';position:absolute;left:0;top:18px;width:6px;height:1.5px;background:var(--amber);
}

/* ===== Locations ===== */
.loc-grid{
  display:grid;grid-template-columns:1fr 0.62fr;gap:40px;align-items:start;
  padding-left:28px;
}
.loc-row{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;
}
.loc-pill{
  font-size:13.5px;font-weight:500;color:var(--navy);
  border:1px solid var(--line);background:#fff;
  padding:9px 16px;border-radius:20px;
}
.loc-pill i{color:var(--amber);margin-right:6px;font-size:11px;}
.loc-visual{position:sticky;top:90px;}
.loc-row--col{flex-direction:column;align-items:stretch;}
.loc-row--col .loc-pill{text-align:left;}

/* ===== Features inline ===== */
.feat-row{margin-top:8px;}
.feat-row > div{
  display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--line);
}
.feat-row > div:last-child{border-bottom:none;}
.feat-num{
  font-family:'Space Grotesk';font-weight:700;color:var(--amber);font-size:14px;
  min-width:26px;
}
.feat-row h3{font-family:'Space Grotesk';font-size:15px;font-weight:600;color:var(--navy);margin-bottom:4px;}
.feat-row p{font-size:14px;color:#555;margin:0;}

/* ===== Contact + form (shared, used on every page) ===== */
.contact-section{background:var(--navy);color:#fff;padding:72px 24px;}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
  max-width:1100px;margin:0 auto;align-items:start;
}
.contact-info h2{color:#fff;}
.contact-info p{color:#D8DEEA;font-size:15px;margin:16px 0 28px;max-width:420px;}
.contact-detail{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.contact-detail i{color:var(--amber);font-size:16px;width:20px;}
.contact-detail a, .contact-detail span{font-size:15px;color:#fff;}
.contact-detail strong{color:#fff;font-size:17px;font-weight:700;}

.form-card{
  background:#fff;border-radius:6px;padding:32px;color:var(--ink);
}
.form-card h3{font-family:'Space Grotesk';color:var(--navy);font-size:18px;margin-bottom:6px;}
.form-card .sub{font-size:13px;color:#666;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{
  display:block;font-size:12.5px;font-weight:600;color:var(--navy);
  margin-bottom:6px;letter-spacing:.02em;
}
.field input,.field select,.field textarea{
  width:100%;border:1.5px solid var(--line);border-radius:4px;
  padding:11px 13px;font-family:'Poppins';font-size:14px;color:var(--ink);
  background:var(--cream);transition:border-color .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue);
}
.field textarea{resize:vertical;min-height:84px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-submit{
  width:100%;background:var(--amber);color:var(--navy);font-weight:700;
  font-size:15px;border:none;border-radius:4px;padding:13px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:background .2s;margin-top:6px;
}
.form-submit:hover{background:#e2960f;}
.form-note{font-size:11.5px;color:#888;margin-top:12px;text-align:center;}
.form-success{
  display:none;text-align:center;padding:30px 10px;
}
.form-success i{font-size:34px;color:#2DB87A;margin-bottom:12px;}
.form-success h4{font-family:'Space Grotesk';color:var(--navy);margin-bottom:6px;}
.form-success p{font-size:13.5px;color:#666;}

/* ===== Final CTA strip ===== */
.cta-strip{
  background:var(--amber);padding:40px 24px;text-align:center;
}
.cta-strip-inner{
  max-width:780px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.cta-strip h3{font-family:'Space Grotesk';color:var(--navy);font-size:20px;font-weight:700;}
.cta-strip p{color:#5c4308;font-size:13.5px;margin-top:4px;}

/* ===== Footer ===== */
footer{background:#0A1830;color:#9FA8BD;padding:48px 24px 28px;}
.footer-cols{
  display:grid;grid-template-columns:2fr 1fr;gap:40px;
  max-width:1100px;margin:0 auto 28px;
}
.footer-cols--3{grid-template-columns:1.6fr 1fr 1fr;}
.footer-logo{color:#fff;font-size:17px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.footer-logo .bolt{color:var(--amber);}
.footer-cols p{font-size:13px;line-height:1.7;max-width:380px;}
.footer-locs h4{color:#fff;font-size:13px;font-weight:600;margin-bottom:14px;letter-spacing:.04em;text-transform:uppercase;}
.footer-locs ul{list-style:none;display:flex;flex-direction:column;gap:9px;}
.footer-locs a{font-size:13.5px;color:#9FA8BD;}
.footer-locs a:hover{color:var(--amber);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding-top:20px;
  max-width:1100px;margin:0 auto;font-size:12px;color:#6B7488;
}

/* ===== Fixed WhatsApp button ===== */
.wa-fixed{
  position:fixed;bottom:26px;right:22px;z-index:500;
  width:56px;height:56px;border-radius:50%;
  background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:26px;box-shadow:0 6px 18px rgba(37,211,102,.4);
  animation:wapulse 2.4s infinite;
}
@keyframes wapulse{
  0%,100%{box-shadow:0 6px 18px rgba(37,211,102,.4);}
  50%{box-shadow:0 6px 18px rgba(37,211,102,.4),0 0 0 8px rgba(37,211,102,.15);}
}

/* ===== Mobile sticky bar ===== */
.mbar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:480;
  background:#fff;border-top:1px solid var(--line);
  padding:10px 14px;gap:10px;
  box-shadow:0 -4px 16px rgba(0,0,0,.06);
}
.mbar a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:7px;
  padding:12px;border-radius:5px;font-weight:600;font-size:13.5px;
}
.mbar .wa{background:#25D366;color:#fff;}
.mbar .quote{background:var(--navy);color:#fff;}

/* ====================================================================
   RESPONSIVE — shared breakpoints
   ==================================================================== */
@media (max-width:860px){
  .hero-grid{grid-template-columns:1fr;}
  .hero-visual{order:-1;}
  .offer-list{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .footer-cols{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .loc-grid,.split-grid{grid-template-columns:1fr;padding-left:28px;}
  .loc-grid .section-body,.split-grid .section-body{padding-left:0;}
  .loc-visual,.split-visual{position:static;max-width:340px;margin:16px auto 0;}
  .header-nav{display:none;}
}
@media (max-width:600px){
  .hero h1{font-size:30px;}
  h2{font-size:23px;}
  .section-head,.section-body{padding-left:20px;}
  .phone-link{display:none;}
  .cta-strip-inner{flex-direction:column;text-align:center;}
  .mbar{display:flex;}
  .wa-fixed{display:none;}
  body{padding-bottom:70px;}

  /* center everything on mobile */
  .header-inner{justify-content:center;gap:14px;flex-wrap:wrap;}
  .breadcrumb .wrap{justify-content:center;flex-wrap:wrap;}
  .hero-grid{text-align:center;}
  .hero > .hero-grid > div:first-child{display:flex;flex-direction:column;align-items:center;}
  .hero p{margin-left:auto;margin-right:auto;}
  .hero-ctas{justify-content:center;}
  .hero-phone-big{justify-content:center;}
  .eyebrow{justify-self:center;}

  .rail-line,.rail-dot{display:none;}
  .loc-grid,.split-grid{padding-left:0;}
  .section-head{padding-left:0;text-align:center;margin-left:auto;margin-right:auto;}
  .section-body{padding-left:0;text-align:center;margin-left:auto;margin-right:auto;}
  .section-body .hero-ctas,
  .section-body > a.btn{align-self:center;}
  .section-body a.btn{margin-left:auto;margin-right:auto;}

  .check-list{text-align:left;max-width:380px;margin-left:auto;margin-right:auto;}
  .offer-list{text-align:center;}
  .offer-list li{padding-left:0;}
  .offer-list li::before{display:none;}

  .loc-row{justify-content:center;}
  .loc-row--col{align-items:center;}
  .loc-row--col .loc-pill{text-align:center;}
  .loc-visual{display:flex;flex-direction:column;align-items:center;}

  .feat-row > div{flex-direction:column;align-items:center;text-align:center;}
  .wrap > a.btn{margin-left:auto;margin-right:auto;display:flex;width:fit-content;}

  .contact-info{text-align:center;}
  .contact-info p{margin-left:auto;margin-right:auto;}
  .contact-detail{justify-content:center;}

  .footer-cols{text-align:center;}
  .footer-logo{justify-content:center;}
  .footer-cols p{margin-left:auto;margin-right:auto;}
  .footer-locs ul{align-items:center;}

  .cta-strip-inner{align-items:center;}
}
