/* =====================================================================
   Poop Scoop Dude - re-skin design system (shared)
   Dooty-Duty-quality look on PSD's own brand. Cascades across every page.
   Brand color is locked via body class: lead-red (red CTA, cyan accent).
   ===================================================================== */
:root{
  --cream:#f4f7fb; --cream-2:#e9f2f8; --cream-3:#dcebf4; --paper:#ffffff;
  --ink:#15293a; --ink-2:#2b3f51; --muted:#5a6b7c; --line:rgba(20,40,60,.10); --line-2:rgba(20,40,60,.16);
  --paw-tex:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='110' height='110' viewBox='0 0 512 512'%3E%3Cpath fill='%23ffffff' fill-opacity='0.05' d='M256 224c-79.4 0-192 122.8-192 200.3 0 34.9 26.8 55.7 71.7 55.7 48.9 0 81.1-25.1 120.3-25.1 39.5 0 71.9 25.1 120.3 25.1 44.9 0 71.7-20.9 71.7-55.7C448 346.8 335.4 224 256 224zM108.7 211.4c-10.4-34.7-42.4-57.1-71.6-50.1-29.1 7-44.3 40.7-33.9 75.3 10.4 34.7 42.4 57.1 71.6 50.1 29.1-6.9 44.3-40.7 33.9-75.3zm84.7-20.8c30.9-8.1 46.4-49.9 34.6-93.4S181.5 25.2 150.5 33.3s-46.4 49.9-34.6 93.4c11.9 43.4 46.6 72 77.5 63.9zm281.4-29.3c-29.1-7-61.2 15.5-71.6 50.1-10.4 34.7 4.8 68.4 33.9 75.3 29.1 7 61.2-15.5 71.6-50.1 10.4-34.6-4.8-68.4-33.9-75.3zm-156.3 49.3c30.9 8.1 65.6-20.5 77.5-63.9 11.8-43.4-3.7-85.2-34.6-93.4s-65.6 20.5-77.5 63.9c-11.8 43.5 3.7 85.3 34.6 93.4z'/%3E%3C/svg%3E");
  --font:"Nunito",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --display:"Baloo 2",system-ui,-apple-system,sans-serif;
  --r-sm:14px; --r-md:20px; --r-lg:28px; --r-xl:40px; --max:1340px;
  --pad:clamp(18px,4vw,34px); --gap:clamp(64px,8vw,108px);
  --sh-sm:0 2px 8px rgba(20,40,60,.06);
  --sh-md:0 14px 40px rgba(20,40,60,.10);
  --sh-lg:0 28px 70px rgba(20,40,60,.14);
}
body.lead-red{ --lead:#ed1c28; --lead-2:#cf1420; --lead-soft:#fde0e2; --lead-tint:#fef2f2; --accent:#1aa3bf; --lead-sh:rgba(237,28,40,.26); }
body.lead-cyan{ --lead:#1796b0; --lead-2:#11798f; --lead-soft:#d6f0f6; --lead-tint:#edf9fc; --accent:#ed1c28; --lead-sh:rgba(23,150,176,.30); }

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:1.02;margin:0;color:var(--ink);letter-spacing:-.02em}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.eyebrow{font-family:var(--font);font-weight:800;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--lead)}
/* brand-color highlight spans (EN uses .swap/.lead-accent, ES dictionary uses .accent/.grad) */
.lead-accent,.swap,.accent,.grad{color:var(--lead)}
.muted{color:var(--muted)}

/* line-icons */
.licon{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:block}
.ic-lg .licon{width:26px;height:26px}
.chip .ic .licon{width:17px;height:17px}
.bic{display:inline-block;width:18px;height:18px;vertical-align:-4px}
.zipbar-ic .licon{width:18px;height:18px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;font-family:var(--font);border-radius:999px;padding:.95rem 1.6rem;font-size:1.02rem;cursor:pointer;border:2px solid transparent;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease}
.btn-primary{background:var(--lead);color:#fff;box-shadow:0 12px 30px var(--lead-sh)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px var(--lead-sh)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--lead);color:var(--lead)}
.btn-lg{padding:1.1rem 1.9rem;font-size:1.08rem}
.btn:active{transform:translateY(0) scale(.98)}
.btn:focus-visible,.q button:focus-visible,a:focus-visible{outline:3px solid var(--lead);outline-offset:2px;border-radius:10px}
/* before/after action buttons: equal width + centered as a balanced pair on laptop (so they line up cleanly instead of bunching asymmetrically under the two-up image grid); stack full-width on mobile */
.ba-actions{align-items:stretch}
.ba-actions .btn{flex:1 1 240px;max-width:380px}

/* top strip (sticky so the locations + EN|ES toggle stay visible while scrolling, every page) */
.strip{background:var(--ink);color:#cfe1ee;font-size:.82rem;font-weight:500;position:sticky;top:0;z-index:60}
.strip .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;height:40px}
.strip a{color:#fff;font-weight:700}
.strip .s-r{display:flex;gap:1.1rem;align-items:center}
.lang-toggle{display:inline-flex;align-items:center;gap:.4rem;font-weight:700}
.lang-toggle a{color:#9fb8cb;padding:0 .1rem}
.lang-toggle a:hover{color:#fff}
.lang-toggle a.is-active,.lang-toggle a[aria-current="true"]{color:#fff;text-decoration:underline;text-underline-offset:3px}
.lang-sep{color:#46627a}
@media(max-width:720px){.strip .s-l{display:none}.strip .wrap{justify-content:center}}

/* nav (sticks directly under the 40px strip so both stay pinned) */
.nav{position:sticky;top:40px;z-index:50;background:rgba(244,247,251,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow .2s ease,border-color .2s ease}
.nav.scrolled{box-shadow:0 8px 28px rgba(20,40,60,.10);border-bottom-color:transparent}
.nav .wrap{display:flex;align-items:center;gap:1.2rem;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:800;font-size:1.18rem}
.brand img{width:50px;height:50px;object-fit:contain}
.nav-links{display:flex;gap:1.4rem;margin-left:auto;font-weight:600;font-size:.96rem;color:var(--ink-2);align-items:center}
.nav-links a{white-space:nowrap}
.nav-links a:hover{color:var(--lead)}
.nav-portal{font-weight:700}
.nav .cta{display:flex;gap:.7rem;align-items:center;margin-left:1.2rem;flex:0 0 auto}
.nav .cta .btn{white-space:nowrap}
.nav .phone{font-weight:800;color:var(--ink);white-space:nowrap}
@media(max-width:980px){.nav-links{display:none}.nav .cta .phone{display:none}}
/* Spanish labels run longer; tighten the nav and drop the redundant nav phone (already in the strip above) so the CTA button stays on one line and never overflows */
html[lang="es"] .nav-links{gap:1.02rem;font-size:.9rem}
html[lang="es"] .nav .cta{margin-left:.9rem}
html[lang="es"] .nav .phone{display:none}
/* Spanish nav labels are long; the wider 1340px container fits them on one line on real laptops/desktops, but collapse them below 1200px so they never wrap or overflow (English collapses at 980px) */
@media(max-width:1200px){html[lang="es"] .nav-links{display:none}}

/* hero */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 460px at 88% -8%, var(--lead-tint), transparent 60%),
  linear-gradient(180deg,var(--cream),var(--cream-2))}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:60px;background:var(--paper);
  -webkit-mask:radial-gradient(50px 60px at 50% 0,transparent 98%,#000) repeat-x;mask:radial-gradient(50px 60px at 50% 0,transparent 98%,#000) repeat-x;-webkit-mask-size:100px 60px;mask-size:100px 60px}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;padding-top:clamp(40px,5vw,68px);padding-bottom:clamp(64px,7vw,96px)}
.hero h1{font-size:clamp(2.9rem,6.8vw,5.1rem);font-weight:800}
.hero p.sub{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--ink-2);max-width:34ch;margin-top:1.1rem}
.hero .actions{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.7rem}
.trust{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:1.7rem}
.trust .tb{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:.45rem .9rem .45rem .5rem;font-weight:700;font-size:.84rem;color:var(--ink-2);box-shadow:var(--sh-sm)}
.trust .tb-ic{width:26px;height:26px;border-radius:8px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;flex:0 0 auto}
.trust .tb-ic .licon{width:15px;height:15px}
.trust .tb strong{color:var(--ink);font-weight:800}
.trust .stars{color:#f5a623;letter-spacing:1px}
.trust .dot{width:5px;height:5px;border-radius:50%;background:var(--line-2)}
.hero-art{position:relative}
.hero-photo{position:relative;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:4/5;background:#dfe9e0;border:7px solid #fff}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(20,40,60,.20));pointer-events:none}
.hero-badge{position:absolute;left:-14px;bottom:-14px;width:96px;height:96px;border-radius:50%;background:#fff;box-shadow:var(--sh-md);display:grid;place-items:center;border:4px solid var(--lead);z-index:3}
.hero-badge img{width:74px;height:74px;border-radius:50%;object-fit:cover}
.chip{position:absolute;z-index:3;background:#fff;border-radius:14px;box-shadow:var(--sh-md);padding:.6rem .8rem;display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.84rem}
.chip .ic{width:30px;height:30px;border-radius:9px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;flex:0 0 auto}
.chip.c1{top:14px;right:14px}
.chip.c2{top:46%;left:-22px}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr}.hero-art{order:-1;max-width:460px}.chip.c2{left:6px}}

/* stats */
.stats{background:var(--paper)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,2vw,24px);padding:clamp(30px,4vw,46px) var(--pad)}
.stat{text-align:center}
.stat b{display:block;font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,4vw,2.8rem);color:var(--lead);line-height:1;font-variant-numeric:tabular-nums}
.stat span{font-weight:600;color:var(--muted);font-size:.86rem;display:block;margin-top:.4rem}
@media(max-width:560px){.stats .wrap{grid-template-columns:repeat(2,1fr);gap:22px}}

/* section scaffolding */
.section{padding:var(--gap) 0}
.section.paper{background:var(--paper)}
.section.cream{background:var(--cream)}
.section.navy{background:#0e3a47;color:#fff;position:relative;overflow:hidden;background-image:var(--paw-tex);background-size:120px 120px}
.section.navy .head h2,.section.navy h4{color:#fff}
.section.navy .head p{color:rgba(255,255,255,.78)}
.section.navy .card{background:#1c5263;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 32px rgba(0,0,0,.3)}
.section.navy .card h4{color:#fff}
.section.navy .card p{color:rgba(255,255,255,.86)}
.section.navy .card:hover{box-shadow:0 20px 48px rgba(0,0,0,.42)}
.section.navy .ic-lg{background:var(--accent);color:#fff}
.head{max-width:640px;margin-bottom:clamp(34px,5vw,54px)}
.head.center{margin-left:auto;margin-right:auto;text-align:center}
.head h2{font-size:clamp(2.15rem,4.3vw,3.55rem);font-weight:800;margin-top:.5rem}
.head p{color:var(--muted);font-size:1.06rem;margin-top:.9rem}

/* feature cards */
.grid{display:grid;gap:clamp(14px,2vw,22px)}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:900px){.g4,.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.g4,.g3,.g2{grid-template-columns:1fr}}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(20px,2.4vw,28px);box-shadow:var(--sh-sm);transition:transform .15s ease,box-shadow .15s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.section.paper .card{background:var(--cream)}
.ic-lg{width:52px;height:52px;border-radius:15px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;margin-bottom:1rem}
.card h4{font-size:1.3rem;font-weight:800;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.96rem}
/* written SEO copy block (replaces a card grid with real, crawlable prose) */
.seo-copy{max-width:720px;margin:0 auto}
.seo-copy p{color:var(--ink-2);font-size:clamp(1.02rem,1.3vw,1.16rem);line-height:1.78;margin:0 0 1.1rem}
.seo-copy p:last-child{margin-bottom:0}
.seo-copy a{color:var(--lead);font-weight:700;text-decoration:none;border-bottom:2px solid var(--lead-soft);transition:color .15s ease,border-color .15s ease}
.seo-copy a:hover{color:var(--lead-2);border-bottom-color:var(--lead)}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,30px);position:relative}
.step{text-align:center;position:relative}
.step .num{width:64px;height:64px;border-radius:50%;background:var(--lead);color:#fff;font-family:var(--display);font-weight:800;font-size:1.5rem;display:grid;place-items:center;margin:0 auto 1.1rem;box-shadow:0 10px 24px var(--lead-sh);position:relative;z-index:2}
.steps::before{content:"";position:absolute;top:32px;left:16%;right:16%;height:3px;background:repeating-linear-gradient(90deg,var(--line-2) 0 10px,transparent 10px 20px);z-index:1}
.step h4{font-size:1.16rem;margin-bottom:.5rem}
.step p{color:var(--muted);font-size:.95rem;max-width:30ch;margin:0 auto}
.step-photo{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px;margin:0 0 1.15rem;box-shadow:0 12px 28px rgba(21,41,58,.14);display:block}
.steps:has(.step-photo)::before{display:none}
@media(max-width:600px){.steps{grid-template-columns:1fr}.steps::before{display:none}}

/* areas */
.area{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);padding:1.2rem 1.3rem;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease,border-color .15s;display:block}
.section.paper .area{background:var(--cream)}
.area:hover{transform:translateY(-8px);border-color:var(--lead);box-shadow:0 18px 36px rgba(20,40,60,.16)}
.area h4{font-size:1.12rem;font-weight:700;display:flex;align-items:center;gap:.5rem}
.area h4 .pin{color:var(--lead);display:inline-flex;align-items:center;flex:0 0 auto}
.area h4 .pin .licon{width:19px;height:19px}
.area h4 span{font-weight:700}
.area > span{color:var(--muted);font-size:.88rem;font-weight:600;display:block;margin-top:.35rem}

/* before/after */
.ba{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:0 0 0 5px #fff,var(--sh-md);aspect-ratio:4/3;user-select:none;touch-action:none;background:#222}
.ba-hover{cursor:ew-resize}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after-wrap{position:absolute;inset:0;width:50%;overflow:hidden}
.ba .after-wrap img{position:absolute;top:0;left:0;right:auto;height:100%;max-width:none;object-fit:cover}
.ba .lab{position:absolute;top:12px;padding:.3rem .7rem;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);backdrop-filter:blur(4px)}
.ba .lab.b{left:12px}.ba .lab.a{right:12px;background:var(--lead)}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);box-shadow:0 0 0 1px rgba(0,0,0,.1)}
.ba .knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;box-shadow:var(--sh-md);display:grid;place-items:center;color:var(--lead);font-weight:800;font-size:22px;cursor:ew-resize}
@keyframes baSweepW{0%,100%{width:50%}30%{width:78%}65%{width:22%}}
@keyframes baSweepL{0%,100%{left:50%}30%{left:78%}65%{left:22%}}
.ba.hint .after-wrap{animation:baSweepW 2.6s cubic-bezier(.4,0,.2,1)}
.ba.hint .handle,.ba.hint .knob{animation:baSweepL 2.6s cubic-bezier(.4,0,.2,1)}
@media(prefers-reduced-motion:reduce){.ba.hint .after-wrap,.ba.hint .handle,.ba.hint .knob{animation:none}}

/* reviews */
.rev{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;box-shadow:var(--sh-sm)}
.rev .stars{color:#f5a623;letter-spacing:1px;font-size:.95rem}
.rev p{margin:.7rem 0 1.1rem;color:var(--ink-2);font-size:.97rem}
.rev .who{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:.92rem}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;font-weight:800}
.review-card-wrap{margin-top:clamp(28px,3vw,44px);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(18px,2.4vw,30px);box-shadow:var(--sh-sm)}
#review-carousel{min-height:280px}
.gbar{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-top:clamp(28px,3vw,40px);font-weight:700;color:var(--ink-2);flex-wrap:wrap}
.gbar .score{font-family:var(--display);font-weight:800;font-size:1.4rem;color:var(--ink)}

/* faq */
.faq{max-width:780px;margin:0 auto}
.q{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:.8rem;overflow:hidden}
.section.cream .q{background:var(--paper)}
.q button{width:100%;text-align:left;background:none;border:0;padding:1.15rem 1.3rem;font-family:var(--display);font-weight:700;font-size:1.06rem;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.q button .pm{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;font-weight:800;transition:transform .2s}
.q.open button .pm{transform:rotate(45deg)}
.q .ans{max-height:0;overflow:hidden;transition:max-height .25s ease}
.q .ans p{padding:0 1.3rem 1.2rem;color:var(--muted);font-size:.97rem}
.q .ans a{color:var(--lead);font-weight:700}

/* section brand photo (tool-free imagery accents) */
.section-photo{display:block;width:100%;max-width:760px;margin:0 auto clamp(30px,4.5vw,50px);aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--sh-lg);border:6px solid #fff}
.section.navy .section-photo{border-color:rgba(255,255,255,.92)}

/* final cta */
.final{background:linear-gradient(rgba(14,58,71,.84),rgba(14,58,71,.9)),url(/assets/brand/cta-yard.jpg),var(--paw-tex);background-size:cover,cover,110px 110px;background-position:center,center,top left;color:#fff;text-align:center;position:relative;overflow:hidden}
.final-paw{display:flex;justify-content:center;margin-bottom:1rem}
.final .wrap{padding:clamp(54px,7vw,90px) var(--pad)}
.final h2{color:#fff;font-size:clamp(2.4rem,4.6vw,3.7rem);max-width:18ch;margin:0 auto}
.final p{color:rgba(255,255,255,.92);margin:1rem auto 1.9rem;max-width:46ch}
.final .btn-primary{background:#fff;color:var(--lead);box-shadow:0 14px 34px rgba(0,0,0,.2)}
.final .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.final .btn-ghost:hover{color:#fff;border-color:#fff}

/* footer */
.foot{background:var(--ink);color:#b6c6d4;font-size:.92rem}
.foot .wrap{padding:clamp(48px,6vw,72px) var(--pad) 28px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(22px,3vw,40px)}
.foot h5{font-family:var(--display);color:#fff;font-size:1rem;margin:0 0 .9rem}
.foot a{display:block;color:#c7d3dd;padding:.22rem 0}
.foot a:hover{color:#fff}
.foot .brand{color:#fff;margin-bottom:.7rem}
.foot .brand img{width:46px;height:46px}
.foot .legal{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.12);margin-top:18px;padding-top:18px;color:#8fa1ad;font-size:.82rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
@media(max-width:760px){.foot .wrap{grid-template-columns:1fr 1fr}}

/* sticky mobile CTA bar (4-up: Call / Text / Ask / Free Quote) */
.mcta{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:.5rem;padding:.55rem .7rem calc(.55rem + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -8px 24px rgba(20,40,60,.10);align-items:stretch}
.mcta .mc-mini{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:52px;padding:.45rem 0;border-radius:13px;background:#fff;border:1px solid var(--line-2);color:var(--ink);font-weight:800;font-size:.64rem;cursor:pointer;font-family:var(--font)}
.mcta .mc-mini svg{width:20px;height:20px;fill:var(--lead)}
.mcta .mc-quote{flex:1;justify-content:center;padding:.85rem 1rem;font-size:1rem}
@media(max-width:760px){.mcta{display:flex}body{padding-bottom:80px}}
/* mobile: the 4-up bar's Ask button replaces the floating chat bubble */
@media(max-width:760px){body.chat-in-bar .sc-launch{display:none!important}}

/* scroll-reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1)}
.reveal.in{opacity:1;transform:none}
/* hero ken-burns zoom */
@keyframes kenburns{from{transform:scale(1.001)}to{transform:scale(1.055)}}
.hero-photo img{animation:kenburns 24s ease-in-out infinite alternate}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.hero-photo img{animation:none}}

/* ZIP modal */
.zipmodal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;background:rgba(16,28,42,.55);backdrop-filter:blur(3px);padding:20px}
.zipmodal.open{display:flex;animation:zfade .2s ease}
@keyframes zfade{from{opacity:0}to{opacity:1}}
.zipmodal-card{background:var(--cream);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:clamp(26px,4vw,40px);max-width:520px;width:100%;position:relative;text-align:center}
.zipmodal-card h3{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:1.2rem}
.zipmodal-x{position:absolute;top:12px;right:16px;background:none;border:0;font-size:1.7rem;line-height:1;color:var(--muted);cursor:pointer}
.zipbar{display:flex;align-items:center;gap:.4rem;background:#fff;border-radius:999px;padding:.4rem;box-shadow:var(--sh-md);max-width:420px;margin:0 auto;border:1px solid var(--line)}
.zipbar-ic{padding-left:.8rem;color:var(--muted);display:inline-flex;align-items:center}
.zipbar input{flex:1;min-width:0;border:0;outline:0;background:none;font-family:var(--font);font-size:1rem;padding:.7rem .4rem;color:var(--ink)}

/* per-city / interior page hero variant (smaller, image right) */
.subhero{position:relative;overflow:hidden;background:radial-gradient(1100px 460px at 88% -8%, var(--lead-tint), transparent 60%),linear-gradient(180deg,var(--cream),var(--cream-2))}
.subhero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,52px);align-items:center;padding:clamp(36px,5vw,60px) var(--pad)}
.subhero h1{font-size:clamp(2.5rem,5.2vw,4rem);font-weight:800}
.subhero p.sub{font-size:clamp(1rem,1.4vw,1.14rem);color:var(--ink-2);max-width:42ch;margin-top:1rem}
.subhero-photo{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-lg);aspect-ratio:3/4;background:#dfe9e0;border:7px solid #fff}
.subhero-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
@media(max-width:860px){.subhero .wrap{grid-template-columns:1fr}.subhero-photo{max-width:520px;order:-1}}
.chips-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.nbhd{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:.45rem .9rem;font-weight:700;font-size:.86rem;color:var(--ink-2)}
.nbhd .licon{width:15px;height:15px;color:var(--lead)}

/* plans */
.plans-grid{align-items:stretch}
.plan{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,2.6vw,30px);box-shadow:var(--sh-sm);display:flex;flex-direction:column;position:relative;transition:transform .15s ease,box-shadow .15s ease}
.section.paper .plan{background:var(--cream)}
.plan:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.plan.pop{border:2px solid var(--lead);box-shadow:var(--sh-md)}
.plan .pop-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--lead);color:#fff;font-weight:800;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:.34rem .9rem;border-radius:999px;white-space:nowrap;box-shadow:0 8px 20px var(--lead-sh)}
.plan h4{font-size:1.5rem;margin-bottom:.25rem}
.plan .tagline{color:var(--muted);font-weight:700;font-size:.92rem;margin-bottom:.4rem}
.plan ul{list-style:none;padding:0;margin:1rem 0 1.4rem;display:grid;gap:.65rem}
.plan li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-2)}
.plan li .ck{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center}
.plan li .ck .licon{width:13px;height:13px}
.plan>.btn{margin-top:auto;justify-content:center}
.plan-onetime{margin-top:clamp(16px,2vw,22px);background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(16px,2vw,22px) clamp(20px,2.4vw,28px);display:flex;align-items:center;gap:1rem;flex-wrap:wrap;box-shadow:var(--sh-sm)}
.section.paper .plan-onetime{background:var(--cream)}
.plan-onetime .po-ic{width:46px;height:46px;border-radius:13px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;flex:0 0 auto}
.plan-onetime>div{flex:1;min-width:220px;font-size:.98rem;color:var(--ink-2)}
.plan-onetime strong{color:var(--ink);font-family:var(--display)}
.plan-onetime .btn{flex:0 0 auto}
@media(max-width:600px){.plan-onetime{flex-direction:column;align-items:flex-start}}

/* peace of mind */
.pom{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(30px,5vw,68px);align-items:center}
.pom-photos{position:relative;min-height:clamp(380px,42vw,520px)}
.pom-ph{margin:0;position:absolute;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);width:76%;background:#fff;border:7px solid #fff;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s ease;will-change:transform}
.pom-ph img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.pom-ph figcaption{position:absolute;left:14px;bottom:14px;display:flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.96);color:var(--ink);font-weight:800;font-size:.78rem;padding:.45rem .8rem;border-radius:999px;box-shadow:var(--sh-sm)}
.pom-ph figcaption .licon{width:16px;height:16px;color:var(--lead)}
.pom-ph-1{top:0;left:0;z-index:1;transform:rotate(-3deg)}
.pom-ph-2{bottom:0;right:0;z-index:2;transform:rotate(3deg)}
.pom-ph--front{z-index:5;transform:rotate(0deg) scale(1.035);box-shadow:0 30px 72px rgba(20,40,60,.32)}
.pom-text h2{font-size:clamp(2.3rem,4.2vw,3.7rem);line-height:1.01}
.pom-text>.muted{font-size:1.08rem;max-width:46ch}
.pom-feats{display:grid;gap:1.4rem;margin:1.7rem 0}
.pom-feat{display:flex;gap:1rem;align-items:flex-start}
.pom-feat .ic-lg{margin-bottom:0;flex:0 0 auto;width:52px;height:52px;background:var(--lead);color:#fff}
.pom-feat h4{font-size:1.16rem;margin-bottom:.25rem}
.pom-feat p{color:var(--muted);font-size:1rem}
@media(max-width:860px){.pom{grid-template-columns:1fr}.pom-photos{width:min(440px,88vw);min-height:clamp(430px,124vw,560px);margin:0 auto 8px}}

/* service area map */
.map-row{margin-top:clamp(28px,4vw,48px);display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(22px,3vw,40px);align-items:stretch}
.map-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,2.6vw,32px);box-shadow:var(--sh-sm);display:flex;flex-direction:column}
.section.cream .map-card{background:#fff}
.map-card h3{font-size:clamp(1.4rem,2.4vw,1.9rem);margin:.4rem 0 1rem}
.map-pts{list-style:none;padding:0;margin:0 0 1.2rem;display:grid;gap:.6rem}
.map-pts li{display:flex;gap:.85rem;align-items:center;font-size:1rem;font-weight:600;color:var(--ink-2)}
.map-pts .ck{flex:0 0 auto;width:44px;height:44px;border-radius:13px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease}
.map-pts .ck .licon{width:21px;height:21px}
.map-pts li:hover .ck{transform:translateY(-3px) scale(1.07);box-shadow:0 8px 18px var(--lead-sh)}
.map-dyk{margin-top:auto;background:var(--cream);border:1px solid var(--line);border-radius:var(--r-md);padding:1.1rem 1.2rem}
.map-dyk strong{display:block;font-family:var(--display);font-size:1.1rem;margin-bottom:.2rem}
.map-dyk span{display:block;color:var(--muted);font-size:.92rem;margin-bottom:.9rem}
.map-embed{position:relative;border-radius:var(--r-xl);overflow:hidden;border:7px solid #fff;box-shadow:var(--sh-lg);min-height:380px;background:#dfe9e0}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.map-badge{position:absolute;top:14px;left:14px;display:flex;align-items:center;gap:.6rem;background:#fff;border-radius:14px;box-shadow:var(--sh-md);padding:.55rem .8rem;z-index:2;text-decoration:none;color:inherit;cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease}
a.map-badge:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(20,40,60,.2)}
.map-badge.btm{top:auto;bottom:14px}
.map-badge .g{width:30px;height:30px;border-radius:50%;background:conic-gradient(#ea4335,#fbbc05,#34a853,#4285f4,#ea4335);color:#fff;display:grid;place-items:center;font-weight:900;font-family:var(--display);flex:0 0 auto}
.map-badge strong{display:block;font-family:var(--display);font-size:1rem;color:var(--ink);line-height:1.1}
.map-badge>div>span{display:block;font-size:.74rem;color:var(--muted);font-weight:600}
@media(max-width:820px){.map-row{grid-template-columns:1fr}.map-embed{min-height:300px}}
/* real Vegas-area photo strip (each tile links to its city page) */
.area-photos{margin-top:clamp(16px,2.4vw,26px);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.6vw,18px)}
.ap{position:relative;display:block;border-radius:var(--r-md);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--sh-sm);transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .22s ease}
.ap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s ease}
.ap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(14,40,55,.8))}
.ap span{position:absolute;left:0;right:0;bottom:0;z-index:2;color:#fff;font-family:var(--display);font-weight:800;font-size:1.02rem;letter-spacing:.01em;padding:.65rem .85rem;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.ap:hover{transform:translateY(-6px);box-shadow:0 18px 38px rgba(20,40,60,.2)}
.ap:hover img{transform:scale(1.08)}
@media(max-width:680px){.area-photos{grid-template-columns:1fr 1fr}}

/* ===== dynamic hover micro-interactions (buttons expand, icons + photos lift) ===== */
.btn{transition:transform .2s cubic-bezier(.34,1.45,.5,1),box-shadow .2s ease,background .15s ease,border-color .15s ease,color .15s ease}
.btn:hover{transform:translateY(-2px) scale(1.04)}
.btn-lg:hover{transform:translateY(-3px) scale(1.05)}
.btn:active{transform:translateY(0) scale(.97)}
.card .ic-lg,.pom-feat .ic-lg,.chip,.trust .tb,.nbhd,.area .pin,.step .num,.plan .pop-badge{transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease,border-color .15s ease,color .15s ease}
.card:hover .ic-lg{transform:scale(1.12) rotate(-5deg)}
.pom-feat:hover .ic-lg{transform:translateY(-4px) scale(1.08)}
.step:hover .num{transform:translateY(-4px) scale(1.06)}
.plan:hover .pop-badge{transform:translateX(-50%) translateY(-3px)}
.trust .tb:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.nbhd:hover{transform:translateY(-3px);border-color:var(--lead);color:var(--lead)}
.nbhd:hover .licon{color:var(--lead)}
.area:hover .pin{transform:scale(1.18)}
.pom-ph{transition:transform .3s cubic-bezier(.34,1.4,.5,1),box-shadow .25s ease}
.pom-ph-1:hover{transform:rotate(-1deg) translateY(-8px) scale(1.02);z-index:5}
.pom-ph-2:hover{transform:rotate(1deg) translateY(-8px) scale(1.02);z-index:6}
.ba{transition:transform .25s cubic-bezier(.34,1.4,.5,1),box-shadow .25s ease}
.ba:hover{transform:translateY(-5px)}
.hero-photo,.subhero-photo{transition:transform .3s cubic-bezier(.34,1.4,.5,1),box-shadow .25s ease}
.hero-art:hover .hero-photo,.subhero:hover .subhero-photo{transform:translateY(-6px)}
.review-card-wrap,.map-card,.map-embed{transition:transform .25s cubic-bezier(.34,1.4,.5,1),box-shadow .2s ease}
.map-embed:hover{transform:translateY(-4px)}
@media(prefers-reduced-motion:reduce){
  .btn,.card .ic-lg,.pom-feat .ic-lg,.pom-ph,.ba,.hero-photo,.subhero-photo,.step .num,.map-embed{transition:none}
  .btn:hover,.btn-lg:hover,.card:hover .ic-lg,.pom-feat:hover .ic-lg,.pom-ph-1:hover,.pom-ph-2:hover,.ba:hover,.hero-art:hover .hero-photo,.subhero:hover .subhero-photo,.step:hover .num,.map-embed:hover{transform:none}
}

/* ===== shared content-page components (commercial, contact, about, faq, gallery, reviews, deodorizing) ===== */
/* centered page hero (no photo) */
.page-hero{position:relative;overflow:hidden;background:radial-gradient(1100px 460px at 88% -8%, var(--lead-tint), transparent 60%),linear-gradient(180deg,var(--cream),var(--cream-2));text-align:center}
.page-hero .wrap{padding:clamp(40px,6vw,74px) var(--pad)}
.page-hero .eyebrow{justify-content:center}
.page-hero h1{font-size:clamp(2.4rem,5.2vw,3.9rem);font-weight:800;line-height:1.03}
.page-hero p.sub{font-size:clamp(1.02rem,1.5vw,1.18rem);color:var(--ink-2);max-width:62ch;margin:1.05rem auto 0}
.page-hero .actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.7rem}
.crumbs{font-size:.86rem;color:var(--muted);font-weight:600;margin-bottom:.7rem}
.crumbs a{color:var(--muted);text-decoration:none}.crumbs a:hover{color:var(--lead)}
.crumbs .sep{margin:0 .4rem;opacity:.6}

/* trust strip (icon + label row) */
.tstrip{display:flex;flex-wrap:wrap;gap:1.1rem 1.6rem;justify-content:center;margin-top:1.6rem;color:var(--ink-2);font-size:.93rem;font-weight:600}
.tstrip .ti{display:flex;align-items:center;gap:.5rem}
.tstrip .ti svg{width:18px;height:18px;color:var(--lead);flex:0 0 auto}

/* numbered step badge inside a .card */
.cardnum{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:13px;background:var(--lead-soft);color:var(--lead);font-family:var(--display);font-weight:800;font-size:1.25rem;margin-bottom:.9rem;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.card:hover .cardnum{transform:translateY(-3px) scale(1.06)}
.cardnum.done{background:var(--lead);color:#fff}

/* checklist rows reused on content pages */
.perks{list-style:none;padding:0;margin:1.2rem 0 0;display:grid;gap:.7rem}
.perks li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-2);font-size:.98rem}
.perks .ck{flex:0 0 auto;width:26px;height:26px;border-radius:8px;background:var(--lead-soft);color:var(--lead);display:grid;place-items:center;margin-top:1px}
.perks .ck .licon{width:15px;height:15px}
.perks li strong{color:var(--ink)}

/* shared forms (commercial intake + contact) */
.psd-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,40px);box-shadow:var(--sh-sm);max-width:780px;margin:clamp(20px,3vw,34px) auto 0;text-align:left}
.psd-form .field{margin-bottom:1.05rem}
.psd-form .field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem;margin-bottom:1.05rem}
.psd-form label{display:block;font-weight:700;color:var(--ink);margin-bottom:.4rem;font-size:.95rem}
.psd-form .help{color:var(--muted);font-size:.84rem;margin:-.2rem 0 .45rem;font-weight:500}
.psd-form .input,.psd-form input,.psd-form select,.psd-form textarea{width:100%;font-family:var(--font);font-size:1rem;color:var(--ink);background:var(--cream);border:1.5px solid var(--line-2);border-radius:12px;padding:.8rem .9rem;transition:border-color .15s ease,box-shadow .15s ease}
.psd-form .input:focus,.psd-form input:focus,.psd-form select:focus,.psd-form textarea:focus{outline:0;border-color:var(--lead);box-shadow:0 0 0 3px var(--lead-soft)}
.psd-form textarea{resize:vertical;min-height:112px}
.psd-form .check-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.psd-form .check-row{display:flex;align-items:center;gap:.6rem;font-weight:600;color:var(--ink-2);background:var(--cream);border:1.5px solid var(--line);border-radius:12px;padding:.7rem .8rem;cursor:pointer;margin-bottom:0}
.psd-form .check-row input{width:auto}
.psd-form .check-row:hover{border-color:var(--lead)}
.psd-form .submit-row{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;margin-top:.4rem}
.psd-form .small-print{color:var(--muted);font-size:.82rem;margin-top:1rem}
@media(max-width:600px){.psd-form .field-row,.psd-form .check-grid{grid-template-columns:1fr}}

/* review carousel card wrapper for inner pages */
.rh-wrap{margin-top:clamp(20px,3vw,34px);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(20px,2.4vw,30px);box-shadow:var(--sh-sm)}
#review-carousel{min-height:280px}
