/* Springfield Dumpster Rental Guys — shared styles */
:root{
  --ink:#17180F;
  --forest:#1E4A2C;
  --forest-2:#2C6138;
  --leaf:#4E9E44;
  --leaf-dark:#3C7E36;
  --paper:#F6F4EC;
  --paper-2:#EDEADD;
  --tint:#E7EFE2;
  --line:#DBD7C7;
  --white:#ffffff;
  --muted:#5C5F52;
  --shadow:0 10px 30px rgba(23,24,15,.10);
  --radius:14px;
  --wrap:1160px;
  --font-display:"Oswald",system-ui,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--forest-2);text-decoration:none}
a:hover{color:var(--leaf-dark)}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.05;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5.2vw,3.9rem);text-transform:uppercase;letter-spacing:.005em}
h2{font-size:clamp(1.7rem,3.6vw,2.7rem);text-transform:uppercase}
h3{font-size:1.25rem;text-transform:uppercase;letter-spacing:.01em}
p{margin:0 0 1rem}
.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.78rem;color:var(--forest-2);
  background:var(--tint);border:1px solid #CFE0C7;padding:.34em .8em;border-radius:2px;margin-bottom:1rem;
}
.eyebrow.on-dark{color:#CFE9C4;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2)}
.lead{font-size:1.14rem;color:#3B3D31}
.muted{color:var(--muted)}
.center{text-align:center}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);font-weight:600;
  text-transform:uppercase;letter-spacing:.03em;font-size:1rem;padding:.85em 1.5em;border-radius:8px;
  border:2px solid transparent;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s;
}
.btn-primary{background:var(--leaf);color:#fff;box-shadow:0 6px 18px rgba(78,158,68,.35)}
.btn-primary:hover{background:var(--leaf-dark);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--forest);border-color:var(--forest)}
.btn-ghost:hover{background:var(--forest);color:#fff}
.btn-ghost.on-dark{color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost.on-dark:hover{background:#fff;color:var(--forest)}

/* top utility bar */
.topbar{background:var(--ink);color:#D9DBCF;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 22px;flex-wrap:wrap}
.topbar strong{color:#fff;font-weight:600}
.topbar .tb-right{color:#B9E0AE}

/* header / nav */
.site-header{position:sticky;top:0;z-index:60;background:rgba(246,244,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 22px;max-width:var(--wrap);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);text-transform:uppercase;line-height:.95;color:var(--ink)}
.brand img{width:54px;height:54px;border-radius:50%;object-fit:cover}
.brand .bn{font-weight:700;font-size:1.02rem}
.brand .bn span{display:block;color:var(--forest-2)}
.menu{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
.menu>li{position:relative}
.menu>li>a{
  display:block;padding:12px 12px;font-family:var(--font-display);text-transform:uppercase;
  font-weight:500;letter-spacing:.03em;font-size:.92rem;color:var(--ink);border-radius:6px;
}
.menu>li>a:hover{background:var(--tint);color:var(--forest)}
.has-sub>a::after{content:"▾";margin-left:.35em;font-size:.7em;color:var(--muted)}
.submenu{
  position:absolute;top:100%;left:0;min-width:250px;background:#fff;border:1px solid var(--line);
  border-radius:10px;box-shadow:var(--shadow);padding:8px;list-style:none;margin:6px 0 0;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:.16s;z-index:70;
}
.has-sub:hover .submenu,.has-sub:focus-within .submenu{opacity:1;visibility:visible;transform:none}
.sub-toggle{display:none}
.submenu a{display:block;padding:9px 12px;border-radius:6px;font-size:.95rem;color:var(--ink)}
.submenu a:hover{background:var(--tint);color:var(--forest)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-phone{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--forest);white-space:nowrap}
.menu-toggle{display:none;background:none;border:2px solid var(--forest);color:var(--forest);border-radius:8px;padding:8px 10px;font-size:1.2rem;cursor:pointer}

/* hero */
.hero{position:relative;background:linear-gradient(160deg,#1E4A2C 0%,#173C22 60%,#122E1A 100%);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
   radial-gradient(circle at 82% 18%,rgba(78,158,68,.35),transparent 45%),
   repeating-linear-gradient(135deg,rgba(255,255,255,.03) 0 2px,transparent 2px 22px);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center;padding:72px 22px}
.hero h1{color:#fff}
.hero h1 em{font-style:normal;color:#9FD68F;display:block}
.hero p{color:#D7E4CF;font-size:1.15rem;max-width:52ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 22px}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px}
.hero-badges span{display:inline-flex;align-items:center;gap:.4em;font-size:.86rem;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:30px;padding:.4em .9em;color:#E4EFDD}
.hero-badges span::before{content:"✓";color:#9FD68F;font-weight:700}
.hero-art{position:relative}
.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:10px;box-shadow:var(--shadow)}
.hero-card img{border-radius:12px;width:100%;height:auto;display:block;aspect-ratio:3/4;object-fit:cover;object-position:center}
.call-chip{position:absolute;left:-14px;bottom:-14px;background:var(--leaf);color:#fff;border-radius:12px;padding:10px 16px;box-shadow:0 8px 22px rgba(0,0,0,.3);font-family:var(--font-display)}
.call-chip small{display:block;font-size:.7rem;letter-spacing:.14em;opacity:.9}
.call-chip b{font-size:1.25rem;letter-spacing:.02em}

/* trust strip */
.trust{background:var(--ink);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 34px;padding:16px 22px;text-align:center}
.trust span{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:.92rem;color:#CFE9C4}

/* sections */
section{padding:66px 0}
.section-head{max-width:720px;margin-bottom:34px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.bg-tint{background:var(--tint)}
.bg-paper2{background:var(--paper-2)}
.bg-forest{background:var(--forest);color:#fff}
.bg-forest h2,.bg-forest h3{color:#fff}
.bg-forest p{color:#D7E4CF}

/* feature grid */
.grid{display:grid;gap:22px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 2px 10px rgba(23,24,15,.04);transition:transform .14s,box-shadow .14s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card .ic{width:46px;height:46px;border-radius:10px;background:var(--tint);color:var(--forest);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:14px}
.card h3{margin-bottom:.4em}
.card p{margin:0;color:var(--muted);font-size:.98rem}
a.card{color:inherit;display:block}
a.card .more{display:inline-block;margin-top:12px;color:var(--forest-2);font-family:var(--font-display);text-transform:uppercase;font-size:.85rem;letter-spacing:.05em}

/* two-column media */
.media{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.media.rev{direction:rtl}.media.rev>*{direction:ltr}
.media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;object-position:center}

/* size cards */
.sizes{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.size{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center;transition:.14s;color:inherit;display:block}
.size:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--leaf)}
.size .yd{font-family:var(--font-display);font-weight:700;font-size:2.5rem;color:var(--forest);line-height:1}
.size .lb{font-family:var(--font-display);text-transform:uppercase;font-size:.72rem;letter-spacing:.12em;color:var(--muted)}
.size p{font-size:.86rem;color:var(--muted);margin:.5em 0 0;min-height:2.4em}
.size .more{font-family:var(--font-display);text-transform:uppercase;font-size:.78rem;color:var(--forest-2);letter-spacing:.05em;display:block;margin-top:10px}

/* steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.step{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px 26px}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:-18px;left:24px;font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#fff;background:var(--leaf);width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;box-shadow:0 6px 14px rgba(78,158,68,.4)}
.step h3{margin-top:10px}

/* areas */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chips a{background:#fff;border:1px solid var(--line);border-radius:30px;padding:.5em 1.1em;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-size:.86rem;color:var(--forest);transition:.14s}
.chips a:hover{background:var(--forest);color:#fff;border-color:var(--forest)}
.bg-forest .chips a{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25);color:#fff}
.bg-forest .chips a:hover{background:#fff;color:var(--forest)}

/* reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.stars{color:#E8A100;letter-spacing:.1em;margin-bottom:10px}
.review p{font-style:italic;color:#3B3D31}
.review .who{font-family:var(--font-display);text-transform:uppercase;font-size:.82rem;letter-spacing:.05em;color:var(--muted);font-style:normal}

/* faq */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;padding:18px 22px;font-family:var(--font-display);text-transform:uppercase;font-size:1.02rem;letter-spacing:.01em;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--leaf);font-size:1.4rem;font-family:var(--font-display)}
.faq details[open] summary::after{content:"–"}
.faq .a{padding:0 22px 18px;color:var(--muted)}

/* cta band */
.cta-band{background:linear-gradient(120deg,#1E4A2C,#2C6138);color:#fff;text-align:center;border-radius:20px;padding:50px 26px;box-shadow:var(--shadow)}
.cta-band h2{color:#fff}
.cta-band .phone{font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,5vw,3rem);color:#fff;display:inline-block;margin:.2em 0}

/* content article */
.article{max-width:780px;margin:0 auto}
.article h2{margin-top:1.6em}
.article h3{margin-top:1.4em}
.article ul,.article ol{padding-left:1.2em}
.article li{margin-bottom:.5em}
.callout{background:var(--tint);border-left:4px solid var(--leaf);border-radius:8px;padding:18px 20px;margin:1.4em 0}
.pricetable{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:.97rem}
.pricetable th,.pricetable td{border:1px solid var(--line);padding:11px 13px;text-align:left}
.pricetable th{background:var(--forest);color:#fff;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.03em;font-weight:600}
.pricetable tr:nth-child(even) td{background:#fff}

/* page hero (interior) */
.page-hero{background:linear-gradient(160deg,#1E4A2C,#163A21);color:#fff;padding:56px 0}
.page-hero h1{color:#fff;margin-bottom:.3em}
.page-hero p{color:#D7E4CF;max-width:60ch;margin:0}
.crumbs{font-size:.82rem;color:#9FD68F;margin-bottom:14px;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-display)}
.crumbs a{color:#9FD68F}

/* checklist */
.checks{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.checks li{position:relative;padding-left:34px;color:#3B3D31}
.checks li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:6px;background:var(--leaf);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/16px no-repeat}

/* footer */
.site-footer{background:var(--ink);color:#C9CBBE;padding:56px 0 26px;font-size:.94rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px}
.foot-brand img{width:64px;border-radius:50%;margin-bottom:12px}
.foot-brand p{color:#9FA093;line-height:1.7}
.site-footer h4{font-family:var(--font-display);text-transform:uppercase;color:#fff;font-size:.98rem;letter-spacing:.05em;margin:0 0 14px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:9px}
.site-footer a{color:#C9CBBE}
.site-footer a:hover{color:#9FD68F}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:36px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:#8A8C7F;font-size:.85rem}
.foot-bottom a{color:#8A8C7F}

/* mobile call bar */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;background:var(--leaf);color:#fff;text-align:center;padding:13px;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.05em;font-weight:600;box-shadow:0 -4px 16px rgba(0,0,0,.2)}
.callbar a{color:#fff}

/* responsive */
@media(max-width:960px){
  .hero .wrap{grid-template-columns:1fr;padding:52px 22px}
  .hero-art{order:-1;max-width:440px}
  .hero-card img{aspect-ratio:16/10}
  .media{grid-template-columns:1fr}.media.rev{direction:ltr}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .sizes{grid-template-columns:repeat(2,1fr)}
  .steps,.reviews{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .menu-toggle{display:block}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);padding:10px;gap:0;box-shadow:var(--shadow);
    max-height:calc(100vh - 74px);max-height:calc(100dvh - 74px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
  .menu.open{display:flex}
  .menu>li>a{padding:14px 10px}
  .has-sub{display:flex;flex-wrap:wrap;align-items:center}
  .has-sub>a{flex:1}
  .has-sub>a::after{display:none}
  .sub-toggle{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex:0 0 auto;background:none;border:none;border-left:1px solid var(--line);color:var(--forest);font-size:1.1rem;cursor:pointer;transition:transform .18s}
  .sub-toggle[aria-expanded="true"]{transform:rotate(180deg)}
  .submenu{display:none;flex-basis:100%;position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-left:2px solid var(--tint);border-radius:0;margin:0 0 6px 12px;padding:0}
  .has-sub.open .submenu{display:block}
  .submenu a{padding:11px 12px}
  .nav-phone{display:none}
  .g-2,.g-3,.g-4,.sizes{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .topbar .tb-right{display:none}
  .callbar{display:block}
  body{padding-bottom:52px}
  section{padding:48px 0}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}
body.nav-open{overflow:hidden}
:focus-visible{outline:3px solid var(--leaf);outline-offset:2px;border-radius:4px}
