/* Green Homes Improvements — design system.
   Based on Blufire landing-page template VARIATION 3 (Teal & Green roofing,
   _Blufire-Web-Assets/landing-page-templates/templates/variation-3), re-skinned
   to Green Homes' brand: deep forest green (was teal), fresh green accent,
   gold CTAs (from their logo). Class names kept from the template.
   Note: .btn-green renders GOLD here (brand CTA colour). */
:root{
  --teal:#14522d;        /* deep forest green (template's dark teal slot) */
  --teal-2:#1c6b3c;
  --green:#2fb56b;       /* fresh green accent */
  --green-d:#279a5b;
  --gold:#f2a71b;
  --gold-d:#d98f0a;
  --bg:#f8f8f6;
  --tint:#edf4ee;
  --mint:#e8f7ee;
  --grey:#7d827e;
  --grey-2:#9aa09b;
  --line:#e4e7e4;
  --ph:#808080;
  --white:#fff;
  --maxw:1290px;
  --side:75px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--teal);background:#fff;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.display{font-family:'Sora',sans-serif;line-height:1.14;letter-spacing:-.01em}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--side)}
.green{color:var(--green)}
.gold{color:var(--gold)}
.ph{background:var(--ph);position:relative;overflow:hidden}
.eyebrow{color:var(--green);font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;display:inline-flex;align-items:center;gap:14px}
.eyebrow.line::after{content:"";width:90px;height:2px;background:var(--green);display:inline-block}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:'Sora';font-weight:700;font-size:15px;letter-spacing:.04em;border:none;cursor:pointer;border-radius:6px;text-transform:uppercase}
.btn-green{background:var(--gold);color:var(--teal);padding:16px 28px}
.btn-green:hover{background:var(--gold-d)}
.acirc{width:46px;height:46px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.acirc-dark{background:var(--teal);color:#fff}
.acirc-line{border:1px solid var(--line);color:var(--teal);background:#fff}
.gchk{color:var(--green);flex:0 0 auto}

/* topbar */
.topbar{background:var(--teal);color:#fff;font-size:14px;font-weight:500}
.topbar .wrap{display:flex;justify-content:center;gap:60px;padding:15px 75px}
.topbar .t{display:flex;align-items:center;gap:10px}

/* header */
.header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.header .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 75px}
.logo img{height:54px;width:auto;border-radius:6px}
.nav{display:flex;gap:28px;font-weight:500;color:var(--teal)}
.nav a:hover{color:var(--green)}
.has-drop{position:relative}
.has-drop .drop{display:none;position:absolute;top:100%;left:-14px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 14px 34px rgba(20,82,45,.14);padding:8px 0;min-width:240px;z-index:70}
.has-drop:hover .drop{display:block}
.drop a{display:block;padding:10px 18px;font-size:14.5px}
.drop a:hover{background:var(--mint);color:var(--teal)}
.header-right{display:flex;align-items:center;gap:18px}
.hphone{display:flex;align-items:center;gap:10px;color:var(--teal);font-weight:700;font-family:'Sora'}
.hphone .ic{color:var(--green)}
.hphone small{display:block;font-family:'DM Sans';font-size:11px;color:var(--grey);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.hphone span{line-height:1.25;font-size:16px;white-space:nowrap}

/* hero */
.hero .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding-top:70px;padding-bottom:90px;align-items:start}
.tag{display:inline-block;background:var(--mint);color:var(--teal);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:8px 14px;margin-bottom:26px}
.tag::before{content:"■ ";color:var(--green)}
.hero h1{font-size:52px;font-weight:700;margin-bottom:24px}
.hero .sub{color:var(--grey);font-size:18px;max-width:500px;padding-bottom:26px;border-bottom:1px solid var(--line);margin-bottom:26px}
.hero .fl{font-family:'Sora';font-weight:700;font-size:18px;margin-bottom:18px}
.hform{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:640px}
.field{border:1px solid var(--line);border-radius:6px;padding:15px 16px;font-family:'DM Sans';font-size:15px;color:var(--teal);width:100%;display:flex;align-items:center;gap:10px;background:#fff}
.field input,.field select{border:none;outline:none;width:100%;font:inherit;color:var(--teal);background:transparent}
.field input::placeholder{color:var(--grey-2)}
.field select:invalid,.field select option[value=""]{color:var(--grey-2)}
.field .fi{color:var(--green);flex:0 0 auto}
.field:focus-within{border-color:var(--green)}
.hform .femail{grid-column:1/-1}
.hform .btn{grid-column:1;justify-self:start;margin-top:4px}
.hform .fnote{grid-column:1/-1;color:var(--grey);font-size:12.5px}
.hero-right{position:relative;padding-top:30px}
.hero-img{width:100%;height:640px;position:relative;z-index:2;object-fit:cover}
.hero-right .shadow{position:absolute;right:-26px;bottom:-26px;width:90%;height:640px;background:var(--teal);z-index:1}
.award{position:absolute;top:-10px;left:-40px;z-index:3;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#f5d97e,#caa23c);display:flex;align-items:center;justify-content:center;color:#6b531a;font-family:'Sora';font-weight:700;font-size:11.5px;text-align:center;box-shadow:0 10px 24px rgba(0,0,0,.2);padding:16px}

/* badge strip (template's logos strip, with real credential badges) */
.logos{background:var(--bg)}
.logos .wrap{display:flex;justify-content:space-between;align-items:center;gap:28px;padding:26px 75px;flex-wrap:wrap}
.logos img{height:40px;width:auto}
.logos .grating{display:flex;align-items:center;gap:8px;font-weight:700;font-family:'Sora';font-size:16px}
.logos .grating .gg{display:inline-flex;width:26px;height:26px;border-radius:50%;background:#fff;border:1px solid #e0e0e0;color:#4285F4;font-weight:800;align-items:center;justify-content:center;font-family:Arial}
.logos .grating .st{color:var(--gold);letter-spacing:2px}

/* guarantee dark band */
.guar{background:var(--teal);color:#fff;text-align:center}
.guar .wrap{padding:80px 75px}
.guar h2{font-size:44px;font-weight:700;margin-bottom:26px}
.guar .sub{color:#b9cbbf;max-width:760px;margin:0 auto 12px;font-size:17px}
.guar .sub2{color:#b9cbbf;margin-bottom:50px}
.guar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.12)}
.gcard{border:1px solid rgba(255,255,255,.12);padding:38px 30px;text-align:left;min-height:300px;display:flex;flex-direction:column}
.gcard .ic{width:62px;height:62px;border-radius:50%;border:1.5px solid var(--green);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:auto}
.gcard h4{font-family:'Sora';font-size:21px;font-weight:600;margin:24px 0 14px}
.gcard p{color:#b9cbbf;font-size:14px}

/* section */
.sec{padding:90px 0}
h2.h{font-size:44px;font-weight:700}
.lead{color:var(--grey);font-size:17px;line-height:1.6}

/* testimonials */
.testi .head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:46px}
.testi h2{font-size:44px;font-weight:700;margin-top:14px}
.testi-row{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.tcard{border:1px solid var(--line);border-radius:10px;padding:34px}
.tcard .stars{color:var(--gold);letter-spacing:4px;font-size:20px;margin-bottom:20px}
.tcard p{color:var(--teal);font-size:15px;margin-bottom:28px}
.tcard .who{display:flex;align-items:center;gap:16px;border-top:1px solid var(--line);padding-top:18px;flex-wrap:wrap}
.tcard .who b{font-family:'Sora';font-weight:700}
.tcard .who .loc{color:var(--grey);font-size:14px;border-left:1px solid var(--line);padding-left:16px}
.tcard .who .tg{margin-left:auto;background:var(--mint);color:var(--teal-2);font-weight:700;font-size:12px;text-transform:uppercase;padding:6px 12px;border-radius:4px}

/* how it works */
.how{background:var(--bg)}
.how .wrap{padding:90px 75px;text-align:center}
.how h2{font-size:44px;font-weight:700;margin:10px 0 56px}
.step{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:40px;text-align:left;align-items:stretch}
.step .img{height:380px;object-fit:cover;width:100%}
.step .card{padding:50px;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--line);position:relative;overflow:hidden;background:#fff}
.step .card .n{font-family:'Sora';font-weight:700;font-size:26px;color:var(--green);margin-bottom:30px}
.step .card h4{font-family:'Sora';font-size:28px;font-weight:600;margin-bottom:18px}
.step .card p{color:var(--grey);font-size:15px;max-width:400px}
.step.dark .card{background:var(--teal);color:#fff;border:none;border-radius:0 120px 0 0}
.step.dark .card .n{color:var(--gold)}
.step.dark .card p{color:#b9cbbf}

/* our services */
.osvc{position:relative}
.osvc .top{display:grid;grid-template-columns:1fr 1fr;align-items:center}
.osvc .top .l{padding:90px 0 40px}
.osvc .top .l .inner{max-width:560px;padding-right:60px;margin-left:calc((100vw - var(--maxw))/2 + 75px)}
.osvc .top .r{background:var(--teal);align-self:stretch;display:flex;align-items:center;padding:40px 75px}
.osvc h2{font-size:44px;font-weight:700;margin-top:12px}
.osvc-cards{max-width:var(--maxw);margin:0 auto;padding:0 75px 90px;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
.ocard{display:grid;grid-template-columns:1fr 100px;border-radius:10px;overflow:hidden;min-height:300px;transition:transform .2s,box-shadow .2s}
.ocard:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,82,45,.18)}
.ocard .body{background:var(--teal);color:#fff;padding:34px}
.ocard .ic{width:52px;height:52px;border-radius:50%;border:1.5px solid var(--green);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.ocard h4{font-family:'Sora';font-size:22px;font-weight:600;margin-bottom:12px}
.ocard p{color:#b9cbbf;font-size:13px}
.ocard .pic{background-size:cover;background-position:center}
.ocard .go{color:var(--gold);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.05em;margin-top:16px;display:inline-block}

/* offer band */
.offer{background:var(--teal);color:#fff;text-align:center}
.offer .wrap{padding:80px 75px}
.offer h2{font-size:40px;font-weight:700;margin:14px 0 24px}
.offer .btn{margin-bottom:46px}
.offer-row{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;text-align:left}
.ofcard{border:1px solid rgba(255,255,255,.14);border-radius:10px;padding:34px;position:relative}
.ofcard .num{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;font-family:'Sora';font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.ofcard h4{font-family:'Sora';font-size:20px;font-weight:600;margin-bottom:12px}
.ofcard p{color:#b9cbbf;font-size:13px}
.ofcard .bonus{position:absolute;top:20px;right:20px;background:var(--gold);color:var(--teal);font-size:11px;font-weight:700;text-transform:uppercase;padding:5px 10px;border-radius:4px}

/* call cta */
.callcta{background:#fff}
.callcta .wrap{padding:70px 75px}
.callcta .inner{background:var(--tint);border-radius:14px;padding:50px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.callcta h2{font-size:40px;font-weight:700}
.callcta .r{display:flex;flex-direction:column;gap:18px;align-items:flex-end}
.callcta .r p{color:var(--grey);font-size:14px;max-width:360px;text-align:right}

/* recent works */
.works{background:var(--bg)}
.works .wrap{padding:90px 75px;text-align:center}
.works h2{font-size:44px;font-weight:700;margin:10px 0 50px}
.works-row{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.works-row img{height:420px;object-fit:cover;width:100%}

/* values */
.values .head{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:46px}
.values h2{font-size:42px;font-weight:700;margin-top:14px}
.values-row{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.vcard{border:1px solid var(--line);border-radius:10px;padding:38px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.vcard.mint{background:var(--mint);border:none;border-radius:0 0 100px 0}
.vcard .ic{width:62px;height:62px;border-radius:50%;border:1.5px solid var(--green);color:var(--green);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.vcard h4{font-family:'Sora';font-size:22px;font-weight:600;margin:0 0 14px}
.vcard p{color:var(--grey);font-size:14px}

/* about dark split */
.about3{background:var(--teal);color:#fff}
.about3 .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:90px 75px;align-items:center}
.about3 h2{font-size:44px;font-weight:700;margin:18px 0 22px}
.about3 .lead{color:#b9cbbf;margin-bottom:30px}
.about3 .eyebrow{color:var(--gold)}
.about3 .eyebrow.line::after{background:var(--gold)}
.about3-img{position:relative}
.about3-img img{width:100%;height:520px;object-fit:cover;position:relative;z-index:2}
.about3-img .shadow{position:absolute;right:-24px;top:-24px;width:90%;height:520px;background:var(--teal-2);z-index:1}

/* feature split */
.fsplit .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.fsplit-img{position:relative}
.fsplit-img img{width:100%;height:560px;object-fit:cover;position:relative;z-index:2}
.fsplit-img .shadow{position:absolute;left:-24px;top:-24px;width:90%;height:560px;background:var(--tint);z-index:1}
.fsplit h2{font-size:42px;font-weight:700;margin:14px 0 18px}
.fsplit .lead{margin-bottom:30px;max-width:460px}
.fitem{display:grid;grid-template-columns:auto 1fr;gap:18px;padding-bottom:28px;position:relative}
.fitem .sq{width:14px;height:14px;background:var(--green);margin-top:6px}
.fitem:not(:last-child) .sq::after{content:"";position:absolute;left:6px;top:20px;bottom:0;width:2px;background:var(--green)}
.fitem h4{font-family:'Sora';font-size:20px;font-weight:600;margin-bottom:8px}
.fitem p{color:var(--grey);font-size:14px}

/* stats dark */
.stats3{background:var(--teal);color:#fff}
.stats3 .wrap{padding:90px 75px}
.stats3 .head{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:50px;align-items:start}
.stats3 .head .lead{color:#b9cbbf;margin-top:18px}
.stats3 h2{font-size:42px;font-weight:700}
.stats3 .eyebrow{color:var(--gold)}
.stats3 .eyebrow.line::after{background:var(--gold)}
.stats3-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(255,255,255,.12)}
.scard3{border:1px solid rgba(255,255,255,.12);padding:34px 28px}
.scard3 .top{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.scard3 .ic{width:44px;height:44px;border-radius:8px;border:1.5px solid var(--green);color:var(--green);display:flex;align-items:center;justify-content:center}
.scard3 .num{font-family:'Sora';font-weight:700;font-size:38px}
.scard3 .num i{color:var(--green);font-style:normal}
.scard3 h4{font-family:'Sora';font-size:20px;font-weight:600;margin-bottom:12px}
.scard3 p{color:#b9cbbf;font-size:14px}

/* faq */
.faq3 .wrap{padding:90px 75px;text-align:center}
.faq3 h2{font-size:44px;font-weight:700;margin:10px 0 50px}
.faq3-list{display:flex;flex-direction:column;gap:18px;text-align:left;margin-bottom:50px}
.qa{border:1px solid var(--line);border-radius:10px;padding:26px 30px;cursor:pointer}
.qa .row{display:flex;justify-content:space-between;align-items:center;gap:20px}
.qa .q{font-family:'Sora';font-weight:600;font-size:18px}
.qa.open{background:var(--mint);border-color:transparent}
.qa p{color:var(--grey);font-size:14px;margin-top:14px;max-width:900px;display:none}
.qa.open p{display:block}

/* final contact dark */
.contact3{background:var(--teal);color:#fff}
.contact3 .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:90px 75px;align-items:center}
.contact3 h2{font-size:44px;font-weight:700;margin:18px 0 20px}
.contact3 .lead{color:#b9cbbf;max-width:440px}
.contact3 .eyebrow{color:var(--gold)}
.contact3 .eyebrow.line::after{background:var(--gold)}
.cform{display:flex;flex-direction:column;gap:16px}
.cform .field{background:transparent;border-color:rgba(255,255,255,.2);color:#fff}
.cform .field input{color:#fff}
.cform .field input::placeholder{color:#a9c4b1}
.cform .field select{color:#fff}
.cform .field select option{color:var(--teal)}
.cform .btn{margin-top:6px;width:100%;justify-content:center}
.cform .fnote{color:#a9c4b1;font-size:12.5px}

/* footer */
.footer{background:var(--teal);color:#fff;border-top:1px solid rgba(255,255,255,.08)}
.footer .wrap{display:grid;grid-template-columns:1.2fr .8fr 1.2fr;gap:50px;padding:70px 75px;align-items:start}
.footer .flogo img{height:56px;border-radius:6px;margin-bottom:18px}
.footer .lead{color:#b9cbbf;margin-bottom:26px;font-size:14px}
.foot-nav{display:flex;flex-direction:column;gap:16px;border-left:1px solid rgba(255,255,255,.12);padding-left:40px}
.foot-nav a{font-weight:500}
.foot-nav a:hover{color:var(--green)}
.foot-card{background:var(--teal-2);border-radius:10px;padding:34px}
.foot-card .it{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.foot-card .it:last-child{margin-bottom:0}
.foot-card .ic{color:var(--gold);flex:0 0 auto}
.foot-card .it span{font-family:'Sora';font-size:15px;word-break:break-word}
.fbot{border-top:1px solid rgba(255,255,255,.1);padding:20px 75px;font-size:13px;color:#8fae97;text-align:center}

/* sticky mobile bar (CRO playbook, not in template) */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;box-shadow:0 -6px 24px rgba(0,0,0,.22)}
.sc-call,.sc-quote{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 0;font-weight:800;font-family:'Sora';font-size:14px;text-transform:uppercase}
.sc-call{background:var(--teal);color:#fff}
.sc-quote{background:var(--gold);color:var(--teal)}

/* ===== TABLET ===== */
@media (max-width:980px){
  :root{--side:32px}
  .hero h1{font-size:40px}
  .nav{display:none}
  .guar-grid,.stats3-grid{grid-template-columns:repeat(2,1fr)}
  .osvc-cards,.offer-row,.works-row,.values-row{grid-template-columns:repeat(2,1fr)}
  h2.h,.guar h2,.testi h2,.how h2,.osvc h2,.offer h2,.callcta h2,.works h2,.values h2,.about3 h2,.fsplit h2,.stats3 h2,.faq3 h2,.contact3 h2{font-size:34px}
  .osvc .top .l .inner{margin-left:32px}
}
/* ===== MOBILE ===== */
@media (max-width:768px){
  :root{--side:18px}
  body{font-size:15px;padding-bottom:56px}
  .header-right .btn{display:none}
  .hphone small{display:none}
  .topbar .wrap{flex-direction:column;gap:8px;padding:12px 18px}
  .header .wrap{padding:12px 18px}
  .logo img{height:44px}
  .hero .wrap{grid-template-columns:1fr;gap:40px;padding-top:42px;padding-bottom:54px}
  .hero h1{font-size:31px}
  .hform{grid-template-columns:1fr;max-width:none}
  .hform .btn{justify-self:stretch;width:100%}
  .hero-img,.hero-right .shadow{height:340px}
  .award{width:110px;height:110px;left:auto;right:6px;top:-20px;font-size:10px}
  .hero-right .shadow,.about3-img .shadow,.fsplit-img .shadow{display:none}
  .hero-right{padding-top:0}
  .logos .wrap{flex-wrap:wrap;gap:18px;justify-content:center;padding:22px 18px}
  .logos img{height:32px}
  .sec{padding:54px 0}
  .guar .wrap,.how .wrap,.osvc-cards,.offer .wrap,.callcta .wrap,.works .wrap,.stats3 .wrap,.faq3 .wrap,.footer .wrap{padding-left:18px;padding-right:18px}
  .guar-grid,.stats3-grid,.testi-row,.osvc-cards,.offer-row,.works-row,.values-row,.values .head,.testi .head,.stats3 .head,.footer .wrap,.contact3 .wrap,.about3 .wrap,.fsplit .wrap,.step,.callcta .inner,.osvc .top{grid-template-columns:1fr}
  .gcard,.scard3,.vcard{min-height:auto}
  .step.dark .card{border-radius:0 60px 0 0}
  .step .card{padding:34px}
  .step .img,.works-row img{height:280px}
  .about3-img img,.fsplit-img img{height:320px}
  .about3 .wrap,.fsplit .wrap,.contact3 .wrap{padding-top:54px;padding-bottom:54px}
  .osvc .top .l{padding:46px 0 0}
  .osvc .top .l .inner{margin-left:18px;padding-right:18px}
  .osvc .top .r{padding:26px 18px}
  .osvc-cards{padding-bottom:54px}
  .ocard{grid-template-columns:1fr}
  .ocard .pic{height:140px}
  .callcta .inner{padding:30px;text-align:center}
  .callcta .r{align-items:center}.callcta .r p{text-align:center}
  .foot-nav{border-left:none;padding-left:0}
  .sticky-cta{display:flex}
  h2.h,.guar h2,.testi h2,.how h2,.osvc h2,.offer h2,.callcta h2,.works h2,.values h2,.about3 h2,.fsplit h2,.stats3 h2,.faq3 h2,.contact3 h2{font-size:27px}
}

/* reCAPTCHA badge: lift above the mobile sticky bar */
@media (max-width:768px){ .grecaptcha-badge{ bottom:84px !important } }
