
:root{
  --primary:#f58220;
  --primary-dark:#d96c12;
  --secondary:#0f3b65;
  --secondary-2:#123f6e;
  --ink:#17202a;
  --muted:#5b6876;
  --line:#d9e1e7;
  --bg:#f4f7fb;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --success:#1d7a53;
  --shadow:0 20px 60px rgba(15,59,101,.12);
  --radius:20px;
  --radius-sm:14px;
  --container:min(1200px, 92vw);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(245,130,32,.08), transparent 30%),
    linear-gradient(180deg,#f7f9fc 0%, #eef3f8 100%);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.container{width:var(--container);margin:0 auto}
.section{padding:88px 0}
.section-tight{padding:64px 0}
.section-head{
  max-width:760px;
  margin:0 auto 40px;
  text-align:center;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(15,59,101,.08);
  color:var(--secondary);
  font-size:13px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
h1,h2,h3,h4{
  margin:0 0 14px;
  line-height:1.15;
  color:#10263a;
}
h1{font-size:clamp(2.5rem,5vw,4.5rem)}
h2{font-size:clamp(2rem,3vw,3rem)}
h3{font-size:1.25rem}
p{margin:0 0 14px;color:var(--muted)}
ul{padding-left:20px}
.small{font-size:.95rem}
.muted{color:var(--muted)}
.center{text-align:center}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}
.btn,.btn-secondary,.nav-btn,.cta-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  cursor:pointer;
}
.btn,.nav-btn,.cta-btn{
  background:linear-gradient(135deg,var(--primary),#ff9d49);
  color:#fff;
  box-shadow:0 14px 30px rgba(245,130,32,.22);
}
.btn-secondary{
  background:#fff;
  color:var(--secondary);
  border-color:rgba(15,59,101,.18);
  box-shadow:0 10px 26px rgba(15,59,101,.08);
}
.btn:hover,.btn-secondary:hover,.nav-btn:hover,.cta-btn:hover{
  transform:translateY(-2px);
}
.card,.box,.faq-item,.stat-card,.service-card,.cred-card,.gallery-card,.contact-card,.info-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,59,101,.08);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}

.utility-bar{
  background:#0c2947;
  color:#dbe8f4;
  font-size:14px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.utility-inner{
  width:var(--container);
  margin:0 auto;
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  padding:8px 0;
}
.utility-items,.utility-trust{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.utility-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.site-header{
  position:sticky;
  top:0;
  z-index:1100;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(15,59,101,.08);
}
.site-header.is-scrolled{box-shadow:0 16px 40px rgba(15,59,101,.12)}
.header-inner{
  width:var(--container);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  min-height:124px;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  flex:0 0 auto;
}
.brand img{height:148px;width:auto;filter:drop-shadow(0 8px 20px rgba(15,59,101,.12))}
.brand-copy{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.brand-copy strong{
  font-size:1.35rem;
  letter-spacing:.02em;
}
 .brand-copy span{
  color:var(--muted);
  font-size:1rem;
}
.nav-wrap{
  display:flex;
  align-items:center;
  gap:24px;
  margin-left:auto;
}
.nav-toggle{
  display:none;
  width:48px;height:48px;
  border-radius:14px;
  border:1px solid rgba(15,59,101,.12);
  background:#fff;
}
.main-nav{display:flex;align-items:center;gap:6px}
.main-nav > a,
.dropdown-toggle{
  padding:12px 14px;
  border-radius:12px;
  font-weight:600;
  color:#21384c;
  background:transparent;
  border:none;
}
.main-nav > a:hover,.dropdown-toggle:hover,.dropdown:hover > .dropdown-toggle{
  background:rgba(15,59,101,.06);
}
.dropdown{position:relative}
.dropdown-menu{
  position:absolute;
  top:100%;
  left:0;
  min-width:240px;
  padding:12px;
  background:#fff;
  border:1px solid rgba(15,59,101,.08);
  border-radius:18px;
  box-shadow:0 24px 60px rgba(15,59,101,.18);
  display:none;
}
.dropdown:hover .dropdown-menu,
.dropdown:focus-within .dropdown-menu{display:block}
.dropdown-menu a{
  display:block;
  padding:12px 14px;
  border-radius:12px;
}
.dropdown-menu a:hover{background:rgba(15,59,101,.06)}

.hero{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(100deg, rgba(12,34,56,.86), rgba(15,59,101,.66)),
    url('/assets/images/solarpanel.png') center/cover no-repeat;
  min-height:clamp(620px,88vh,840px);
  display:flex;
  align-items:center;
}
.hero::after{
  content:"";
  position:absolute;
  inset:auto -8% -140px auto;
  width:380px;height:380px;
  background:radial-gradient(circle, rgba(245,130,32,.3), rgba(245,130,32,0));
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:32px;
  align-items:center;
}
.hero-copy{color:#fff;padding:68px 0}
.hero-copy h1{color:#fff;max-width:12ch}
.hero-copy p{color:#d7e3ef;font-size:1.1rem;max-width:62ch}
.hero-highlights{
  display:flex;gap:12px;flex-wrap:wrap;
  margin:24px 0 32px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14);
  color:#fff;
  font-weight:600;
}
.hero-card{
  padding:28px;
  background:rgba(255,255,255,.95);
}
.hero-card h3{margin-bottom:8px}
.hero-card ul{
  list-style:none;
  padding:0;margin:18px 0 0;
}
.hero-card li{
  display:flex;justify-content:space-between;gap:16px;
  padding:14px 0;
  border-bottom:1px solid rgba(15,59,101,.08);
}
.hero-card li:last-child{border-bottom:none}
.offer-strip{
  background:linear-gradient(135deg,#123f6e,#0f3b65);
  color:#fff;
  text-align:center;
  padding:16px;
  font-weight:700;
}

.trust-band{margin-top:-42px;position:relative;z-index:5}
.trust-shell{
  padding:22px;
  background:#fff;
  border:1px solid rgba(15,59,101,.08);
  border-radius:24px;
  box-shadow:0 24px 60px rgba(15,59,101,.12);
}
.trust-grid{display:grid;grid-template-columns:1.15fr repeat(3,1fr);gap:18px;align-items:stretch}
.trust-intro{
  padding:18px 20px;
  background:linear-gradient(135deg,rgba(15,59,101,.08),rgba(15,59,101,.03));
  border-radius:18px;
}
.trust-card{
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:8px;
  border-radius:18px;
  background:var(--surface-2);
}
.trust-card strong{font-size:1.05rem}
.trust-icon{
  width:44px;height:44px;
  display:grid;place-items:center;
  border-radius:14px;
  background:rgba(245,130,32,.12);
  color:var(--primary);
  font-size:1.15rem;
  font-weight:800;
}

.services-grid,.gallery-grid,.benefits-grid,.cards-grid,.contact-grid{display:grid;gap:24px}
.services-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.service-card{padding:28px;position:relative;overflow:hidden}
.service-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto auto;
  width:140px;height:140px;
  border-radius:50%;
  transform:translate(45%,-45%);
  background:radial-gradient(circle, rgba(245,130,32,.18), rgba(245,130,32,0));
}
.service-card p{min-height:72px}
.service-meta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--secondary);
  font-weight:700;
  margin-top:8px;
}
.box{padding:26px}
.box ul{margin:0;padding-left:18px}
.stats-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;margin-top:34px}
.stat-card{padding:24px;text-align:center}
.stat-card strong{display:block;font-size:2rem;color:var(--secondary);margin-bottom:8px}

.solar-builder{padding:88px 0}
.builder-container{
  max-width:980px;
  margin:auto;
  padding:40px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(15,59,101,.08);
  border-radius:28px;
  box-shadow:0 28px 70px rgba(15,59,101,.15);
}
.builder-heading{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:start;
  margin-bottom:28px;
}
.builder-note{
  padding:20px;
  border-radius:18px;
  background:linear-gradient(135deg,rgba(15,59,101,.06),rgba(245,130,32,.1));
}
.sub{color:var(--muted);margin-bottom:0}
.builder-control{margin-bottom:34px}
label{display:block;font-weight:700;margin-bottom:12px;text-transform:capitalize}
.hint{font-size:.95rem;color:var(--muted);margin-top:10px}
.panel-buttons,.battery-buttons{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}
.panel-buttons button,.battery-buttons button{
  border:none;
  border-radius:16px;
  background:#eef3f8;
  color:#183853;
  font-weight:700;
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, color .2s ease;
}
.panel-buttons button{
  width:64px;height:64px;font-size:2rem;
}
.panel-buttons button:hover,.battery-buttons button:hover{transform:translateY(-2px);background:#e5edf5}
.battery-buttons button{padding:14px 20px}
.battery-buttons button.active{background:var(--secondary);color:#fff}
.panel-display{font-size:2.75rem;font-weight:800;min-width:110px;text-align:center;color:var(--secondary)}
.builder-results{
  margin-top:22px;
  padding:28px;
  background:var(--surface-2);
  border-radius:24px;
}
.result-big{font-size:clamp(3rem,6vw,4.5rem);font-weight:900;color:var(--secondary);margin-bottom:4px}
.result-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-top:24px;
}
.result-grid div{
  padding:18px;
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(15,59,101,.08);
}
.lifetime{margin-top:20px;font-size:1.35rem;font-weight:700}
.warning{margin-top:12px;color:#b7431c;font-weight:700}
.disclaimer{margin-top:16px;font-size:.9rem;color:var(--muted)}
.builder-cta{margin-top:28px}
.cta-sub{margin-top:12px;color:var(--muted)}

.quote-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(10,22,38,.55);
  backdrop-filter:blur(6px);
  z-index:1200;
}
.quote-modal.open{display:flex}
.quote-box{
  position:relative;
  width:min(100%,540px);
  padding:32px;
  background:#fff;
  border-radius:24px;
  box-shadow:0 28px 80px rgba(0,0,0,.25);
}
.quote-box input,.quote-box textarea,.quote-box button,.quote-form input,.quote-form select,.quote-form textarea,.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;
  border:1px solid rgba(15,59,101,.12);
  border-radius:14px;
  padding:14px 16px;
  background:#fff;
  outline:none;
}
.quote-box input:focus,.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus,.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  border-color:rgba(15,59,101,.35);
  box-shadow:0 0 0 4px rgba(15,59,101,.08);
}
.quote-box button,.quote-form button,.contact-form button{
  background:linear-gradient(135deg,var(--primary),#ff9d49);
  color:#fff;
  font-weight:700;
  border:none;
}
.quote-box > * + *{margin-top:14px}
.close{
  position:absolute;
  top:16px;right:18px;
  font-size:1.6rem;
  cursor:pointer;
}
.quote-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:28px;
  align-items:start;
}
.quote-form{
  padding:28px;
  background:rgba(255,255,255,.94);
  border-radius:24px;
  border:1px solid rgba(15,59,101,.08);
  box-shadow:var(--shadow);
}
.quote-form form,.contact-form form{
  display:grid;
  gap:14px;
}
.quote-side{
  padding:30px;
  border-radius:24px;
  background:linear-gradient(135deg,#10365b,#0f3b65);
  color:#fff;
  box-shadow:var(--shadow);
}
.quote-side p,.quote-side li{color:#d7e3ef}
.quote-side ul{margin:20px 0 0}
.quote-side .pill{background:rgba(255,255,255,.1)}

.faq-list{display:grid;gap:16px}
.faq-item{padding:10px 18px}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:18px 0;
  background:none;
  border:none;
  text-align:left;
  font-weight:700;
  color:#11283d;
  cursor:pointer;
}
.faq-question::after{content:"+";font-size:1.5rem;color:var(--primary)}
.faq-item.open .faq-question::after{content:"−"}
.faq-answer{
  display:none;
  padding:0 0 18px;
  color:var(--muted);
}
.faq-item.open .faq-answer{display:block}

.cta{
  padding:84px 0;
  background:linear-gradient(135deg,#0f3b65,#153f69);
  color:#fff;
}
.cta h2,.cta h3,.cta h1{color:#fff}
.cta p{color:#d9e5f2}
.cta-panel{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  align-items:center;
}
.pay-grid,.about-grid,.contact-grid,.gallery-grid,.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.gallery-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.gallery-card{overflow:hidden}
.gallery-card img{aspect-ratio:4/3;object-fit:cover;width:100%}
.gallery-card .content{padding:18px}
.about-layout{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:30px;
  align-items:start;
}
.stack{display:grid;gap:24px}
.cred-card,.info-card,.contact-card{padding:28px}
.benefits-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.contact-card .label{font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.contact-form{
  padding:28px;
  background:#fff;
  border-radius:24px;
  border:1px solid rgba(15,59,101,.08);
  box-shadow:var(--shadow);
}
.page-hero{
  padding:88px 0 60px;
  background:linear-gradient(135deg,#10365b,#0f3b65);
  color:#fff;
}
.page-hero h1,.page-hero p{color:#fff}
.page-hero p{max-width:780px}
.page-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.accreditations{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(15,59,101,.1);
  background:#fff;
  box-shadow:0 12px 28px rgba(15,59,101,.08);
  font-weight:700;
  color:var(--secondary);
}

footer.site-footer{
  background:#0b2035;
  color:#d8e1ea;
  padding:28px 0;
}
.footer-grid{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer-links{display:flex;gap:16px;flex-wrap:wrap}
.footer-links a:hover{color:#fff}


.logo-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:18px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.16);
  min-height:76px;
}
.logo-pill img{
  height:44px;
  width:auto;
  max-width:150px;
  object-fit:contain;
  filter:none;
}
.trust-grid-logos{
  grid-template-columns:minmax(0,1.1fr) repeat(3,minmax(180px,1fr));
}
.trust-logo-card{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:154px;
  padding:22px;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,59,101,.08);
  border-radius:20px;
  box-shadow:0 20px 60px rgba(15,59,101,.12);
}
.trust-logo-card img{
  max-height:72px;
  width:auto;
  object-fit:contain;
}
.accreditation-strip{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:26px;
}
.accreditation-tile{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:120px;
  padding:20px;
  background:#fff;
  border:1px solid rgba(15,59,101,.08);
  border-radius:18px;
  box-shadow:0 18px 42px rgba(15,59,101,.10);
}
.accreditation-tile img{
  max-height:64px;
  width:auto;
  object-fit:contain;
}
.service-page-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:26px;
  align-items:start;
}
.check-list{
  list-style:none;
  padding:0;
  margin:18px 0 0;
}
.check-list li{
  position:relative;
  padding-left:28px;
  margin-bottom:12px;
}
.check-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--success);
  font-weight:800;
}
@media (max-width: 1080px){
  .header-inner{min-height:112px}
  .brand img{height:128px}
  .brand-copy strong{font-size:1.2rem}
  .trust-grid-logos{grid-template-columns:1fr 1fr}
  .service-page-grid{grid-template-columns:1fr}
}

@media (max-width: 1100px){
  .services-grid,.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .trust-grid{grid-template-columns:1fr 1fr}
  .hero-grid,
  .accreditation-strip,
  .trust-grid-logos,
  .service-page-grid,.builder-heading,.quote-grid,.about-layout,.cta-panel,.pay-grid,.contact-grid,.cards-grid{grid-template-columns:1fr}
  .stats-row,.result-grid,.benefits-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .brand img{height:118px}
}

@media (max-width: 860px){
  .nav-toggle{display:grid;place-items:center}
  .nav-wrap{
    top:100%;

    position:absolute;
    left:0;right:0;top:100%;
    padding:16px;
    background:#fff;
    border-bottom:1px solid rgba(15,59,101,.08);
    box-shadow:0 18px 40px rgba(15,59,101,.1);
    display:none;
    flex-direction:column;
    align-items:stretch;
  }
  .site-header.menu-open .nav-wrap{display:flex}
  .main-nav{flex-direction:column;align-items:stretch}
  .main-nav > a,.dropdown-toggle,.dropdown-menu a{padding:14px 16px}
  .dropdown-menu{
    position:static;
    display:block;
    min-width:auto;
    padding:8px 0 0;
    border:none;
    box-shadow:none;
  }
  .dropdown{border-top:1px solid rgba(15,59,101,.08);padding-top:8px}
  .header-inner{min-height:96px}
  .utility-inner{justify-content:center}
}

@media (max-width: 640px){
  .section,.solar-builder,.cta{padding:68px 0}
  .hero{min-height:auto}
  .hero-copy{padding:56px 0}
  .hero-card,.builder-container,.quote-form,.contact-form,.cred-card,.info-card,.contact-card,.box{padding:22px}
  .stats-row,.result-grid,.services-grid,.gallery-grid,.benefits-grid,.trust-grid,.pay-grid,.contact-grid,.cards-grid{grid-template-columns:1fr}
  .trust-band{margin-top:-28px}
  .brand-copy{display:flex}
  .brand-copy span{font-size:.82rem}
  .brand img{height:92px}
}

.visually-hidden{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  border:0;
}
