/* Nick's Electrical Service — faithful restore (self-contained CSS) */
:root{
  --ink:#1c1f24;        /* near-black */
  --dark:#222428;       /* hero/dark bands */
  --dark2:#2b2e33;
  --blue:#2b6fff;       /* original #3366ff accent, modernized */
  --blue-d:#1f57d6;
  --yellow:#f6c12b;     /* original #F9BF3B accent */
  --gray:#5b626c;
  --line:#e4e7ec;
  --bg-soft:#f6f7f9;
  --white:#ffffff;
  --radius:12px;
  --maxw:1180px;
  --shadow:0 8px 30px rgba(20,22,26,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--white);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{font-family:"Lato",sans-serif;font-weight:900;line-height:1.18;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(1.9rem,4.6vw,3.1rem)}
h2{font-size:clamp(1.55rem,3.2vw,2.25rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
section{padding:74px 0}

/* part labels */
.part-label{display:inline-block;font-family:"Bungee",sans-serif;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);background:rgba(43,111,255,.10);padding:5px 12px;border-radius:30px;margin-bottom:14px}
.detail-text.light .part-label,.area-text.light .part-label{color:var(--yellow);background:rgba(246,193,43,.16)}

/* ---------- Top bar ---------- */
#top-header{background:var(--ink);color:#cfd4db;font-size:.86rem}
.top-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:42px}
.top-tagline{opacity:.92}
.top-phone{color:#fff;font-weight:700;white-space:nowrap}
.top-phone:hover{color:var(--yellow);text-decoration:none}

/* ---------- Header / nav ---------- */
#main-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 14px rgba(20,22,26,.05)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:18px}
.logo img{height:54px;width:auto;object-fit:contain}
#primary-nav ul{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0}
#primary-nav a{color:var(--ink);font-weight:700;font-size:.96rem;padding:10px 13px;border-radius:8px;display:block}
#primary-nav a:hover{color:var(--blue);background:var(--bg-soft);text-decoration:none}
#primary-nav .nav-cta{background:var(--blue);color:#fff;margin-left:6px}
#primary-nav .nav-cta:hover{background:var(--blue-d);color:#fff}
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:42px;background:none;border:1px solid var(--line);border-radius:8px;cursor:pointer;padding:0 11px}
.nav-toggle span{display:block;height:2.5px;background:var(--ink);border-radius:2px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-weight:800;font-size:1rem;padding:14px 26px;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:.2s;text-align:center}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-d);border-color:var(--blue-d);color:#fff}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-ghost-dark{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-ghost-dark:hover{background:var(--blue);color:#fff}
.btn-block{width:100%}

/* ---------- Hero ---------- */
.hero{background-size:cover;background-position:center;color:#fff;padding:96px 0 92px;position:relative}
.hero-inner{max-width:820px}
.hero-eyebrow{font-family:"Bungee",sans-serif;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:var(--yellow);margin-bottom:12px}
.hero h1{color:#fff;margin-bottom:18px}
.hero-sub{font-size:1.18rem;color:#e7ebf1;max-width:680px;margin-bottom:22px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.badge{font-weight:800;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:#fff;border:1.5px solid rgba(255,255,255,.45);padding:7px 14px;border-radius:30px}
.badge:nth-child(4){background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.hero-reviews a{color:#fff;font-weight:700}
.hero-reviews a:hover{color:var(--yellow)}

/* ---------- Bands ---------- */
.band-light{background:#fff}
.band-light.intro{background:var(--bg-soft)}
.band-dark{background:var(--dark);color:#e9ecf1}
.band-dark h2,.section-title.light,.detail-text.light h2,.area-text.light h2{color:#fff}
.section-title{text-align:center}
.section-intro{text-align:center;max-width:760px;margin:0 auto 42px;color:var(--gray);font-size:1.08rem}
.section-intro.light{color:#c4cad3}
.lead{font-size:1.15rem;max-width:840px}

/* intro trust row */
.intro{text-align:center}
.intro .lead{margin:0 auto 36px;color:var(--gray)}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:left}
.trust-item{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 20px;box-shadow:var(--shadow)}
.trust-item strong{display:block;font-size:1.05rem;margin-bottom:5px;color:var(--ink)}
.trust-item span{color:var(--gray);font-size:.95rem}
.trust-item{border-top:3px solid var(--blue)}

/* ---------- Services grid ---------- */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.22s;color:var(--ink)}
.service-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(0,0,0,.18)}
.service-card img{width:100%;height:210px;object-fit:cover}
.service-body{padding:20px 22px 24px}
.service-body h3{margin-bottom:8px}
.service-body p{color:var(--gray);font-size:.97rem;margin-bottom:12px}
.service-link{font-weight:800;color:var(--blue)}

/* ---------- CTA strip ---------- */
.cta-strip{background:linear-gradient(120deg,var(--blue),#1746b8);color:#fff;padding:46px 0}
.cta-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-strip h2{color:#fff;margin-bottom:4px}
.cta-strip p{color:#dce6ff;margin:0}
.cta-strip .btn-primary{background:#fff;color:var(--blue);border-color:#fff}
.cta-strip .btn-primary:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}

/* ---------- Detail sections ---------- */
.detail-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:48px;align-items:center}
.detail-grid.reverse{grid-template-columns:1fr 1.15fr}
.detail-grid.reverse .detail-img{order:2}
.detail-img img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
.detail-text p{font-size:1.04rem}
.detail-text.light p{color:#cfd4db}
.callout{border-left:4px solid var(--blue);background:rgba(43,111,255,.07);padding:13px 18px;border-radius:0 10px 10px 0;font-size:1.05rem}
.detail-text.light .callout{background:rgba(246,193,43,.12);border-left-color:var(--yellow);color:#fff}

/* FAQ */
.faq{margin-top:14px}
.faq details{border:1px solid rgba(255,255,255,.16);border-radius:10px;margin-bottom:10px;background:rgba(255,255,255,.04);overflow:hidden}
.band-light .faq details{border-color:var(--line);background:#fff}
.faq summary{cursor:pointer;font-weight:800;padding:14px 18px;list-style:none;color:#fff;position:relative;font-size:1.02rem}
.band-light .faq summary{color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:18px;top:12px;font-size:1.3rem;color:var(--yellow);font-weight:700}
.faq details[open] summary::after{content:"\2013"}
.band-light .faq summary::after{color:var(--blue)}
.faq details p{padding:0 18px 16px;margin:0;color:#cfd4db;font-size:.98rem}
.band-light .faq details p{color:var(--gray)}

/* two-up */
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.mini-detail figure{margin:0 0 18px}
.mini-detail img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:280px;object-fit:cover}

/* ---------- Gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-grid figure{margin:0;border-radius:10px;overflow:hidden;box-shadow:var(--shadow);background:#eef0f3}
.gallery-grid img{width:100%;height:190px;object-fit:cover;transition:.3s}
.gallery-grid figure:hover img{transform:scale(1.06)}
.gallery-more{text-align:center;margin-top:34px}

/* ---------- Service area ---------- */
.area-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
.area-img img{border-radius:var(--radius);box-shadow:var(--shadow)}
.area-cities{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:9px 16px;padding:0;margin:18px 0 0}
.area-cities li{position:relative;padding-left:18px;color:#cfd4db;font-weight:600;font-size:.96rem}
.area-cities li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;background:var(--yellow);border-radius:50%}

/* ---------- Quote ---------- */
.quote-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.contact-list{list-style:none;padding:0;margin:22px 0 0}
.contact-list li{display:flex;gap:14px;padding:11px 0;border-bottom:1px solid var(--line);font-size:1.02rem}
.contact-list .ci{font-family:"Bungee",sans-serif;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);min-width:74px;padding-top:3px}
.quote-form{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:var(--shadow)}
.quote-form h3{margin-bottom:18px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.quote-form label{display:block;font-weight:700;font-size:.9rem;color:var(--ink);margin-bottom:14px}
.quote-form input,.quote-form textarea{width:100%;margin-top:6px;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font:inherit;font-weight:400;color:var(--ink);background:#fcfcfd}
.quote-form input:focus,.quote-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,111,255,.12)}
.services-needed{border:1.5px solid var(--line);border-radius:11px;padding:14px 16px 6px;margin:0 0 16px}
.services-needed legend{font-weight:800;font-size:.9rem;padding:0 6px;color:var(--ink)}
.ck{display:flex !important;align-items:center;gap:8px;font-weight:600 !important;font-size:.92rem !important;margin-bottom:9px !important}
.ck input{width:auto !important;margin:0 !important}
.form-note{font-size:.8rem;color:var(--gray);margin:12px 0 0;text-align:center}

/* ---------- Footer ---------- */
#main-footer{background:var(--ink);color:#aeb4bd;padding-top:58px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:40px}
.foot-logo{height:48px;width:auto;object-fit:contain;background:#fff;padding:7px 10px;border-radius:8px;margin-bottom:14px}
.foot-col p{font-size:.95rem;color:#9aa1ab}
.foot-lic{font-weight:700;color:#c8ced6 !important;font-size:.9rem !important}
.foot-col h4{color:#fff;font-size:1.05rem;margin-bottom:14px}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col ul li{margin-bottom:9px}
.foot-col ul a,.foot-col ul li{color:#aeb4bd;font-size:.96rem}
.foot-col ul a:hover{color:var(--yellow)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 0}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;font-size:.9rem}
.foot-call{color:#fff;font-weight:800}
.foot-call:hover{color:var(--yellow)}

/* ---------- Sticky mobile call ---------- */
.sticky-call{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:60;background:var(--blue);color:#fff;text-align:center;font-weight:900;padding:15px;border-radius:12px;box-shadow:0 8px 26px rgba(0,0,0,.3)}
.sticky-call:hover{background:var(--blue-d);color:#fff;text-decoration:none}

/* ======================================================= RESPONSIVE */
@media(max-width:980px){
  .trust-row{grid-template-columns:repeat(2,1fr)}
  .service-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .detail-grid,.detail-grid.reverse,.area-grid,.quote-grid{grid-template-columns:1fr;gap:30px}
  .detail-grid.reverse .detail-img{order:0}
  .detail-img,.area-img{max-width:560px;margin:0 auto}
}
@media(max-width:760px){
  section{padding:54px 0}
  .top-tagline{display:none}
  .top-bar{justify-content:center}
  .nav-toggle{display:flex}
  #primary-nav{position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 12px 24px rgba(0,0,0,.12);max-height:0;overflow:hidden;transition:max-height .3s ease}
  #primary-nav.open{max-height:520px}
  #primary-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:8px 14px 16px}
  #primary-nav a{padding:13px 10px;border-radius:8px}
  #primary-nav .nav-cta{margin:8px 0 0;text-align:center}
  .two-up{grid-template-columns:1fr;gap:34px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .area-cities{grid-template-columns:repeat(2,1fr)}
  .field-row{grid-template-columns:1fr}
  .services-needed{display:grid}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .cta-strip-inner{flex-direction:column;align-items:flex-start}
  .sticky-call{display:block}
  #main-footer{padding-bottom:78px}
  .footer-bottom{padding-bottom:78px}
}
@media(max-width:440px){
  body{font-size:16px}
  .hero{padding:64px 0 60px}
  .service-grid{grid-template-columns:1fr}
  .service-card img{height:200px}
  .trust-row{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn{width:100%}
  .quote-form{padding:22px 18px}
  .btn{padding:13px 20px}
}
