
:root{
  --green:#0f5f35;
  --green-dark:#0c4d2c;
  --cream:#f4f1ec;
  --text:#11382c;
  --orange:#df5a1d;
  --orange-dark:#c24712;
  --yellow:#e1a72f;
  --line:#d8d6cf;
  --shadow:0 12px 30px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--text);
  background:#f7f5f1;
  line-height:1.45;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1180px, calc(100% - 40px)); margin:0 auto}
.top-strip{
  background:#114a2f;color:#fff;font-size:12px;font-weight:700;text-align:center;padding:6px 14px
}
.top-strip a{color:#fff;text-decoration:underline}
.site-header{
  background:linear-gradient(180deg,#0c6436,#0e5b33);
  color:#fff;
  padding:16px 26px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:22px;
  align-items:center;
}
.brand{display:flex;align-items:center;gap:12px;font-weight:800}
.brand-mark{
  width:36px;height:36px;border:3px solid #f3f0e9;border-radius:10px;display:inline-block
}
.brand-text{font-size:16px;line-height:1.05}
.header-call{justify-self:center;font-size:14px;font-weight:800}
.header-call a{color:#fff;text-decoration:underline}
.main-nav{display:flex;gap:24px;flex-wrap:wrap}
.main-nav a{font-weight:700;font-size:14px}
.hero{
  position:relative;
  background:url('../images/hero.jpg') center/cover no-repeat;
  min-height:520px;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(5,25,15,.58) 0%, rgba(5,25,15,.40) 33%, rgba(5,25,15,.12) 64%, rgba(5,25,15,.08) 100%);
}
.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns:1.08fr 360px;
  gap:36px;
  align-items:start;
  padding:56px 0 64px;
}
.hero-copy{color:#fff;max-width:600px;padding-top:12px}
.hero-copy h1{
  font-size:64px;line-height:.98;margin:0 0 16px;font-weight:900;letter-spacing:-1.5px;
  text-shadow:0 4px 18px rgba(0,0,0,.35);
}
.hero-sub{font-size:18px;font-weight:700;margin:0 0 18px}
.checklist{list-style:none;padding:0;margin:22px 0 24px}
.checklist li{position:relative;padding-left:34px;margin:10px 0;font-size:18px;font-weight:800}
.checklist li:before{
  content:"✓";position:absolute;left:0;top:-1px;color:#fff;font-size:28px;font-weight:900
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:52px;padding:14px 26px;border-radius:8px;
  font-weight:900;box-shadow:var(--shadow)
}
.btn-orange{background:linear-gradient(180deg,var(--orange),var(--orange-dark));color:#fff}
.btn-yellow{background:linear-gradient(180deg,#f0bc46,#d8951e);color:#23351f}
.btn.full{width:100%;border:none;cursor:pointer;font-size:18px}
.quote-card{
  background:#f3efe9;border-radius:10px;padding:24px 22px;box-shadow:0 10px 24px rgba(0,0,0,.24);
  margin-top:18px;border:1px solid rgba(0,0,0,.08)
}
.quote-card h2{margin:0 0 18px;color:#b33e18;font-size:22px;line-height:1.1}
.quote-card input,.quote-card textarea{
  width:100%;border:1px solid #d7d2cb;border-radius:6px;background:#fff;
  padding:14px 14px;font-size:17px;margin-bottom:14px;font-family:inherit
}
.quote-card textarea{min-height:86px;resize:vertical}
.section{padding:52px 0}
.alt{background:linear-gradient(180deg,#f8f6f2,#f2efea)}
.section-title{
  text-align:center;font-size:30px;margin:0 0 28px;color:#0f5b34;font-weight:900
}
.section-title.lines{
  display:flex;align-items:center;gap:18px;justify-content:center
}
.section-title.lines:before,.section-title.lines:after{
  content:"";height:1px;background:var(--line);width:min(32vw,360px)
}
.service-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px
}
.service-card{
  background:#fff;border-radius:14px;padding:12px;box-shadow:var(--shadow);border:1px solid #ece7de
}
.service-card img{
  width:100%;aspect-ratio:1.58/1;object-fit:cover;border-radius:10px
}
.service-card h3{
  text-align:center;font-size:22px;margin:14px 0 8px;color:#16382d
}
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center
}
.benefit{margin-bottom:28px}
.benefit h3{
  font-size:28px;color:#0f5b34;margin:0 0 8px;position:relative;padding-left:42px
}
.benefit h3:before{
  content:"";position:absolute;left:0;top:16px;width:24px;height:4px;background:#74a97c;border-radius:4px
}
.benefit p{font-size:17px;margin:0;color:#243d36;max-width:520px}
.why-image-wrap{
  background:#fff;padding:12px;border-radius:14px;box-shadow:var(--shadow);border:1px solid #ece7de
}
.why-image-wrap img{border-radius:10px;width:100%;aspect-ratio:1.1/1;object-fit:cover}
.areas-list{display:flex;flex-wrap:wrap;gap:10px 12px;margin-top:14px}
.tag{
  background:#e6ece3;border:1px solid #d4ded0;color:#214434;padding:12px 16px;border-radius:12px;
  font-size:16px;font-weight:700
}
.center{text-align:center}
.narrow{max-width:820px}
.cta-lite{padding-bottom:24px}
.cta-lite h2{font-size:30px;margin:0 0 8px;color:#0f5b34}
.cta-lite p{font-size:17px;margin:0;color:#2c4139}
.cta-band{
  background:linear-gradient(180deg,#0f6738,#0d5d34);
  color:#fff;padding:28px 0
}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.phone-big{font-size:42px;line-height:1;font-weight:900;color:#f5c24d}
.site-footer{
  background:#f8f6f3;padding:22px 0;color:#666;font-size:14px;border-top:1px solid #ece8e1
}
.footer-inner{display:flex;justify-content:space-between;gap:20px;align-items:center}
.page-hero{
  background:linear-gradient(rgba(8,29,18,.55), rgba(8,29,18,.55)), url('../images/hero.jpg') center/cover no-repeat;
  color:#fff;padding:78px 0 58px
}
.page-hero h1{font-size:52px;line-height:1.02;margin:0 0 14px;font-weight:900}
.page-hero p{font-size:18px;font-weight:700;max-width:720px;margin:0 0 20px}
.breadcrumbs{font-size:13px;margin-bottom:12px;opacity:.9}
.two-col{
  display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:start
}
.content-card,.aside-card{
  background:#fff;border-radius:14px;padding:28px;box-shadow:var(--shadow);border:1px solid #ece7de
}
.content-card h2,.aside-card h2{color:#0f5b34;font-size:30px;margin:0 0 14px}
.content-card h3,.aside-card h3{color:#0f5b34;font-size:22px;margin:22px 0 10px}
.content-card p,.aside-card p{font-size:17px;color:#263d36}
.bullets{padding-left:20px}
.bullets li{margin:10px 0;font-size:17px}
.faq-item{border-top:1px solid #e7e1d7;padding:16px 0}
.faq-item:first-child{border-top:none}
.inline-form input,.inline-form textarea{width:100%;padding:14px;border:1px solid #d7d2cb;border-radius:6px;margin-bottom:12px;font-size:16px;font-family:inherit}
.inline-form textarea{min-height:120px}
@media (max-width: 1100px){
  .hero-grid{grid-template-columns:1fr 340px}
  .hero-copy h1{font-size:56px}
  .site-header{grid-template-columns:auto 1fr;row-gap:12px}
  .main-nav{grid-column:1/-1}
}
@media (max-width: 820px){
  .site-header{display:flex;flex-direction:column;align-items:flex-start}
  .header-call{justify-self:start}
  .hero-grid,.why-grid,.two-col,.cta-band-inner{grid-template-columns:1fr;display:grid}
  .hero-grid{padding-top:34px}
  .hero-copy h1{font-size:42px}
  .service-cards{grid-template-columns:1fr}
  .quote-card{max-width:480px}
  .phone-big{font-size:40px}
  .section-title.lines:before,.section-title.lines:after{width:16vw}
}


.hero::before{
content:'';
position:absolute;
top:0;left:0;right:0;bottom:0;
background:rgba(0,0,0,0.55);
z-index:0;
}
.hero-grid{position:relative;z-index:2;}


/* Locked homepage upgrades under the approved hero */
.haul-section{background:#f6f3ee}
.haul-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.haul-card{
  background:#fff;
  border-radius:20px;
  padding:18px 18px 24px;
  box-shadow:0 12px 30px rgba(0,0,0,.10);
  border:1px solid #ece5db;
}
.haul-card img{
  width:100%;
  aspect-ratio:1.45 / 1;
  object-fit:cover;
  border-radius:16px;
  margin-bottom:18px;
}
.haul-card h3{
  font-size:24px;
  color:#124b2f;
  margin:0 0 12px;
  text-align:center;
}
.haul-card p{
  font-size:17px;
  line-height:1.6;
  color:#33443b;
  margin:0 0 22px;
  min-height:82px;
}
.haul-btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:100%;
  min-height:56px;
  border-radius:12px;
  background:linear-gradient(180deg, #0f6a3a, #0a4d2a);
  color:#fff;
  font-weight:800;
  font-size:18px;
  box-shadow:var(--shadow);
}
.why-section .locked-why-grid{
  grid-template-columns:1.02fr .98fr;
  gap:34px;
  align-items:center;
}
.benefit-row{
  display:grid;
  grid-template-columns:72px 1fr;
  gap:20px;
  align-items:start;
  margin-bottom:28px;
}
.benefit-icon{
  width:62px;
  height:62px;
  border-radius:50%;
  background:#0f5b34;
  color:#fff;
  font-size:30px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
}
.benefit-text h3{
  font-size:28px;
  color:#0f5b34;
  margin:0 0 10px;
  padding-left:0;
}
.benefit-text h3:before{display:none}
.benefit-text p{
  margin:0;
  font-size:17px;
  line-height:1.65;
  color:#2f4038;
}
@media (max-width: 900px){
  .haul-cards{grid-template-columns:1fr}
  .why-section .locked-why-grid{grid-template-columns:1fr}
}

/* Junk Removal page upgrade */
.eyebrow{
  font-size:14px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin:0 0 10px;
  color:#d8eadc;
}
.page-hero-grid{
  display:grid;
  grid-template-columns:1.05fr 380px;
  gap:34px;
  align-items:start;
}
.page-hero-copy{
  max-width:760px;
}
.page-hero-copy h1{
  font-size:58px;
  line-height:1.02;
  margin:0 0 14px;
}
.page-hero-sub{
  font-size:20px;
  line-height:1.5;
  font-weight:700;
  max-width:760px;
  margin:0 0 22px;
}
.service-checks{
  list-style:none;
  margin:0 0 24px;
  padding:0;
}
.service-checks li{
  position:relative;
  padding-left:32px;
  margin:10px 0;
  font-size:18px;
  font-weight:800;
}
.service-checks li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:-1px;
  font-size:24px;
  font-weight:900;
}
.page-quote-card{
  background:#f3efe9;
  border-radius:14px;
  padding:26px 24px;
  box-shadow:0 10px 24px rgba(0,0,0,.24);
  border:1px solid rgba(0,0,0,.08);
}
.page-quote-card h2{
  margin:0 0 12px;
  color:#b33e18;
  font-size:24px;
}
.page-quote-card p{
  margin:0 0 16px;
  font-size:17px;
  color:#29413b;
}
.quick-trust-band{
  padding-top:22px;
  padding-bottom:10px;
}
.quick-trust-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.mini-trust{
  background:#fff;
  border:1px solid #ece7de;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:18px 20px;
  font-size:16px;
  font-weight:800;
  text-align:center;
  color:#184233;
}
.soft-bg{
  background:linear-gradient(180deg,#f8f6f2,#f2efea);
}
.split-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:28px;
  align-items:start;
}
.service-detail-grid,
.trust-grid,
.faq-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.service-detail-card,
.trust-card,
.faq-card,
.callout-box{
  background:#fff;
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
  border:1px solid #ece7de;
}
.service-detail-card h3,
.trust-card h3,
.faq-card h3,
.callout-box h3{
  font-size:24px;
  line-height:1.25;
  color:#124b2f;
  margin:0 0 12px;
}
.service-detail-card p,
.trust-card p,
.faq-card p,
.callout-box p{
  font-size:17px;
  line-height:1.65;
  color:#33443b;
  margin:0;
}
.left-pills{
  justify-content:flex-start;
  margin-top:18px;
}
.full-width-btn{
  width:100%;
  margin-top:14px;
}
.faq-card p{
  margin-top:10px;
}
@media (max-width: 980px){
  .page-hero-grid,
  .split-grid,
  .quick-trust-grid,
  .service-detail-grid,
  .trust-grid,
  .faq-grid{
    grid-template-columns:1fr;
  }
  .page-hero-copy h1{
    font-size:44px;
  }
}

/* Corrected homepage upgrades */
.micro-trust-strip{
  display:flex;
  flex-wrap:wrap;
  gap:10px 18px;
  margin-top:18px;
  color:#fff;
  font-size:14px;
  font-weight:800;
}
.section-kicker{
  margin:0 0 10px;
  font-size:17px;
  line-height:1.6;
  color:#425149;
}
.center-kicker{
  text-align:center;
  max-width:780px;
  margin-left:auto;
  margin-right:auto;
}
.content-slab{
  background:#fff;
  border-radius:18px;
  padding:28px;
  box-shadow:var(--shadow);
  border:1px solid #ece7de;
}
.two-col-simple{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:28px;
  align-items:start;
}
.simple-checks{
  margin:0;
  padding-left:20px;
}
.simple-checks li{
  margin:12px 0;
  font-size:17px;
  color:#243d36;
  font-weight:700;
}
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.review-card{
  background:#fff;
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
  border:1px solid #ece7de;
  text-align:left;
  min-height:180px;
}
.stars{
  font-size:22px;
  color:#d89a1b;
  margin-bottom:12px;
  letter-spacing:2px;
}
.review-card p{
  margin:0;
  font-size:17px;
  line-height:1.65;
  color:#2f4038;
}
.service-area-authority{
  margin:18px 0 0;
  font-size:16px;
  color:#2f4038;
  font-weight:700;
}
.internal-link-pills{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
}

/* Final service-card alignment fix */
.haul-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.haul-card-content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.haul-card h3 {
  line-height: 1.25;
  min-height: 92px;
}

.haul-card p {
  min-height: 112px;
}

.haul-card .haul-btn {
  margin-top: auto;
}

/* Keep the responsive homepage upgrades separate from the desktop alignment rules */
@media (max-width: 900px){
  .two-col-simple,
  .review-grid{
    grid-template-columns:1fr;
  }
  .micro-trust-strip{
    font-size:13px;
  }
  .haul-card h3,
  .haul-card p{
    min-height:auto;
  }
}
