/* ============================================================
   CENTRAL PA JUNK REMOVAL — styles.css v3
   Fonts: Oswald 500/600/700 (headings) · DM Sans (body)
   Palette: --ink #0d0e10 · --paper #e8e2d9 · --cream #dfd8cc
            --green #15a348 · --green-deep #127a39
            --army #4a4e44
   Character: hard corners, grungy warmth, work-order aesthetic
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'DM Sans',sans-serif;
  background:#e8e2d9;
  color:#0d0e10;
  font-size:17px;
  line-height:1.65;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit}
input,select,textarea{font:inherit}

:root{
  /* palette */
  --ink:#0d0e10;
  --dark:#17181c;
  --black:#0a0b0d;
  --paper:#e8e2d9;
  --cream:#dfd8cc;
  --army:#4a4e44;
  --green:#15a348;
  --green-deep:#127a39;
  --green-light:#22c55e;
  --stripe:#15a348;
  --stripe-hot:#127a39;
  --stripe-deep:#0d5c2a;
  --body:#2a2d30;
  --muted:#A1A1AA;
  --muted-dark:#6B7178;
  --graphite:#1e2024;
  --charcoal:#2a2d32;
  --line:rgba(255,255,255,.08);
  /* type */
  --head:'Oswald',sans-serif;
  --body-font:'DM Sans',sans-serif;
  /* utils */
  --r:4px;
  --r-lg:6px;
  --trans:.22s ease;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow-sm:0 2px 8px rgba(0,0,0,.1);
  --shadow-green:0 8px 32px -8px rgba(21,163,72,.3);
}

/* ── Grain ────────────────────────────────────────────────── */
body.grain::before{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;opacity:.55;
  mix-blend-mode:multiply;
}

/* ── Typography ───────────────────────────────────────────── */
h1,h2,h3,h4,h5{
  font-family:var(--head);
  font-weight:700;
  line-height:1.08;
  letter-spacing:.01em;
  text-transform:uppercase;
}
h1{font-size:clamp(46px,6.5vw,86px);letter-spacing:-.01em}
h2{font-size:clamp(30px,4vw,52px)}
h3{font-size:clamp(20px,2.4vw,28px)}
h4{font-size:clamp(16px,1.8vw,20px)}
h5{font-size:13px;letter-spacing:.1em}
p{font-size:17px;line-height:1.7;color:inherit}
p.lead{font-size:18px;font-weight:500;line-height:1.65}

/* ── Layout ───────────────────────────────────────────────── */
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
.on-dark{color:#fff}
.on-dark p{color:rgba(255,255,255,.8)}
.center{text-align:center}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* ── Marquee ──────────────────────────────────────────────── */
.top-strip{
  background:var(--ink);color:var(--green);
  height:36px;overflow:hidden;
  border-bottom:1px solid rgba(21,163,72,.15);
  display:flex;align-items:center;
}
.top-strip .marquee{
  display:inline-block;
  padding-left:100%;
  animation:ts-scroll 55s linear infinite;
  white-space:nowrap;
}
.top-strip .marquee span{
  font-family:var(--head);font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;padding:0 18px;
}
.top-strip .marquee .dot{color:rgba(21,163,72,.4);padding:0 2px}
@keyframes ts-scroll{from{transform:translateX(0)}to{transform:translateX(-100%)}}

/* ── Header ───────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:200;
  background:#3d4139; /* army green-gray, not flat black */
  border-bottom:3px solid var(--green);
  height:60px;
}
.header-shell{
  max-width:1200px;margin:0 auto;padding:0 24px;
  height:100%;display:flex;align-items:center;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand-mark{
  width:34px;height:34px;border-radius:3px;
  background:var(--green);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.brand-mark svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round}
.brand strong{
  font-family:var(--head);font-size:21px;font-weight:700;
  color:#fff;text-transform:uppercase;letter-spacing:.03em;
}
.brand small{
  display:block;font-size:11px;font-weight:400;
  color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;
}
.main-nav{margin-left:auto;display:flex;align-items:center;gap:2px}
.main-nav a{
  font-family:var(--head);font-size:13px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.6);padding:7px 10px;border-radius:3px;
  transition:color var(--trans),background var(--trans);
}
.main-nav a:hover,.main-nav a.active{color:#fff;background:rgba(255,255,255,.08)}
.nav-quote{
  background:var(--green)!important;color:#fff!important;
  border-radius:3px;padding:7px 14px;margin-left:8px;
  font-weight:700!important;
}
.nav-quote:hover{background:var(--green-deep)!important}
.menu-button{
  display:none;
  background:var(--green);color:#fff;
  font-family:var(--head);font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:7px 14px;border-radius:3px;
}

/* ── Mobile Panel ─────────────────────────────────────────── */
.mobile-panel{
  display:none;position:fixed;inset:0;z-index:300;
  background:#3d4139;
  flex-direction:column;padding:0 0 32px;overflow-y:auto;
}
.mobile-panel.open{display:flex}
.mp-top{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;border-bottom:1px solid rgba(255,255,255,.1);
}
.mp-close{font-size:28px;color:#fff;line-height:1}
.mobile-panel a{
  font-family:var(--head);font-size:20px;font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;color:#fff;
  padding:15px 24px;border-bottom:1px solid rgba(255,255,255,.06);
}
.mobile-panel a:hover{color:var(--green)}

/* ── Breadcrumb ───────────────────────────────────────────── */
.crumb{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;
  font-size:12px;color:rgba(13,14,16,.45);padding:12px 0;
  font-family:var(--head);letter-spacing:.05em;text-transform:uppercase;
}
.crumb a{color:rgba(13,14,16,.45);transition:color var(--trans)}
.crumb a:hover{color:var(--ink)}
.crumb .sep{color:rgba(13,14,16,.25)}

/* ── Kicker ───────────────────────────────────────────────── */
.kicker{
  display:inline-flex;align-items:center;
  font-family:var(--head);font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--green);margin-bottom:6px;
  border-left:3px solid var(--green);padding-left:10px;
  line-height:1.4;
}

/* ── Sections ─────────────────────────────────────────────── */
.sec{padding:80px 0}
.sec-head{margin-bottom:40px}
.sec-head h2{margin-top:10px}
.sec-head p{margin-top:12px;max-width:640px;font-size:17px;opacity:.75}
.sec-head.center p{margin-left:auto;margin-right:auto}
.sec-paper{background:var(--paper)}
.sec-cream{background:var(--cream)}
.sec-dark{background:var(--dark);color:#fff}
.sec-dark p{color:rgba(255,255,255,.75)}
.sec-black{background:var(--black);color:#fff}
.sec-black p{color:rgba(255,255,255,.75)}
.sec-army{background:var(--army);color:#fff}
.sec-army p{color:rgba(255,255,255,.8)}

/* ── Hero ─────────────────────────────────────────────────── */
.hero{
  background:var(--ink);
  position:relative;overflow:hidden;isolation:isolate;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(6,8,8,.62) 0%,rgba(6,8,8,.80) 100%);
  pointer-events:none;
}
.hero-bg-res{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  animation:kb 22s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes kb{
  0%  {transform:scale(1)    translateX(0%);  background-position:62% center}
  50% {transform:scale(1.04) translateX(-1%); background-position:50% center}
  100%{transform:scale(1.08) translateX(-2%); background-position:38% center}
}
/* Mobile: only cover top portion */
@media(max-width:1024px){
  .hero-bg-res{
    bottom:auto;height:60%;
    -webkit-mask-image:linear-gradient(to bottom,black 0%,black 65%,transparent 100%);
    mask-image:linear-gradient(to bottom,black 0%,black 65%,transparent 100%);
    animation:kb-m 22s ease-in-out infinite alternate;
  }
  @keyframes kb-m{0%{background-position:60% 20%}100%{background-position:42% 20%}}
}
@media(max-width:760px){
  .hero-bg-res{
    height:56%;
    -webkit-mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 100%);
    mask-image:linear-gradient(to bottom,black 0%,black 60%,transparent 100%);
  }
}
/* Hero shell variants */
.hero-one-col{
  position:relative;z-index:2;
  padding:84px 0 92px;max-width:680px;
}
.hero-two-col{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr .85fr;
  gap:54px;align-items:center;
  padding:80px 0 88px;
}
.hero h1{color:#fff;margin-top:10px}
.hero h1 .y{color:var(--green)}
.hero-eyebrow{margin-bottom:20px}
.hero-sub{
  font-size:17px;color:rgba(255,255,255,.75);
  margin-top:14px;max-width:540px;line-height:1.65;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
@media(max-width:1024px){
  .hero-two-col{
    grid-template-columns:1fr;gap:32px;padding:56px 0 60px;
  }
  .hero-two-col .quick-form{max-width:480px}
}
@media(max-width:760px){
  .hero-one-col{padding:52px 0 60px}
  .hero-two-col{padding:44px 0 52px}
}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--head);font-size:14px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:12px 22px;border-radius:3px;
  border:2px solid transparent;
  transition:background var(--trans),color var(--trans),filter .15s,transform .12s;
  cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-deep)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#222}
.btn.full{width:100%;justify-content:center}
.btn-arrow{transition:transform .18s ease}
.btn:hover .btn-arrow{transform:translateX(3px)}
.hero-alt-link{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--head);font-size:13px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  color:rgba(255,255,255,.45);transition:color .2s;
}
.hero-alt-link:hover{color:rgba(255,255,255,.85)}

/* ── Quick Form ───────────────────────────────────────────── */
.quick-form{
  background:rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.12);
  border-top:3px solid var(--green);
  border-radius:4px;
  padding:24px 22px;
  position:relative;
  backdrop-filter:blur(8px);
}
.quick-form h3{
  font-family:var(--head);font-size:22px;font-weight:700;
  text-transform:uppercase;color:#fff;margin-bottom:4px;letter-spacing:.04em;
}
.quick-form .qf-sub{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:16px}
.quick-form .field label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.quick-form .field input{
  background:rgba(255,255,255,.07);
  border:1.5px solid rgba(255,255,255,.1);
  color:#fff;border-radius:3px;padding:10px 12px;font-size:15px;width:100%;
  transition:border-color var(--trans);
}
.quick-form .field input:focus{outline:none;border-color:var(--green)}
.quick-form .field input::placeholder{color:rgba(255,255,255,.28)}

/* ── Forms ────────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.field input,.field select,.field textarea{
  padding:11px 13px;border-radius:3px;
  border:1.5px solid rgba(13,14,16,.15);
  background:#fff;font-size:15px;color:var(--ink);
  transition:border-color var(--trans),box-shadow var(--trans);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(21,163,72,.12);
}
.field-help{font-size:12px;color:rgba(13,14,16,.4);margin-top:4px;line-height:1.5}
.bigform-wrap{
  background:linear-gradient(145deg,rgba(21,163,72,.08) 0%,rgba(18,122,57,.12) 100%);
  border-top:4px solid var(--green);
  border-radius:4px;padding:32px 28px;
}
.bigform-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bigform-grid .field label{color:rgba(255,255,255,.7)}
.bigform-grid .field input,
.bigform-grid .field select,
.bigform-grid .field textarea{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.12);color:#fff;border-radius:3px;
}
.bigform-grid .field input::placeholder,
.bigform-grid .field textarea::placeholder{color:rgba(255,255,255,.28)}
.bigform-grid .field select option{background:var(--black);color:#fff}
.bigform-grid .field input:focus,
.bigform-grid .field select:focus,
.bigform-grid .field textarea:focus{
  border-color:var(--green);box-shadow:0 0 0 3px rgba(21,163,72,.15);outline:none;
}
@media(max-width:760px){.bigform-grid{grid-template-columns:1fr}.bigform-wrap{padding:22px 16px}}

/* ── Split ────────────────────────────────────────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-body{display:flex;flex-direction:column;gap:18px}
.split-body p{font-size:17px;color:var(--muted-dark);margin-bottom:14px}
.local-body{max-width:760px}
.local-body p,.local-body p.lead,.local-body .lead{
  font-size:17px!important;color:var(--body)!important;
  font-weight:400!important;line-height:1.72!important;margin-bottom:18px!important;
}
.on-dark .local-body p,.on-dark .local-body .lead{color:rgba(255,255,255,.82)!important}
.sec-army .local-body p,.sec-army .local-body .lead{color:rgba(255,255,255,.82)!important}
.split-media{position:relative}
.sm-img{
  width:100%;aspect-ratio:4/3;border-radius:4px;
  background-size:cover;background-position:center;
  box-shadow:0 20px 60px rgba(0,0,0,.3);
}
.sm-badge{
  position:absolute;left:20px;bottom:20px;
  background:var(--green);color:#fff;
  font-family:var(--head);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  padding:7px 14px;border-radius:0;
  box-shadow:0 4px 14px rgba(21,163,72,.3);
}
@media(max-width:1024px){.split{grid-template-columns:1fr;gap:36px}.split-media{order:-1}}

/* ── Split list ───────────────────────────────────────────── */
.split-list{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:8px}
.split-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:16px;color:inherit;padding:11px 14px;
  background:rgba(255,255,255,.05);
  border-left:3px solid var(--green);
}
.split-list li::before{
  content:'';width:18px;height:18px;flex-shrink:0;margin-top:1px;border-radius:50%;
  background-color:rgba(21,163,72,.2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2315a348' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}
.sec-army .split-list li,.sec-dark .split-list li{color:rgba(255,255,255,.88)}
.sec-army .split-list li::before,.sec-dark .split-list li::before{
  background-color:rgba(21,163,72,.25);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2322c55e' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
}

/* ── Service / Process Cards (01 02 03 04) ────────────────── */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.svc-card{
  position:relative;overflow:hidden;
  border-radius:4px;
  background:var(--dark);
  padding:36px 28px 28px;
  border:none;
  border-top:3px solid var(--green);
  display:flex;flex-direction:column;gap:8px;
  transition:transform var(--trans),box-shadow var(--trans);
  text-decoration:none;
  isolation:isolate; /* ensures z-index stacking works */
}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 18px 44px rgba(0,0,0,.35)}
.svc-bg{
  position:absolute;inset:0;
  z-index:0;
  background-size:cover;background-position:center;
  opacity:.18; /* visible but doesn't fight text */
  transition:opacity .4s ease;
}
.svc-card:hover .svc-bg{opacity:.28}
.svc-num{
  position:relative;z-index:1;
  font-family:var(--head);font-size:52px;font-weight:700;
  color:var(--green);opacity:.5;line-height:1;
}
.svc-card h3{
  position:relative;z-index:1;
  color:#fff;font-size:22px;margin:0;font-weight:700;
}
.svc-card p{
  position:relative;z-index:1;
  color:rgba(255,255,255,.68);font-size:15px;
}
.svc-link{
  position:relative;z-index:1;
  font-family:var(--head);font-size:12px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--green);margin-top:6px;
}
@media(max-width:760px){.svc-grid{grid-template-columns:1fr}}

/* ── County Cards ─────────────────────────────────────────── */
.county-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.county-card{
  position:relative;
  background:var(--dark);
  border-radius:4px;
  padding:18px 20px 16px;
  text-decoration:none;
  display:flex;flex-direction:column;gap:4px;
  overflow:hidden;
  border:none;
  border-top:3px solid rgba(21,163,72,.35);
  transition:transform var(--trans),border-top-color var(--trans);
}
.county-card:hover{transform:translateY(-2px);border-top-color:var(--green)}
.county-num{
  font-family:var(--head);font-size:24px;font-weight:700;
  color:var(--green);opacity:.35;line-height:1;margin-bottom:2px;
}
.county-card h3{color:#fff;font-size:17px;font-weight:700;font-family:var(--head);letter-spacing:.03em}
.county-card p{color:rgba(255,255,255,.4);font-size:12px;line-height:1.4}
.county-card span{font-family:var(--head);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--green);margin-top:6px;display:block}
/* Always 2 cols on mobile */
@media(max-width:760px){.county-grid{grid-template-columns:1fr 1fr;gap:8px}}
@media(max-width:360px){.county-grid{grid-template-columns:1fr}}

/* ── Haul cards ───────────────────────────────────────────── */
.haul-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px}
.haul-card{border-radius:4px;padding:28px 24px}
.haul-card.yes{background:rgba(21,163,72,.07);border:1px solid rgba(21,163,72,.2)}
.haul-card.no{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.15)}
.haul-card h3{font-size:19px;margin-bottom:14px;font-family:var(--head);letter-spacing:.04em}
.haul-card.yes h3{color:var(--green)}
.haul-card.no h3{color:#ef4444}
.haul-list{list-style:none;display:flex;flex-direction:column;gap:7px}
.haul-list li{
  font-size:14px;color:var(--body);
  display:flex;align-items:flex-start;gap:9px;line-height:1.45;
}
.haul-list li::before{
  content:'';width:16px;height:16px;flex-shrink:0;margin-top:1px;
  border-radius:50%;background-repeat:no-repeat;background-position:center;background-size:10px;
}
.haul-card.yes .haul-list li::before{
  background-color:rgba(21,163,72,.12);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2315a348' stroke-width='3'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
}
.haul-card.no .haul-list li::before{
  background-color:rgba(239,68,68,.1);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='3'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E");
}
@media(max-width:760px){.haul-grid{grid-template-columns:1fr}}

/* ── Town cols ────────────────────────────────────────────── */
.town-cols{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.town-cols a{
  font-family:var(--head);font-size:14px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.65);
  border:1px solid rgba(255,255,255,.1);
  border-radius:3px;padding:7px 14px;
  transition:color var(--trans),border-color var(--trans),background var(--trans);
}
.town-cols a:hover{color:#fff;border-color:var(--green);background:rgba(21,163,72,.08)}

/* ── Process strip ────────────────────────────────────────── */
.process-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:8px}
.process-img{
  aspect-ratio:4/3;border-radius:4px;
  background-size:cover;background-position:center;
  background-color:var(--graphite);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease);
}
.process-img:hover{transform:translateY(-2px)}
.process-img.wide{grid-column:span 2;aspect-ratio:16/9}
@media(max-width:900px){.process-strip{grid-template-columns:1fr 1fr}.process-img.wide{grid-column:1/-1}}
@media(max-width:600px){.process-strip{grid-template-columns:1fr}.process-img.wide{aspect-ratio:4/3;grid-column:auto}}

/* ── Image strip (homepage) ───────────────────────────────── */
.img-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:8px}
.img-strip-item{
  aspect-ratio:4/3;border-radius:4px;
  background-size:cover;background-position:center;
  box-shadow:0 4px 18px rgba(0,0,0,.2);
  transition:transform .3s var(--ease);
}
.img-strip-item:hover{transform:translateY(-2px)}
@media(max-width:760px){.img-strip{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.img-strip{grid-template-columns:1fr}}

/* ── FAQ ──────────────────────────────────────────────────── */
.faq{display:flex;flex-direction:column;gap:2px;max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(13,14,16,.1)}
.sec-dark .faq-item,.sec-black .faq-item{border-color:rgba(255,255,255,.1)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;
  font-family:var(--head);font-size:18px;font-weight:600;text-align:left;
  text-transform:uppercase;letter-spacing:.02em;padding:16px 0;color:inherit;
  transition:color var(--trans);
}
.faq-q:hover{color:var(--green)}
.fq-ic{font-size:22px;font-weight:400;flex-shrink:0;transition:transform var(--trans)}
.faq-item.open .fq-ic{transform:rotate(45deg)}
.faq-a{display:none;padding-bottom:14px;overflow:hidden}
.faq-item.open .faq-a{display:block}
.faq-a p{font-size:16px;opacity:.72}

/* ── Sticky bars ──────────────────────────────────────────── */
.sticky-cta{position:fixed;bottom:20px;right:20px;z-index:150;display:none}
@media(max-width:640px){body.has-local-sticky .sticky-cta{display:block}}
.local-sticky{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:150;
  background:var(--green);
  padding:13px 24px;align-items:center;justify-content:space-between;
  gap:20px;box-shadow:0 -4px 20px rgba(0,0,0,.25);
  border-top:2px solid var(--green-deep);
}
body.has-local-sticky .local-sticky{display:flex}
.local-sticky-text{
  font-family:var(--head);font-size:16px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;color:#fff;
}
.local-sticky-text span{
  opacity:.75;font-weight:400;margin-left:8px;
  letter-spacing:0;font-family:var(--body-font);font-size:14px;text-transform:none;
}
.local-sticky .btn-dark{flex-shrink:0;padding:10px 22px;font-size:14px}
@media(max-width:760px){.local-sticky{display:none!important}}

/* ── Footer ───────────────────────────────────────────────── */
.site-footer{background:var(--ink);color:rgba(255,255,255,.55);padding:60px 0 28px}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-brand strong{
  font-family:var(--head);font-size:20px;font-weight:700;
  color:#fff;text-transform:uppercase;display:block;margin-bottom:10px;
  letter-spacing:.03em;
}
.footer-brand p{font-size:14px;line-height:1.6;color:rgba(255,255,255,.45)}
.site-footer h5{
  font-family:var(--head);font-size:11px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:12px;
}
.site-footer a{display:block;font-size:14px;color:rgba(255,255,255,.5);margin-bottom:7px;transition:color var(--trans)}
.site-footer a:hover{color:var(--green)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:8px;padding-top:20px;
  font-size:12px;color:rgba(255,255,255,.28);
}
.footer-bottom a{display:inline;margin:0;color:rgba(255,255,255,.35)}
.footer-bottom a:hover{color:var(--green)}
.footer-disclaimer{font-size:12px;color:rgba(255,255,255,.18);line-height:1.6;margin-top:20px;max-width:820px}
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:760px){
  .sec{padding:56px 0}
  .main-nav{display:none}
  .menu-button{display:block}
  .footer-grid{grid-template-columns:1fr}
}
