/* Base Reset (minimal) */
*,*::before,*::after{box-sizing:border-box;}
body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0;}
ul[role='list'],ol[role='list']{list-style:none;margin:0;padding:0;}
body{font-family:var(--font-body);line-height:1.58;-webkit-font-smoothing:antialiased;background:#fff;color:#1a1f23;}
img{max-width:100%;display:block;height:auto;}
input,button,textarea,select{font:inherit;}
:root{
  --bg:#ffffff;
  --accent:#0b6c4f;
  --accent-alt:#074c37;
  --text:#1a1f23;
  --text-light:#4d5b66;
  --border:#e2e8ec;
  --radius:12px;
  --shadow:0 2px 4px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.04);
  --space:clamp(.75rem,2vw,1.25rem);
  --wrapper:1200px;
  --font-body: 'Atkinson Hyperlegible', system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --font-head: 'Plus Jakarta Sans', system-ui,-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  /* Added logo height & top bar height variables (updated) */
  --top-bar-h:34px;
  --logo-h:clamp(120px,16vw,120px);
}

.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;padding:.5rem .75rem;background:#000;color:#fff;z-index:1000;}

.container{width:100%;max-width:var(--wrapper);margin:0 auto;padding:0 var(--space);} 
.site-header{background:#f9f7f6;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--border);overflow:visible;}
.header-inner{display:flex;align-items:center;gap:2rem;min-height:70px;position:relative;}
.logo{object-fit:contain;height:var(--logo-h);width:auto;margin-top:calc(-1 * var(--top-bar-h));position:relative;z-index:5;}
.primary-nav ul{display:flex;gap:1.25rem;flex-wrap:wrap;align-items:center;list-style:none;margin:0;padding:0;}
.primary-nav a{position:relative;display:inline-block;padding:.35rem .5rem;font-weight:500;color:var(--text);text-decoration:none;}
.primary-nav a:focus-visible,.primary-nav a:hover{color:var(--accent);} 

.primary-nav a[aria-current="true"]{color:var(--accent);font-weight:600;}
.primary-nav a[aria-current="true"]::after{content:"";position:absolute;left:50%;bottom:-2px;transform:translateX(-50%);width:60%;height:2px;background:var(--accent);border-radius:2px;}

.hero{padding:clamp(4rem,9vw,7rem) 0;background:
  linear-gradient(145deg,rgba(255,255,255,.9),rgba(255,255,255,.82) 55%,rgba(255,255,255,.75)),
  url('hero.jpg');
  background-size:cover; 
  background-position:center; 
  background-repeat:no-repeat;
  background-color:#fff; 
}
.hero-inner{display:grid;gap:2rem;grid-template-columns:1fr;}
.hero-text{max-width:650px;}
.hero h1{font-size:clamp(1.9rem,4.2vw,3rem);line-height:1.1;margin-bottom:1rem;}
.tagline{font-size:clamp(1rem,1.3vw,1.25rem);color:var(--text-light);margin-bottom:1.5rem;}

.section{padding:clamp(3.5rem,7vw,6rem) 0;position:relative;}
.section + .section{margin-top:0;}
/* Alternating background for visual differentiation (warm neutrals) */
.section.alt{background:linear-gradient(180deg,#f9f7f6,#fcfbfa);} 
/* Add subtle divider line before alt sections (except first) */
.section.alt::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:min(92%,1100px);height:1px;background:linear-gradient(to right,transparent,#dbe3e7,transparent);} 

/* Equal-height service cards */
.service-grid{display:grid;gap:1.75rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));align-items:stretch;}
.card{display:flex;flex-direction:column;justify-content:flex-start;}
.card .feature-list{margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border);} 

/* Add balanced vertical rhythm around image banners */
.image-banner{margin:clamp(3rem,8vw,5rem) auto;}

/* Refined hero spacing after simplification */
.hero{padding:clamp(4rem,9vw,7rem) 0;}

/* CTA alt styling */
.cta-alt{margin-top:1rem;font-size:.95rem;color:var(--text-light);} 
.cta-alt a{color:var(--accent-alt);font-weight:600;text-decoration:none;border-bottom:1px solid currentColor;}
.cta-alt a:hover,.cta-alt a:focus-visible{color:var(--accent);}

.section{padding:clamp(2.5rem,6vw,4.5rem) 0;}
.section h2{font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.2;margin-bottom:1.25rem;}
.section p{max-width:70ch;}

.service-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));}
.card{background:#fff;border:1px solid var(--border);padding:1.25rem 1.25rem 1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;}
.card h3{margin:0 0 .75rem;font-size:1.15rem;}
.feature-list{list-style:disc;margin:0 0 0 1rem;padding:0;display:grid;gap:.35rem;font-size:.95rem;color:var(--text-light);} 

.rates-wrap{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));}
.rate-block{background:#fff;border:1px solid var(--border);padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden;}
.rate-block h3{margin:0 0 .75rem;}
.price{font-size:2rem;font-weight:600;margin:.25rem 0 1rem;color:var(--accent-alt);} 
.price .amount{font-size:2.25rem;}
.price.variable{font-size:1.4rem;}
.small-print{font-size:.8rem;line-height:1.3;color:var(--text-light);} /* increased from .75rem */
.inline-cta{text-align:center;margin-top:2rem;}

.eco-points{columns:2;gap:1.5rem;list-style:disc;margin:1rem 0 0 1rem;padding:0;}
.eco-points li{break-inside:avoid;font-size:.95rem;margin-bottom:.25rem;}
@media (max-width:700px){.eco-points{columns:1;}}

.contact form{margin-top:1rem;}
.form-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));}
.field{display:flex;flex-direction:column;gap:.4rem;}
.field.full{grid-column:1/-1;}
label{font-weight:500;font-size:.9rem;}
input,select,textarea{border:1px solid var(--border);border-radius:8px;padding:.65rem .75rem;background:#fff;color:var(--text);min-height:44px;}
textarea{min-height:140px;}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:1px;}
input[aria-invalid="true"],select[aria-invalid="true"],textarea[aria-invalid="true"]{border-color:#c23616;box-shadow:0 0 0 2px rgba(194,54,22,.15);} 
.help{font-size:.8rem;color:var(--text-light);} /* increased from .75rem */
.form-foot{margin-top:1rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem;}
.form-status{font-size:.85rem;min-height:1.2em;}
.req{color:#c23616;margin-left:.15rem;}
.hp-field{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden;}

.social ul{display:flex;gap:1rem;list-style:none;margin:2rem 0 0;padding:0;flex-wrap:wrap;}
.social a{text-decoration:none;color:var(--accent-alt);font-weight:500;}
.social a:hover,.social a:focus-visible{text-decoration:underline;}

.btn{--btn-bg:var(--accent);--btn-bg-hover:var(--accent-alt);--btn-color:#fff;--btn-shadow:0 2px 4px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.08);display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.25rem;border-radius:50px;font-weight:600;font-size:.95rem;text-decoration:none;line-height:1;color:var(--btn-color);background:var(--btn-bg);border:2px solid var(--btn-bg);box-shadow:var(--btn-shadow);transition:.25s;cursor:pointer;}
.btn.secondary{--btn-bg:#ffffff;--btn-color:var(--accent);color:var(--accent);border-color:var(--accent);}
.btn:hover,.btn:focus-visible{background:var(--btn-bg-hover);border-color:var(--btn-bg-hover);color:#fff;}
.btn.secondary:hover,.btn.secondary:focus-visible{background:var(--accent);color:#fff;}

.site-footer{background:#f5f7f8;border-top:1px solid var(--border);padding:2rem 0;margin-top:2rem;font-size:.8rem;color:var(--text-light);}
.footer-inner{display:flex;flex-direction:column;gap:.5rem;text-align:center;}
.footer-inner a{color:var(--accent-alt);}

.top-bar{background:#f9f7f6;font-size:.85rem;} /* increased from .75rem */
.top-bar-inner{display:flex;justify-content:flex-end;align-items:center;min-height:var(--top-bar-h);gap:1.25rem;}
.top-bar a{color:var(--accent-alt);text-decoration:none;}
.top-bar a:hover,.top-bar a:focus-visible{text-decoration:underline;}
.top-email{margin:0;}
.top-phone{margin:0;margin-right:1.25rem;}
.primary-nav .divider{width:1px;background:var(--border);height:18px;align-self:center;}
.primary-nav li.divider{list-style:none;padding:0;margin:0 4px;}
.social-nav a{font-size:.85rem;font-weight:500;opacity:.85;} /* increased from .75rem */
.social-nav a:hover,.social-nav a:focus-visible{opacity:1;}

/* Icon-only social row (Nextdoor & Facebook) */
.top-bar .social-icons{display:flex;gap:.5rem;margin-left:auto;}
.top-bar .social-icons a{--icon-size:44px;width:var(--icon-size);height:var(--icon-size);display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:50%;background:#fff;color:var(--accent-alt);text-decoration:none;transition:background .25s,border-color .25s,color .25s,box-shadow .25s;position:relative;} /* increased from 28px */
.top-bar .social-icons a svg{width:20px;height:20px;display:block;fill:currentColor;} /* increased from 16px */
.top-bar .social-icons a:hover,
.top-bar .social-icons a:focus-visible{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 4px rgba(0,0,0,.12);}
.top-bar .social-icons a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
/* Brand accent hovers (optional) */
.top-bar .social-icons a.nextdoor:hover,
.top-bar .social-icons a.nextdoor:focus-visible{background:#00b246;border-color:#00b246;}
.top-bar .social-icons a.facebook:hover,
.top-bar .social-icons a.facebook:focus-visible{background:#1877f2;border-color:#1877f2;}
@media (max-width:640px){
  .top-bar .social-icons{order:3;}
}

/* Hide select top-bar contact items on narrow screens */
@media (max-width:680px){
  .top-facebook,
  .top-phone,
  .top-email{display:none;}
}

/* Screen-reader only utility (for hidden descriptive text if needed) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}

/* Utilities */
.inline-link{color:var(--accent-alt);text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:1px;transition:color .25s,border-color .25s;}
.inline-link:hover,.inline-link:focus-visible{color:var(--accent);border-bottom-color:var(--accent);} 
.cta-group{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:.5rem;}

/* Full-bleed image banners (converted to interstitial card style) */
.image-banner{--banner-min-h:200px;--banner-max-h:360px;position:relative;max-width:var(--wrapper);margin:clamp(2rem,6vw,3rem) auto;/* center within layout */padding:0 var(--space);}
.image-banner img{display:block;width:100%;height:clamp(var(--banner-min-h),32vw,var(--banner-max-h));object-fit:cover;object-position:center;border-radius:var(--radius);box-shadow:var(--shadow);filter:brightness(.94) saturate(1.05);transition:filter .5s,transform 1.4s ease;}
.image-banner:hover img,.image-banner:focus-within img{filter:brightness(.98) saturate(1.1);transform:scale(1.015);} 

/* Optional subtle overlay variant (not used yet) */
.image-banner.tinted::after{content:"";position:absolute;inset:0;border-radius:var(--radius);background:linear-gradient(to bottom,rgba(255,255,255,.35),rgba(0,0,0,.25));mix-blend-mode:multiply;pointer-events:none;}

/* Reduce motion preference */
@media (prefers-reduced-motion:reduce){
  .image-banner img{transition:none;}
}

/* Typography: body = Atkinson Hyperlegible; headings = Plus Jakarta Sans */
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:600;line-height:1.15;letter-spacing:-.25px;}
h1{letter-spacing:-.5px;}

/* Mobile navigation toggle */
.nav-toggle{display:none;background:none;border:0;padding:.75rem;cursor:pointer;line-height:1;align-self:center;position:relative;}
.nav-toggle-bar,.nav-toggle-bar::before,.nav-toggle-bar::after{width:24px;height:2px;background:var(--accent-alt);border-radius:2px;display:block;position:relative;transition:.25s;content:"";}
.nav-toggle-bar::before{position:absolute;top:-7px;left:0;}
.nav-toggle-bar::after{position:absolute;top:7px;left:0;}
.nav-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.nav-open .nav-toggle-bar{background:transparent;}
.nav-open .nav-toggle-bar::before{transform:translateY(7px) rotate(45deg);}
.nav-open .nav-toggle-bar::after{transform:translateY(-7px) rotate(-45deg);}

@media (max-width:680px){
  .nav-toggle{display:inline-flex;}
  .primary-nav{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.08);padding:.5rem 0;opacity:0;transform:translateY(-8px);pointer-events:none;transition:.25s;z-index:40;}
  .nav-open .primary-nav{opacity:1;transform:translateY(0);pointer-events:auto;}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:0;}
  .primary-nav li{width:100%;}
  .primary-nav a{width:100%;padding:.75rem 1rem;}
  .primary-nav a:focus-visible{background:rgba(11,108,79,.08);outline:none;}
}
