/* Breeze Sun Energy — site styles */
/* Palette: primary emerald #0f6e3d, accent amber #e8801a, dark #0e0c19 */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Open Sans','Segoe UI',system-ui,-apple-system,sans-serif;
  color:#3c3a47;
  line-height:1.6;
  background:#fff;
  font-size:16px;
}
img{max-width:100%;height:auto;display:block}
a{color:#0f6e3d;text-decoration:none;transition:color .2s}
a:hover{color:#e8801a}
h1,h2,h3,h4,h5{font-family:'Mulish','Open Sans',sans-serif;color:#333232;font-weight:700;line-height:1.25;margin:0 0 .6em}
h1{font-size:clamp(2rem,4.6vw,3.75rem)}
h2{font-size:clamp(1.6rem,3vw,2.375rem)}
h3{font-size:clamp(1.2rem,1.8vw,1.5rem)}
p{margin:0 0 1em}
ul{padding-left:1.25rem}
.container{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.narrow{max-width:860px;margin-left:auto;margin-right:auto}
:root{
  --green:#0f6e3d;
  --green-dark:#084d28;
  --orange:#e8801a;
  --orange-dark:#c66812;
  --dark:#0e0c19;
  --heading:#333232;
  --text:#3c3a47;
  --muted:#6c757d;
  --light:#f8f9fa;
  --border:#e6e6ea;
}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:#F5F5F5;
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 2px rgba(0,0,0,.04);
}
.nav-wrap{
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1.25rem;
  max-width:1440px;margin:0 auto;
  gap:1.5rem;
}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.brand-logo{width:44px;height:44px;flex:none}
.brand-text{
  font-family:'Mulish',sans-serif;
  font-weight:800;color:var(--heading);
  font-size:1.12rem;line-height:1.1;letter-spacing:.2px;
}
.brand-text small{display:block;font-size:.7rem;font-weight:600;color:var(--green);letter-spacing:1px;text-transform:uppercase}
.primary-nav{flex:1 1 auto;min-width:0;display:flex;justify-content:center;overflow:hidden}
.primary-nav ul{display:flex;gap:.1rem;list-style:none;margin:0;padding:0;flex-wrap:nowrap;max-width:100%}
.primary-nav a{
  display:inline-block;padding:.5rem .55rem;
  font-weight:700;color:var(--heading);font-size:.88rem;
  border-radius:4px;white-space:nowrap;
}
.primary-nav a:hover,.primary-nav a[aria-current="page"]{color:var(--green);background:rgba(15,110,61,.06)}
.nav-cta{display:flex;align-items:center;gap:.75rem}
.phone-link{
  display:inline-flex;align-items:center;gap:.35rem;
  font-weight:700;color:var(--green);font-size:.95rem;
}
.btn{
  display:inline-block;
  padding:.75rem 1.4rem;
  font-weight:700;font-size:.95rem;
  border-radius:4px;
  transition:background .2s,color .2s,transform .1s;
  text-align:center;cursor:pointer;border:2px solid transparent;
  font-family:'Mulish',sans-serif;letter-spacing:.3px;
}
.btn-primary{background:var(--orange);color:var(--dark)}
.btn-primary:hover{background:var(--orange-dark);color:var(--dark)}
.btn-outline{background:transparent;color:#fff;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--green);}
.btn-blue{background:var(--green);color:#fff}
.btn-blue:hover{background:var(--green-dark);color:#fff}
.btn-lg{padding:1rem 1.75rem;font-size:1.05rem}

.nav-toggle{
  display:none;background:transparent;border:0;padding:.5rem;cursor:pointer;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  display:block;width:26px;height:2px;background:var(--heading);position:relative;content:"";
}
.nav-toggle span::before{position:absolute;top:-8px}
.nav-toggle span::after{position:absolute;top:8px}

@media (max-width:1386px){
  .primary-nav{
    position:absolute;left:0;right:0;top:100%;
    background:#fff;border-top:1px solid var(--border);
    padding:.75rem 1.25rem 1rem;
    display:none;
  }
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;gap:0}
  .primary-nav a{display:block;padding:.85rem .25rem;border-bottom:1px solid var(--border);font-size:.95rem}
  .nav-toggle{display:inline-block}
}
@media (max-width:1220px){
  .primary-nav{
    position:absolute;left:0;right:0;top:100%;
    background:#fff;border-top:1px solid var(--border);
    padding:.75rem 1.25rem 1rem;
    display:none;
  }
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;gap:0}
  .primary-nav a{display:block;padding:.85rem .25rem;border-bottom:1px solid var(--border);font-size:.95rem}
  .brand-text small{display:block}
  .nav-toggle{display:inline-block}
  .phone-link span.pl-text{display:none}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;color:#fff;
  padding:8rem 1.25rem 6rem;
  min-height:640px;
  display:flex;align-items:center;
  overflow:hidden;
  background-color:#084d28;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(100deg,
      rgba(8,77,40,.92) 0%,
      rgba(8,77,40,.82) 35%,
      rgba(15,110,61,.55) 65%,
      rgba(26,138,79,.30) 100%),
    linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,0) 40%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 20%, rgba(232,128,26,.15) 0%, transparent 45%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;width:100%}
.hero h1{color:#fff;max-width:22ch;margin-bottom:1rem;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero-lede{
  font-size:1.25rem;max-width:620px;
  color:rgba(255,255,255,.95);
  margin-bottom:2rem;
  text-shadow:0 1px 12px rgba(0,0,0,.35);
}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-grid > div{max-width:640px}

@media (max-width:900px){
  .hero{padding:5rem 1.25rem 4rem;min-height:500px}
}
@media (max-width:600px){
  .hero{padding:4rem 1.25rem 3rem;min-height:440px;background-position:55% center}
  .hero::before{
    background:
      linear-gradient(180deg,
        rgba(8,77,40,.82) 0%,
        rgba(8,77,40,.78) 50%,
        rgba(8,77,40,.88) 100%);
  }
}

/* ---------- Sections ---------- */
.section{padding:5rem 1.25rem}
.section-tight{padding:3.5rem 1.25rem}
.section-light{background:var(--light)}
.section-dark{background:var(--dark);color:rgba(255,255,255,.9)}
.section-dark h2,.section-dark h3{color:#fff}
.section-blue{background:linear-gradient(135deg,#084d28 0%,#0f6e3d 100%);color:#fff}
.section-blue h2,.section-blue h3{color:#fff}
.section-header{text-align:center;max-width:760px;margin:0 auto 3rem}
.eyebrow{
  display:inline-block;text-transform:uppercase;letter-spacing:2px;
  font-size:.78rem;font-weight:800;color:var(--green);
  margin-bottom:.75rem;
}
.section-blue .eyebrow,.section-dark .eyebrow,.hero .eyebrow,.cta-banner .eyebrow{color:#fff;opacity:.92}

/* ---------- Features grid ---------- */
.features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
}
.feature{
  background:#fff;padding:2rem;border-radius:10px;
  border:1px solid var(--border);
  transition:transform .2s,box-shadow .2s;
}
.feature:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.feature-icon{
  width:58px;height:58px;
  background:linear-gradient(135deg,var(--green) 0%,#1a8a4f 100%);
  border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:var(--orange);margin-bottom:1rem;
}
.feature-icon svg{width:30px;height:30px}
.feature h3{margin-bottom:.6rem}
@media (max-width:820px){.features{grid-template-columns:1fr;gap:1.25rem}}

/* ---------- Two-col alternating ---------- */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;
}
.split-reverse{direction:rtl}
.split-reverse>*{direction:ltr}
.split-visual{
  aspect-ratio:4/3;border-radius:14px;overflow:hidden;
  box-shadow:0 15px 40px rgba(0,0,0,.1);
}
@media (max-width:820px){.split,.split-reverse{grid-template-columns:1fr;gap:2rem;direction:ltr}}

/* ---------- Process steps ---------- */
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;
  counter-reset:step;
}
.step{
  position:relative;padding:2.25rem 1.75rem 1.75rem;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;top:-18px;left:1.5rem;
  background:var(--orange);color:var(--dark);
  font-family:'Mulish',sans-serif;font-weight:800;
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  box-shadow:0 4px 12px rgba(232,128,26,.4);
}
@media (max-width:820px){.steps{grid-template-columns:1fr}}

/* ---------- Problem list / check list ---------- */
.bullet-list{list-style:none;padding:0;margin:0;display:grid;gap:1.25rem}
.bullet-list li{
  position:relative;padding-left:2.75rem;
}
.bullet-list li::before{
  content:"";position:absolute;left:0;top:.1rem;
  width:28px;height:28px;border-radius:50%;
  background:var(--orange);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230e0c19' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:18px;background-repeat:no-repeat;background-position:center;
}
.bullet-list.cross li::before{
  background:#d9534f;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}
.bullet-list strong{display:block;color:var(--heading);margin-bottom:.15rem;font-weight:800}

/* ---------- Trust / testimonials ---------- */
.trust-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;
}
.trust-card{
  background:#fff;border:1px solid var(--border);border-radius:10px;
  overflow:hidden;transition:transform .2s,box-shadow .2s;
  height:100%;display:flex;flex-direction:column;
}
.trust-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.trust-card .ph{aspect-ratio:4/5}
.trust-card h3{padding:1rem 1rem 0;font-size:1.05rem;margin-bottom:.25rem}
.trust-card p{padding:0 1rem 1rem;color:var(--muted);font-size:.9rem;margin:0}
@media (max-width:980px){.trust-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.trust-grid{grid-template-columns:1fr}}

/* ---------- Slider (generic carousel) ---------- */
.slider{
  position:relative;padding:0 3.5rem;
}
.slider-viewport{
  overflow:hidden;border-radius:10px;
}
.slider-track{
  display:flex;list-style:none;margin:0;padding:.5rem 0;
  gap:1.25rem;
  transition:transform .55s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.slider-slide{
  flex:0 0 calc((100% - 3 * 1.25rem) / 4);
  min-width:0;display:flex;
}
.slider-slide > *{width:100%}
.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:#fff;border:1px solid var(--border);
  color:var(--green);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(0,0,0,.12);
  z-index:2;transition:background .2s,color .2s,transform .2s,opacity .2s;
  padding:0;
}
.slider-btn:hover{background:var(--green);color:#fff;transform:translateY(-50%) scale(1.06)}
.slider-btn:disabled{opacity:.35;cursor:not-allowed}
.slider-btn:disabled:hover{background:#fff;color:var(--green);transform:translateY(-50%) scale(1)}
.slider-btn svg{width:22px;height:22px}
.slider-btn.prev{left:0}
.slider-btn.next{right:0}

.slider-dots{
  display:flex;justify-content:center;gap:.5rem;
  list-style:none;padding:0;margin:1.5rem 0 0;
}
.slider-dots button{
  width:10px;height:10px;border-radius:50%;padding:0;
  border:0;background:rgba(15,110,61,.25);cursor:pointer;
  transition:background .2s,transform .2s,width .3s;
}
.slider-dots button:hover{background:rgba(15,110,61,.5)}
.slider-dots button[aria-current="true"]{
  background:var(--green);width:28px;border-radius:6px;
}

@media (max-width:1024px){
  .slider-slide{flex:0 0 calc((100% - 2 * 1.25rem) / 3)}
}
@media (max-width:760px){
  .slider{padding:0 1rem}
  .slider-btn{width:40px;height:40px}
  .slider-btn.prev{left:-.25rem}
  .slider-btn.next{right:-.25rem}
  .slider-slide{flex:0 0 calc((100% - 1.25rem) / 2)}
}
@media (max-width:520px){
  .slider-slide{flex:0 0 100%}
}

/* ---------- Table ---------- */
.price-table{
  width:100%;border-collapse:collapse;margin-top:1.5rem;
  background:#fff;border-radius:10px;overflow:hidden;
  box-shadow:0 6px 20px rgba(0,0,0,.05);
  font-size:.95rem;
}
.price-table th,.price-table td{
  padding:1rem;text-align:left;border-bottom:1px solid var(--border);
}
.price-table th{
  background:var(--green);color:#fff;font-weight:700;
  font-family:'Mulish',sans-serif;
}
.price-table tr:last-child td{border-bottom:0}
.price-table tr:nth-child(even) td{background:var(--light)}
.table-scroll{overflow-x:auto}

/* ---------- FAQ ---------- */
.faq details{
  border:1px solid var(--border);border-radius:8px;
  margin-bottom:.75rem;background:#fff;
  padding:0;
}
.faq summary{
  padding:1.1rem 1.25rem;cursor:pointer;
  font-weight:700;font-family:'Mulish',sans-serif;color:var(--heading);
  list-style:none;display:flex;justify-content:space-between;align-items:center;
  gap:1rem;font-size:1.02rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.6rem;color:var(--green);font-weight:400;
  transition:transform .2s;line-height:1;
}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--border)}
.faq details>div{padding:1.25rem}
.faq details>div p:last-child{margin-bottom:0}

/* ---------- Placeholder ---------- */
.ph{
  position:relative;background:#e9eaf0;
  background-image:
    linear-gradient(135deg,rgba(15,110,61,.1) 0%,rgba(232,128,26,.12) 100%);
  overflow:hidden;
  aspect-ratio:16/9;
}
.ph::after{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg,rgba(15,110,61,.06) 0 12px,transparent 12px 24px);
}
.ph>img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;z-index:1;
}
.ph:has(> img)::after{display:none}

/* ---------- Contact info block (replaces forms) ---------- */
.contact-card{
  background:#fff;padding:2.25rem;border-radius:12px;
  box-shadow:0 20px 60px rgba(0,0,0,.12);
  border-top:4px solid var(--orange);
  color:var(--text);
}
.contact-card h3{margin-bottom:1.5rem;color:var(--heading)}
.contact-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr 1fr;gap:1.5rem 2rem;
}
.contact-list li{
  display:grid;grid-template-columns:auto 1fr;
  align-items:start;gap:.25rem .9rem;
}
.contact-list li > svg{
  grid-row:span 2;align-self:start;
  flex:none;color:var(--green);
  width:28px;height:28px;
  background:rgba(15,110,61,.08);
  border-radius:50%;padding:5px;
  box-sizing:border-box;
}
.contact-list strong{
  color:var(--muted);font-weight:700;
  font-size:.72rem;text-transform:uppercase;letter-spacing:1.2px;
  line-height:1;margin:4px 0 0;
}
.contact-list .val{
  color:var(--heading);font-weight:600;
  font-size:1rem;line-height:1.4;
  font-family:'Mulish',sans-serif;
}
.contact-list .val a{color:var(--heading)}
.contact-list .val a:hover{color:var(--green)}
@media (max-width:620px){
  .contact-list{grid-template-columns:1fr;gap:1.25rem}
}

/* ---------- Resource cards ---------- */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.res-card{
  background:#fff;border-radius:10px;overflow:hidden;
  border:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:transform .2s,box-shadow .2s;
}
.res-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.08)}
.res-card .ph{aspect-ratio:16/10}
.res-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.res-card h3{font-size:1.1rem;margin-bottom:.5rem}
.res-card .tag{color:var(--green);font-weight:700;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:.5rem}
@media (max-width:820px){.res-grid{grid-template-columns:1fr}}

/* ---------- CTA banner ---------- */
.cta-banner{
  background:linear-gradient(135deg,#084d28 0%,#0f6e3d 60%,#1a8a4f 100%);
  color:#fff;padding:4rem 1.25rem;
  text-align:center;position:relative;overflow:hidden;
}
.cta-banner--bg{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 30%,rgba(232,128,26,.18) 0%,transparent 50%);
  pointer-events:none;
}
.cta-banner h2{color:#fff;max-width:780px;margin-left:auto;margin-right:auto}
.cta-banner p{max-width:640px;margin:0 auto 1.5rem;color:rgba(255,255,255,.9);font-size:1.1rem}
.cta-banner .hero-actions{justify-content:center;position:relative;z-index:2}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--dark);color:rgba(255,255,255,.7);
  padding:4rem 1.25rem 1.5rem;
}
.footer-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:3rem;
}
.footer-grid h4{
  color:#fff;font-family:'Mulish',sans-serif;
  font-size:1rem;text-transform:uppercase;letter-spacing:1.5px;
  margin-bottom:1rem;
}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:.55rem}
.footer-grid a{color:rgba(255,255,255,.72);font-size:.94rem}
.footer-grid a:hover{color:var(--orange)}
.footer-brand p{font-size:.95rem;color:rgba(255,255,255,.65);margin-bottom:1rem}
.footer-brand .brand-text{color:#fff}
.footer-brand .brand-text small{color:var(--orange)}
.footer-bottom{
  max-width:1180px;margin:3rem auto 0;
  padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.85rem;color:rgba(255,255,255,.55);
}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:var(--orange)}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Cookie banner ---------- */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:9999;
  background:#fff;border-top:3px solid var(--orange);
  box-shadow:0 -6px 24px rgba(0,0,0,.15);
  padding:1.2rem 1.5rem;
  display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;
  color:var(--text);font-size:.95rem;
}
.cookie-banner p{margin:0;flex:1;min-width:260px}
.cookie-banner .actions{display:flex;gap:.5rem;flex-wrap:wrap}
.cookie-banner button{
  padding:.6rem 1.1rem;border-radius:4px;font-weight:700;cursor:pointer;
  border:2px solid var(--green);background:transparent;color:var(--green);
  font-family:'Mulish',sans-serif;font-size:.9rem;
}
.cookie-banner button[data-consent="accept"]{background:var(--orange);border-color:var(--orange);color:var(--dark)}
.cookie-banner button:hover{opacity:.9}

/* ---------- Legal pages ---------- */
.legal-main{padding:3rem 1.25rem 5rem;max-width:820px;margin:0 auto}
.legal-main h1{margin-bottom:.4rem}
.legal-main .meta{color:var(--muted);font-size:.92rem;margin-bottom:2.5rem}
.legal-main h2{margin-top:2.5rem;font-size:1.55rem}
.legal-main h3{margin-top:1.5rem;font-size:1.15rem}
.legal-main .caps{text-transform:uppercase;font-size:.9rem}
.legal-main table{width:100%;border-collapse:collapse;margin:1rem 0 1.5rem;font-size:.9rem}
.legal-main th,.legal-main td{padding:.7rem;border:1px solid var(--border);text-align:left;vertical-align:top}
.legal-main th{background:var(--light)}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-lg{margin-top:2rem}
.visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);border:0}
