
:root {
  --black:#050505;
  --black-2:#101010;
  --black-3:#171717;
  --white:#ffffff;
  --off-white:#f6f6f2;
  --gray:#b8b8b8;
  --dark-gray:#3b3b3b;
  --orange:#fc5501;
  --orange-dark:#d94700;
  --orange-light:#ff7a26;
  --green:#53b84e;
  --border:rgba(255,255,255,.14);
  --shadow:0 28px 80px rgba(0,0,0,.28);
  --radius:26px;
  --max-width:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--off-white);color:var(--black);font-family:Arial,Helvetica,sans-serif;line-height:1.55}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max-width),calc(100% - 32px));margin:0 auto}
.promo-banner{background:#fff;color:var(--black);position:relative;z-index:60;border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 8px 24px rgba(0,0,0,.05)}
.promo-banner__inner{min-height:46px;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0}
.promo-message{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:800;color:#1f2937}
.promo-message strong{font-weight:950;color:var(--orange)}
.promo-actions{display:flex;align-items:center;gap:16px}
.promo-link{color:var(--black);font-weight:950;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}
.promo-close{border:0;background:transparent;color:#374151;font-size:30px;line-height:1;cursor:pointer;padding:0;width:28px;height:28px}
.top-strip{background:var(--orange);color:var(--black);font-weight:900;letter-spacing:.03em;text-transform:uppercase;font-size:13px}
.top-strip__inner{min-height:42px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.top-strip a{font-size:16px}
.site-header{position:sticky;top:0;z-index:50;background:rgba(5,5,5,.94);border-bottom:1px solid rgba(255,255,255,.12);backdrop-filter:blur(14px)}
.nav{min-height:86px;display:flex;justify-content:space-between;align-items:center;gap:18px}
.logo-link img{width:225px}
.desktop-nav{display:flex;align-items:center;gap:22px;color:var(--white);font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.desktop-nav a:hover{color:var(--orange)}
.nav-actions{display:flex;gap:10px;align-items:center}
.menu-button{display:none;background:transparent;color:var(--white);border:1px solid var(--border);border-radius:14px;width:48px;height:48px;font-size:26px;cursor:pointer}
.mobile-nav{display:none;padding-bottom:18px}
.mobile-nav a{display:block;color:var(--white);font-weight:900;text-transform:uppercase;letter-spacing:.05em;padding:14px 0;border-top:1px solid rgba(255,255,255,.1)}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:13px 20px;border-radius:999px;font-weight:950;text-transform:uppercase;letter-spacing:.04em;font-size:14px;transition:.18s ease;border:2px solid transparent;cursor:pointer;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-orange{background:var(--orange);color:var(--black);border-color:var(--orange);box-shadow:0 18px 45px rgba(252,85,1,.24)}
.btn-white{background:var(--white);color:var(--black);border-color:var(--white)}
.btn-black{background:var(--black);color:var(--white);border-color:var(--black)}
.btn-ghost{background:transparent;color:var(--white);border-color:rgba(255,255,255,.28)}
.btn-large{min-height:58px;padding:16px 24px}
.btn-full{width:100%}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.cta-row.center{justify-content:center}
.hero{position:relative;overflow:hidden;background:var(--black);color:var(--white);min-height:760px}
.hero-video{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:brightness(1.08) saturate(1.06) contrast(1.03)}
.hero-overlay{position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 24% 32%,rgba(252,85,1,.10),transparent 30%),linear-gradient(90deg,rgba(0,0,0,.70) 0%,rgba(0,0,0,.50) 48%,rgba(0,0,0,.24) 100%),linear-gradient(180deg,rgba(0,0,0,.24),rgba(0,0,0,.48))}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:42px;align-items:center;padding:92px 0 88px;min-height:760px}
.eyebrow,.mini-kicker{display:inline-flex;align-items:center;gap:10px;margin:0 0 18px;color:var(--orange);font-weight:950;text-transform:uppercase;letter-spacing:.1em;font-size:13px}
.eyebrow span{width:46px;height:4px;background:var(--orange);display:inline-block}
h1,h2,h3{margin-top:0;line-height:.98}
h1{margin-bottom:22px;max-width:900px;font-size:clamp(44px,7vw,84px);letter-spacing:-.06em;text-transform:uppercase}
.hero-text{color:#dedede;font-size:20px;max-width:660px;margin:0 0 32px}
.hero-book-card{background:rgba(255,255,255,.94);color:var(--black);border-radius:34px;padding:36px;box-shadow:0 28px 80px rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.32);max-width:580px;justify-self:end}
.hero-book-card h3{font-size:clamp(34px,4vw,58px);line-height:.98;letter-spacing:-.06em;margin-bottom:18px;color:#111827}
.hero-book-card h3 span{color:var(--orange)}
.hero-book-card p{font-size:18px;line-height:1.5;color:#4b5563;margin:0 0 28px}
.hero-copy{max-width:680px}
.hero-copy p{color:#e5e7eb;font-size:20px;line-height:1.55;max-width:640px;margin:0 0 28px}
.hero-proof{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-proof span{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.14);font-size:13px;font-weight:950;letter-spacing:.04em;text-transform:uppercase;color:#fff}
.hero-book-card--pop{position:relative;background:linear-gradient(180deg,rgba(255,255,255,.975) 0%,rgba(255,255,255,.94) 100%);border:1px solid rgba(255,255,255,.55);border-top:6px solid var(--orange);box-shadow:0 28px 80px rgba(0,0,0,.28),0 12px 32px rgba(252,85,1,.14)}
.hero-card-kicker{display:inline-flex;align-items:center;gap:10px;margin:0 0 16px;color:var(--orange);font-weight:950;text-transform:uppercase;letter-spacing:.1em;font-size:13px}
.hero-book-card--pop h2{font-size:clamp(36px,4.5vw,60px);line-height:.96;letter-spacing:-.065em;margin:0 0 16px;color:#0f172a;text-transform:uppercase}
.hero-book-card--pop h2 span{color:var(--orange)}
.btn-book-pop{width:100%;min-height:72px;border-radius:20px;font-size:clamp(18px,2.2vw,28px);font-weight:950;box-shadow:0 18px 44px rgba(252,85,1,.26)}
.hero-card-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.hero-card-chips span{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;background:#fff3ec;color:#a13a00;border:1px solid rgba(252,85,1,.18);font-size:13px;font-weight:950;line-height:1.1;text-transform:uppercase;letter-spacing:.03em}
.hero-card-alt{margin-top:18px;color:#4b5563;font-size:15px;font-weight:800}
.hero-card-alt a{color:#111827;text-decoration:underline;text-underline-offset:3px}
.btn-book{width:100%;min-height:74px;border-radius:16px;font-size:clamp(22px,2.2vw,34px);font-weight:950;letter-spacing:-.02em;text-transform:uppercase;background:var(--orange);color:var(--black);border-color:var(--orange);box-shadow:0 18px 44px rgba(252,85,1,.24)}
.book-note{margin-top:24px;display:flex;align-items:center;gap:12px;color:#6b7280;font-size:15px;font-weight:700}
.book-check{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(252,85,1,.14);color:var(--orange);font-weight:950;flex:0 0 auto}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px;max-width:680px}
.trust-grid div{padding:18px;border:1px solid var(--border);border-radius:20px;background:rgba(255,255,255,.07);backdrop-filter:blur(8px)}
.trust-grid strong{display:block;color:var(--white);font-size:22px;text-transform:uppercase;line-height:1}
.trust-grid span{color:var(--gray);font-weight:700}
.quick-quote{background:var(--orange);color:var(--black);padding:34px 0}
.quick-quote__inner{display:flex;justify-content:space-between;gap:22px;align-items:center}
.quick-quote h2{font-size:clamp(30px,4vw,46px);text-transform:uppercase;letter-spacing:-.055em;margin-bottom:0}
.quick-quote .mini-kicker{color:var(--black);margin-bottom:8px}
.badge-strip{background:#ededeb;padding:38px 0 34px}
.badge-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;align-items:start}
.trust-badge{text-align:center;padding:4px 8px}
.badge-icon{width:110px;height:110px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;font-size:44px;font-weight:950;color:var(--white);box-shadow:0 10px 28px rgba(0,0,0,.08);border:8px solid rgba(255,255,255,.58)}
.badge-google{background:linear-gradient(135deg,#4285F4,#34A853)}.badge-orange{background:linear-gradient(135deg,#ff7a26,#fc5501)}.badge-green{background:linear-gradient(135deg,#57c65a,#2da94a)}.badge-blue{background:linear-gradient(135deg,#4f7dff,#3264ea)}.badge-gold{background:linear-gradient(135deg,#f4cb21,#dbad00)}
.trust-badge h3{margin:0;color:#4b5563;font-size:clamp(16px,1.5vw,20px);line-height:1.25;font-weight:950;text-transform:uppercase;letter-spacing:.06em}
.section{padding:86px 0}
.section-heading{max-width:840px;margin-bottom:34px}
.section-heading h2{font-size:clamp(36px,5vw,58px);text-transform:uppercase;letter-spacing:-.06em;margin-bottom:16px}
.section-heading p{color:var(--dark-gray);font-size:18px;margin:0;max-width:720px}
.section-heading.light h2,.section-heading.light p{color:var(--white)}
.service-grid,.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card,.info-card{position:relative;overflow:hidden;background:var(--white);border:1px solid rgba(0,0,0,.08);border-radius:var(--radius);padding:28px;min-height:240px;box-shadow:0 16px 42px rgba(0,0,0,.07)}
.service-card::after{content:"";position:absolute;right:-34px;bottom:-34px;width:110px;height:110px;border:18px solid rgba(252,85,1,.16);border-radius:50%}
.service-card span{display:inline-flex;width:50px;height:50px;justify-content:center;align-items:center;background:var(--black);color:var(--orange);border-radius:16px;font-weight:950;margin-bottom:22px}
.service-card h3,.info-card h3{font-size:26px;text-transform:uppercase;letter-spacing:-.045em;margin-bottom:10px}
.service-card p,.info-card p{color:var(--dark-gray);margin:0}
.service-card a{position:relative;z-index:2;display:inline-flex;margin-top:18px;font-weight:950;color:var(--orange);text-transform:uppercase;font-size:13px}
.page-hero{background:linear-gradient(135deg,#050505 0%,#111 60%,#1b1b1b 100%);color:var(--white);padding:96px 0 70px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;border-radius:50%;background:rgba(252,85,1,.18)}
.page-hero__inner{position:relative;z-index:1;max-width:980px}
.page-hero h1{font-size:clamp(42px,6vw,76px)}
.page-hero p{font-size:20px;color:#dedede;max-width:820px;margin:0 0 28px}
.split-grid,.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.black-panel,.white-panel{border-radius:34px;padding:36px;box-shadow:0 18px 52px rgba(0,0,0,.08)}
.black-panel{background:var(--black);color:var(--white)}.white-panel{background:var(--white)}
.black-panel h2,.white-panel h2{font-size:clamp(34px,4vw,52px);text-transform:uppercase;letter-spacing:-.06em;margin-bottom:18px}
.black-panel p{color:#dedede}.white-panel p{color:var(--dark-gray)}
.check-list,.area-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.check-list span,.area-tags a,.area-tags span{display:inline-flex;align-items:center;border-radius:999px;padding:11px 14px;font-weight:900;font-size:14px}
.check-list span{background:rgba(255,255,255,.1);border:1px solid var(--border)}.check-list span::before{content:"✓";color:var(--orange);margin-right:8px}
.area-tags a,.area-tags span{background:#f1f1ed;border:1px solid rgba(0,0,0,.07)}.area-tags a:hover{background:var(--orange);color:var(--black)}
.process-section{background:linear-gradient(rgba(5,5,5,.92),rgba(5,5,5,.92)),url("assets/way2haul-trailer-vinyl-reference.png");background-size:cover;background-position:center;color:var(--white)}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.process-card{border:1px solid var(--border);border-radius:var(--radius);padding:30px;background:rgba(255,255,255,.08);backdrop-filter:blur(12px)}
.process-card strong{width:54px;height:54px;display:inline-flex;align-items:center;justify-content:center;background:var(--orange);color:var(--black);border-radius:18px;font-size:24px;margin-bottom:20px}
.process-card h3{font-size:28px;text-transform:uppercase;letter-spacing:-.045em;margin-bottom:10px}.process-card p{color:#dedede;margin:0}
.mission-section{background:linear-gradient(180deg,#f4f4f0 0%,#fff 100%)}
.mission-grid,.ev-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:center}
.mission-copy h2,.ev-copy h2{font-size:clamp(36px,5vw,58px);text-transform:uppercase;letter-spacing:-.06em;margin-bottom:18px}
.mission-copy p,.ev-copy p{color:var(--dark-gray);font-size:18px;max-width:700px}
.mission-points,.ev-points{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}
.mission-points div{background:var(--white);border:1px solid rgba(0,0,0,.08);border-radius:22px;padding:18px;box-shadow:0 12px 32px rgba(0,0,0,.06)}
.mission-points strong,.ev-points strong{display:block;color:var(--orange);text-transform:uppercase;letter-spacing:-.02em;margin-bottom:6px}
.mission-points span,.ev-points span{color:var(--dark-gray);font-size:14px}
.mission-card,.ev-card{background:var(--black);color:var(--white);border-radius:34px;padding:34px;box-shadow:0 22px 54px rgba(0,0,0,.18);position:relative;overflow:hidden}
.mission-card h3,.ev-card h3{font-size:clamp(28px,3vw,42px);text-transform:uppercase;letter-spacing:-.05em;line-height:1.02;margin-bottom:14px}
.mission-card p,.ev-card p{color:#dedede;margin-bottom:0}
.mission-icon-wrap{display:flex;gap:14px;margin-bottom:20px}.mission-icon{width:68px;height:68px;border-radius:50%;display:grid;place-items:center;font-size:32px;font-weight:900}
.mission-icon.recycle{background:rgba(124,207,116,.16);color:#55b84d;border:1px solid rgba(124,207,116,.32)}.mission-icon.heart{background:rgba(252,85,1,.16);color:var(--orange);border:1px solid rgba(252,85,1,.32)}
.ev-section{background:radial-gradient(circle at 82% 22%,rgba(124,207,116,.18),transparent 30%),radial-gradient(circle at 22% 18%,rgba(252,85,1,.18),transparent 26%),linear-gradient(135deg,#071006 0%,#050505 48%,#111 100%);color:var(--white)}
.ev-copy p{color:#dedede}.ev-points div{border:1px solid var(--border);background:rgba(255,255,255,.07);border-radius:22px;padding:18px}.ev-points span{color:#d6d6d6}
.ev-photo-wrap{border-radius:24px;overflow:hidden;box-shadow:0 18px 44px rgba(0,0,0,.22);margin-bottom:22px;border:1px solid rgba(255,255,255,.18);background:#0f0f0f}
.ev-photo{width:100%;height:360px;object-fit:cover;object-position:center}
.ev-badge{display:inline-flex;background:var(--orange);color:var(--black);font-weight:950;text-transform:uppercase;letter-spacing:.08em;padding:10px 14px;border-radius:999px;margin-bottom:18px}
.review-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.review-grid article{background:var(--black);color:var(--white);border-radius:var(--radius);padding:28px;box-shadow:0 18px 46px rgba(0,0,0,.12)}
.review-grid div{color:var(--orange);letter-spacing:.1em;margin-bottom:16px;font-size:18px}.review-grid p{color:#dedede;margin-bottom:18px}.review-cta{margin-top:30px;text-align:center}

.service-photo-card {
  border-radius: 26px;
  overflow: hidden;
  box-shadow: 0 18px 52px rgba(0,0,0,.16);
  border: 1px solid rgba(0,0,0,.08);
  background: var(--white);
}

.service-photo-card img {
  width: 100%;
  height: 520px;
  object-fit: cover;
  object-position: center;
}

.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.gallery-item{background:var(--white);border-radius:22px;overflow:hidden;box-shadow:0 12px 32px rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.06)}
.gallery-item img{width:100%;height:270px;object-fit:cover}.gallery-item div{padding:16px}.gallery-item span{color:var(--orange);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.gallery-item p{font-weight:800;margin:6px 0 0;color:#333}
.about-photo-card img{height:360px;object-fit:cover;object-position:center center}
@media (min-width:1100px){.about-photo-card img{height:390px}}
@media (max-width:760px){.about-photo-card img{height:260px}}

.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.price-card{background:var(--white);border-radius:26px;padding:28px;border:1px solid rgba(0,0,0,.08);box-shadow:0 16px 40px rgba(0,0,0,.07)}
.price-card h3{font-size:24px;text-transform:uppercase;letter-spacing:-.04em}.price-card strong{display:block;font-size:34px;color:var(--orange);line-height:1;margin:14px 0}.price-card p{color:var(--dark-gray)}
.faq-section{background:#ecece7}.faq-list{display:grid;gap:12px}details{background:var(--white);border:1px solid rgba(0,0,0,.08);border-radius:20px;padding:20px 22px}summary{cursor:pointer;font-weight:950;text-transform:uppercase;letter-spacing:-.015em;font-size:18px}details p{color:var(--dark-gray);margin:12px 0 0}
.blog-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.blog-card{background:var(--white);border-radius:26px;padding:28px;border:1px solid rgba(0,0,0,.08);box-shadow:0 16px 40px rgba(0,0,0,.07)}.blog-card h3{font-size:26px;text-transform:uppercase;letter-spacing:-.05em}.blog-card p{color:var(--dark-gray)}
.article{background:#fff;padding:60px 0}.article .container{max-width:860px}.article h2{font-size:36px;text-transform:uppercase;letter-spacing:-.05em;margin-top:36px}.article p,.article li{font-size:18px;color:#333}.article ul{padding-left:22px}
.final-cta{background:var(--black);color:var(--white);padding:90px 0;text-align:center}.final-cta__inner{border:1px solid var(--border);border-radius:38px;padding:48px 28px;background:radial-gradient(circle at 50% 0%,rgba(252,85,1,.18),transparent 38%),rgba(255,255,255,.05)}.final-cta img{width:min(620px,92%);margin:0 auto 22px}.final-cta h2{font-size:clamp(42px,7vw,78px);text-transform:uppercase;letter-spacing:-.06em;margin-bottom:10px}.final-cta p{color:#dedede;font-size:20px;margin-bottom:28px}
.site-footer{background:#000;color:var(--white);padding:54px 0 34px}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr .8fr;gap:34px}.site-footer img{width:240px;margin-bottom:18px}.site-footer p,.site-footer a{color:#bdbdbd}.site-footer a{display:block;margin:8px 0}.site-footer h3{text-transform:uppercase;letter-spacing:.06em;color:var(--orange);font-size:15px;margin-bottom:12px}.copyright{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:24px;color:#8e8e8e;font-size:14px}
.sticky-actions{display:none;position:fixed;z-index:90;left:12px;right:12px;bottom:12px;gap:10px}.sticky-actions a{flex:1;text-align:center;border-radius:999px;padding:15px 12px;font-weight:950;text-transform:uppercase;background:var(--orange);color:var(--black);box-shadow:0 18px 44px rgba(0,0,0,.28)}.sticky-actions a:last-child{background:var(--white)}

@media(max-width:1080px){
  .service-photo-card img{height:420px}
  .desktop-nav,.nav-actions{display:none}.menu-button{display:block}.mobile-nav.open{display:block}.logo-link img{width:200px}
  .hero-grid,.split-grid,.two-col,.mission-grid,.ev-grid{grid-template-columns:1fr}.hero-grid{padding:66px 0 70px;min-height:auto}.hero{min-height:auto}
  .service-grid,.card-grid,.process-grid,.review-grid,.price-grid,.blog-list,.gallery-grid,.mission-points,.ev-points{grid-template-columns:1fr 1fr}
  .badge-grid{grid-template-columns:repeat(2,1fr)}.quick-quote__inner{display:block}.quick-quote .btn{margin-top:20px}.trust-grid{grid-template-columns:1fr}.sticky-actions{display:flex}body{padding-bottom:76px}.ev-photo{height:320px}
}
@media(max-width:650px){
  .service-photo-card img{height:300px}
  .top-strip__inner,.promo-banner__inner{display:block;text-align:center;padding:10px 0}.promo-actions{justify-content:center;margin-top:6px}
  .nav{min-height:76px}.logo-link img{width:178px}h1{font-size:42px}.hero-text,.page-hero p{font-size:18px}.btn{width:100%}
  .hero-book-card,.black-panel,.white-panel,.mission-card,.ev-card{padding:24px;border-radius:26px}
  .service-grid,.card-grid,.process-grid,.review-grid,.price-grid,.blog-list,.gallery-grid,.mission-points,.ev-points,.badge-grid{grid-template-columns:1fr}
  .gallery-item img{height:240px}.section{padding:62px 0}.ev-photo{height:240px}.footer-grid{grid-template-columns:1fr}
}



/* Before/After gallery sliders */
.section--light{background:#f2f2f0}
.ba-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:28px;
}
.ba-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 18px 42px rgba(0,0,0,.08);
}
.ba-compare{
  position:relative;
  aspect-ratio: 4 / 3;
  overflow:hidden;
  background:#ddd;
  --split:50%;
}
.ba-before,
.ba-after{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}
.ba-after-wrap{
  position:absolute;
  inset:0;
  overflow:hidden;
  width:var(--split);
}
.ba-badge{
  position:absolute;
  top:16px;
  z-index:3;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(5,5,5,.82);
  color:#fff;
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ba-badge--left{left:16px}
.ba-badge--right{right:16px}
.ba-handle{
  position:absolute;
  top:0;
  left:var(--split);
  transform:translateX(-50%);
  width:2px;
  height:100%;
  background:#fff;
  z-index:3;
  box-shadow:0 0 0 1px rgba(0,0,0,.08);
  pointer-events:none;
}
.ba-handle::before{
  content:"↔";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:52px;
  height:52px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  color:#111;
  font-size:1.2rem;
  font-weight:800;
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}
.ba-range{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  margin:0;
  opacity:0;
  cursor:ew-resize;
  z-index:5;
}
.ba-copy{
  padding:22px 22px 24px;
}
.ba-copy span{
  display:inline-block;
  margin-bottom:10px;
  color:var(--orange);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.ba-copy h3{
  margin:0 0 10px;
  font-size:1.35rem;
  line-height:1.2;
}
.ba-copy p{
  margin:0;
  color:var(--muted);
}
.gallery-grid--extras{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
@media(max-width:980px){
  .ba-grid{grid-template-columns:1fr}
  .gallery-grid--extras{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:640px){
  .ba-card{border-radius:22px}
  .ba-badge{top:12px;padding:7px 12px;font-size:.72rem}
  .ba-badge--left{left:12px}
  .ba-badge--right{right:12px}
  .ba-handle::before{width:46px;height:46px}
  .ba-copy{padding:18px}
  .ba-copy h3{font-size:1.18rem}
  .gallery-grid--extras{grid-template-columns:1fr}
}



.ba-book-btn{
  margin-top:18px;
  min-height:46px;
  padding:12px 18px;
  font-size:.82rem;
}
@media(max-width:640px){
  .ba-book-btn{width:100%}
}



/* Mobile-only hero video framing */
@media(max-width:650px){
  .hero{
    min-height: 720px;
  }

  .hero-grid{
    min-height: 720px;
    padding: 48px 0 54px;
    align-content: center;
  }

  .hero-video{
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: 58% center;
    filter: brightness(1.12) saturate(1.08) contrast(1.02);
  }

  .hero-overlay{
    background:
      linear-gradient(180deg, rgba(0,0,0,.54) 0%, rgba(0,0,0,.46) 44%, rgba(0,0,0,.68) 100%),
      linear-gradient(90deg, rgba(0,0,0,.50), rgba(0,0,0,.28));
  }

  .hero-book-card{
    background: rgba(255,255,255,.92);
  }
}

@media(max-width:430px){
  .hero{
    min-height: 760px;
  }

  .hero-grid{
    min-height: 760px;
  }

  .hero-video{
    object-position: 62% center;
  }
}



/* Mobile-only vertical hero video source */
@media(max-width:650px){
  .hero-video{
    object-fit: cover;
    object-position: center center;
  }
}



/* Dedicated desktop/mobile hero videos */
.hero-video-mobile{
  display:none;
}

@media(max-width:650px){
  .hero-video-desktop{
    display:none;
  }

  .hero-video-mobile{
    display:block;
  }
}

@media(min-width:651px){
  .hero-video-desktop{
    display:block;
  }

  .hero-video-mobile{
    display:none;
  }
}



/* Modern trust badge strip */
.badge-strip-modern{
  background:#f2f2ef;
  padding:30px 0;
  border-top:1px solid rgba(0,0,0,.06);
  border-bottom:1px solid rgba(0,0,0,.06);
}

.badge-modern-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}

.trust-pill{
  display:flex;
  align-items:center;
  gap:14px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:20px;
  padding:18px 18px;
  box-shadow:0 12px 32px rgba(0,0,0,.06);
}

.trust-pill__icon{
  width:46px;
  height:46px;
  flex:0 0 46px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:var(--black);
  color:var(--orange);
  font-weight:950;
  font-size:20px;
}

.trust-pill__icon.google-mark{
  background:linear-gradient(135deg,#4285F4,#34A853);
  color:#fff;
  font-family:Arial,Helvetica,sans-serif;
}

.trust-pill strong{
  display:block;
  color:#111827;
  font-size:15px;
  line-height:1.1;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:-.02em;
}

.trust-pill small{
  display:block;
  margin-top:5px;
  color:#6b7280;
  font-size:13px;
  line-height:1.25;
  font-weight:700;
}



/* Mobile trust badge layout fix */
@media(max-width:650px){
  .badge-strip-modern{
    padding:18px 0 20px;
    overflow:hidden;
  }

  .badge-modern-grid{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
    width:100%;
  }

  .trust-pill{
    width:100%;
    min-width:0;
    display:flex;
    align-items:center;
    gap:14px;
    padding:15px 16px;
    border-radius:18px;
    box-shadow:0 8px 22px rgba(0,0,0,.06);
  }

  .trust-pill__icon{
    width:44px;
    height:44px;
    flex:0 0 44px;
    border-radius:14px;
    font-size:20px;
  }

  .trust-pill div{
    min-width:0;
    flex:1;
  }

  .trust-pill strong{
    font-size:15px;
    line-height:1.15;
    white-space:normal;
  }

  .trust-pill small{
    font-size:13px;
    line-height:1.25;
    white-space:normal;
  }
}



/* Footer social links */
.footer-social h3{
  margin-bottom:12px;
}

.social-links{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.social-link{
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
  text-decoration:none;
  font-weight:800;
  opacity:.92;
  transition:opacity .2s ease, transform .2s ease;
}

.social-link:hover{
  opacity:1;
  transform:translateX(2px);
}

.social-icon{
  width:38px;
  height:38px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
}

.social-icon svg{
  width:21px;
  height:21px;
  fill:#fc5501;
}

@media(max-width:650px){
  .social-links{
    flex-direction:row;
    flex-wrap:wrap;
  }

  .social-link{
    padding-right:10px;
  }
}



/* Modern footer redesign */
.footer-modern{
  background:#161d27;
  color:#d7dce5;
  padding:52px 0 24px;
}

.footer-modern-grid{
  display:grid;
  grid-template-columns:1.4fr .9fr 1fr 1.05fr 1.05fr;
  gap:42px;
  align-items:start;
}

.footer-brand img{
  width:118px;
  height:auto;
  margin-bottom:22px;
}

.footer-brand p{
  color:#aeb6c3;
  line-height:1.6;
  max-width:330px;
  margin:0 0 32px;
}

.footer-modern h3{
  color:#fc5501;
  font-size:1.15rem;
  line-height:1.2;
  margin:0 0 22px;
  font-weight:950;
}

.footer-column{
  display:flex;
  flex-direction:column;
}

.footer-column a{
  color:#d7dce5;
  text-decoration:none;
  margin:0 0 14px;
  font-weight:750;
  line-height:1.35;
  opacity:.92;
}

.footer-column a:hover{
  color:#fff;
  opacity:1;
}

.footer-contact .contact-item{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-bottom:22px;
}

.footer-contact .contact-item span{
  color:#fc5501;
  font-size:1.25rem;
  line-height:1;
  margin-top:2px;
}

.footer-contact strong{
  color:#fff;
  font-size:1rem;
  line-height:1.2;
}

.footer-contact small{
  color:#d7dce5;
  font-size:.95rem;
  font-weight:750;
}

.footer-modern .footer-social h3{
  color:#fff;
  margin-bottom:14px;
}

.footer-modern .social-links{
  display:flex;
  flex-direction:row;
  gap:12px;
}

.footer-modern .social-link{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#252d39;
  border:1px solid rgba(255,255,255,.08);
  padding:0;
}

.footer-modern .social-link:hover{
  transform:translateY(-2px);
  background:#303948;
}

.footer-modern .social-icon{
  width:auto;
  height:auto;
  border:0;
  background:transparent;
}

.footer-modern .social-icon svg{
  width:23px;
  height:23px;
  fill:#fff;
}

.footer-modern .copyright{
  border-top:1px solid rgba(255,255,255,.09);
  margin-top:42px;
  padding-top:22px;
  color:#aeb6c3;
  font-size:.92rem;
}

@media(max-width:1120px){
  .footer-modern-grid{
    grid-template-columns:1.2fr 1fr 1fr;
    gap:34px;
  }
}

@media(max-width:760px){
  .footer-modern{
    padding:42px 0 90px;
  }

  .footer-modern-grid{
    grid-template-columns:1fr;
    gap:30px;
  }

  .footer-brand img{
    width:112px;
  }

  .footer-brand p{
    max-width:none;
    margin-bottom:24px;
  }

  .footer-modern h3{
    margin-bottom:14px;
  }

  .footer-column a{
    margin-bottom:11px;
  }

  .footer-modern .copyright{
    margin-top:30px;
  }
}



/* Homepage conversion-focused cleanup */
.compact-section{
  padding-top:72px;
  padding-bottom:72px;
}

.section-heading.narrow{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
  text-align:center;
}

.split-heading{
  display:grid;
  grid-template-columns:1fr minmax(280px,520px);
  gap:34px;
  align-items:end;
  margin-bottom:34px;
}

.split-heading p{
  margin:0;
  color:var(--muted);
  font-size:1.08rem;
  line-height:1.55;
}

.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

.step-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:24px;
  padding:28px;
  box-shadow:0 14px 34px rgba(0,0,0,.06);
}

.step-card span{
  width:48px;
  height:48px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:#fc5501;
  color:#000;
  font-weight:950;
  font-size:1.2rem;
  margin-bottom:18px;
}

.step-card h3{
  font-size:1.3rem;
  margin:0 0 8px;
}

.step-card p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

.service-preview-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}

.service-preview-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:24px;
  padding:24px;
  min-height:208px;
  box-shadow:0 14px 34px rgba(0,0,0,.05);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position:relative;
  overflow:hidden;
}

.service-preview-card::before{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  top:0;
  height:4px;
  border-radius:0 0 999px 999px;
  background:linear-gradient(90deg,var(--orange),rgba(252,85,1,.15));
}

.service-preview-card:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 42px rgba(0,0,0,.09);
  border-color:rgba(252,85,1,.35);
}

.service-preview-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:18px;
}

.service-preview-tag{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(252,85,1,.1);
  color:var(--orange);
  font-size:.78rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.service-preview-arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:50%;
  background:#111;
  color:#fff;
  font-size:1rem;
  font-weight:800;
  flex-shrink:0;
}

.service-preview-card h3{
  margin:0 0 10px;
  font-size:1.25rem;
}

.service-preview-card p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
}

.service-preview-note{
  margin-top:auto;
  padding-top:16px;
  color:#171717;
  font-weight:700;
  font-size:.95rem;
}

.cta-spacer{
  margin-top:30px;
}

.split-feature{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

.split-feature.reverse{
  grid-template-columns:.95fr 1.05fr;
}

.split-feature h2{
  font-size:clamp(2rem,4vw,4.4rem);
  line-height:.95;
  margin:12px 0 18px;
}

.split-feature p{
  color:var(--muted);
  font-size:1.08rem;
  line-height:1.6;
  margin:0 0 22px;
}

.feature-bullets{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:0 0 26px;
}

.feature-bullets span{
  position:relative;
  display:inline-flex;
  align-items:center;
  min-height:50px;
  background:linear-gradient(180deg,#fff 0%,#fff5ee 100%);
  border:1px solid rgba(252,85,1,.24);
  border-radius:999px;
  padding:12px 18px 12px 42px;
  font-weight:900;
  font-size:.95rem;
  color:#171717;
  box-shadow:0 12px 26px rgba(252,85,1,.10);
}

.feature-bullets span::before{
  content:"";
  position:absolute;
  left:16px;
  top:50%;
  width:11px;
  height:11px;
  border-radius:50%;
  background:var(--orange);
  transform:translateY(-50%);
  box-shadow:0 0 0 5px rgba(252,85,1,.12);
}

.mini-ba-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 20px 48px rgba(0,0,0,.10);
}


.compact-reviews{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.service-area-summary{
  max-width:920px;
  text-align:center;
}

.service-area-summary h2{
  font-size:clamp(2rem,4vw,4.4rem);
  line-height:.95;
  margin:12px 0 18px;
}

.service-area-summary p{
  color:var(--muted);
  font-size:1.08rem;
  line-height:1.65;
  margin:0 auto 26px;
  max-width:820px;
}

.rounded-feature-img{
  width:100%;
  height:460px;
  object-fit:cover;
  border-radius:28px;
  box-shadow:0 20px 48px rgba(0,0,0,.12);
  border:1px solid rgba(0,0,0,.08);
}

@media(max-width:980px){
  .split-heading,
  .split-feature,
  .split-feature.reverse{
    grid-template-columns:1fr;
  }

  .steps-grid,
  .service-preview-grid,
  .compact-reviews{
    grid-template-columns:1fr;
  }

  .mini-ba-images img{
    height:280px;
  }

  .rounded-feature-img{
    height:360px;
  }
}

@media(max-width:650px){
  .compact-section{
    padding-top:54px;
    padding-bottom:54px;
  }

  .split-heading{
    gap:12px;
    margin-bottom:24px;
  }

  .step-card,
  .service-preview-card{
    padding:22px;
    border-radius:20px;
  }

  .split-feature{
    gap:28px;
  }

  .mini-ba-images img{
    height:220px;
  }

  .rounded-feature-img{
    height:290px;
    border-radius:22px;
  }

  .feature-bullets span{
    width:100%;
    text-align:center;
  }
}

@media(max-width:650px){
  .hero-copy p{font-size:18px;margin-bottom:22px}
  .hero-proof{gap:8px}
  .hero-proof span{font-size:12px;padding:8px 12px}
  .hero-book-card--pop{padding:24px 22px;border-radius:26px}
  .hero-book-card--pop h2{font-size:40px}
  .btn-book-pop{min-height:64px;font-size:20px}
  .hero-card-chips span{font-size:12px;padding:9px 12px}
}


/* Premium EcoDump-inspired homepage refresh */
.hero{
  min-height:780px;
}
.hero-video{
  filter:brightness(1.03) saturate(1.03) contrast(1.02);
}
.hero-overlay{
  background:
    radial-gradient(circle at 22% 26%, rgba(252,85,1,.10), transparent 30%),
    linear-gradient(90deg, rgba(7,10,15,.78) 0%, rgba(7,10,15,.60) 46%, rgba(7,10,15,.34) 100%),
    linear-gradient(180deg, rgba(7,10,15,.34), rgba(7,10,15,.58));
}
.hero-grid{
  grid-template-columns:1.08fr .92fr;
  gap:56px;
}
.hero-copy{
  max-width:700px;
}
.hero-copy h1{
  max-width:760px;
  font-size:clamp(50px,7vw,92px);
  line-height:.92;
  letter-spacing:-.075em;
  margin-bottom:20px;
}
.hero-copy h1 span{
  color:var(--orange);
}
.hero-copy p{
  color:#e8ebef;
  font-size:21px;
  line-height:1.6;
  max-width:620px;
  margin:0 0 30px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.hero-actions .btn-large{
  min-height:62px;
  padding:18px 28px;
}
.hero-actions .btn-white{
  background:rgba(255,255,255,.92);
  border-color:rgba(255,255,255,.92);
}
.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:14px 18px;
  margin-top:28px;
}
.hero-meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#f8fafc;
  font-size:14px;
  font-weight:850;
  letter-spacing:.02em;
}
.hero-meta span::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--orange);
  box-shadow:0 0 0 5px rgba(252,85,1,.18);
}
.hero-book-card--premium{
  position:relative;
  justify-self:end;
  width:100%;
  max-width:560px;
  padding:42px 40px;
  border-radius:38px;
  background:linear-gradient(180deg, rgba(255,255,255,.985) 0%, rgba(255,255,255,.95) 100%);
  border:1px solid rgba(15,23,42,.08);
  border-top:5px solid var(--orange);
  box-shadow:0 30px 90px rgba(15,23,42,.22), 0 12px 34px rgba(252,85,1,.08);
}
.hero-book-card--premium h2{
  font-size:clamp(38px,4.7vw,62px);
  line-height:.94;
  letter-spacing:-.07em;
  margin:0 0 16px;
  color:#0f172a;
  text-transform:uppercase;
}
.hero-book-card--premium h2 span{
  color:var(--orange);
}
.hero-book-card--premium p{
  font-size:18px;
  line-height:1.6;
  color:#5b6473;
  margin:0 0 24px;
}
.btn-book-premium{
  width:100%;
  min-height:70px;
  border-radius:20px;
  font-size:18px;
  font-weight:950;
  box-shadow:0 18px 40px rgba(252,85,1,.22);
}
.hero-card-list{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.hero-card-list div{
  position:relative;
  padding:16px 16px 16px 58px;
  border-radius:20px;
  background:linear-gradient(90deg, rgba(252,85,1,.075) 0%, rgba(255,255,255,.96) 48%, #f7f7f4 100%);
  border:1px solid rgba(252,85,1,.20);
  border-left:5px solid var(--orange);
  box-shadow:0 10px 26px rgba(15,23,42,.06);
}
.hero-card-list div::before{
  position:absolute;
  left:17px;
  top:18px;
  width:28px;
  height:28px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:var(--orange);
  background:rgba(252,85,1,.12);
  font-size:16px;
  font-weight:950;
  box-shadow:inset 0 0 0 1px rgba(252,85,1,.20);
}
.hero-card-list div:nth-child(1)::before{content:"$";}
.hero-card-list div:nth-child(2)::before{content:"⚡";}
.hero-card-list div:nth-child(3)::before{content:"✓";}
.hero-card-list strong{
  display:block;
  color:#0f172a;
  font-size:13px;
  font-weight:950;
  letter-spacing:.09em;
  text-transform:uppercase;
}
.hero-card-list span{
  display:block;
  color:#5b6473;
  font-size:14px;
  line-height:1.45;
  margin-top:5px;
}
.hero-card-note{
  margin-top:18px;
  color:#4b5563;
  font-size:15px;
  font-weight:800;
}
.hero-card-note a{
  color:#111827;
  text-decoration:underline;
  text-underline-offset:3px;
}
.badge-strip-modern{
  background:#f5f5f1;
  padding:26px 0 28px;
}
.trust-pill{
  border-radius:22px;
  box-shadow:0 10px 28px rgba(15,23,42,.05);
}
.step-card,
.service-preview-card{
  border-radius:26px;
  box-shadow:0 12px 30px rgba(15,23,42,.05);
  border:1px solid rgba(15,23,42,.08);
}
.step-card{
  padding:30px;
}
.step-card span{
  border-radius:999px;
  box-shadow:0 10px 24px rgba(252,85,1,.18);
}
.service-preview-card{
  min-height:188px;
  padding:28px;
}
.service-preview-card h3{
  font-size:1.35rem;
  line-height:1.15;
}
.service-preview-card p,
.split-heading p,
.step-card p,
.service-area-summary p{
  color:#667085;
}
.section-heading h2,
.split-feature h2,
.service-area-summary h2{
  letter-spacing:-.07em;
}
@media(max-width:980px){
  .hero-grid{
    grid-template-columns:1fr;
    gap:28px;
  }
  .hero-book-card--premium{
    justify-self:start;
    max-width:100%;
  }
}
@media(max-width:650px){
  .hero{
    min-height:740px;
  }
  .hero-copy h1{
    font-size:48px;
  }
  .hero-copy p{
    font-size:18px;
  }
  .hero-actions{
    gap:10px;
  }
  .hero-actions .btn-large{
    width:100%;
    min-height:58px;
  }
  .hero-meta{
    gap:10px;
    margin-top:22px;
  }
  .hero-meta span{
    width:100%;
    font-size:13px;
  }
  .hero-book-card--premium{
    padding:28px 24px;
    border-radius:28px;
  }
  .hero-book-card--premium h2{
    font-size:42px;
  }
  .btn-book-premium{
    min-height:64px;
    font-size:17px;
  }
  .hero-card-list div{
    padding:13px 14px;
  }
}


@media (max-width: 768px){
  .service-preview-card{
    min-height:auto;
    padding:22px;
  }

  .service-preview-top{
    margin-bottom:16px;
  }

  .service-preview-tag{
    font-size:.73rem;
    padding:6px 10px;
  }

  .service-preview-note{
    font-size:.9rem;
    padding-top:14px;
  }
}


.results-showcase{
  background:linear-gradient(180deg,#fff7f1 0%, #fff 100%);
}

.results-showcase__grid{
  grid-template-columns:.92fr 1.08fr;
  gap:40px;
  align-items:center;
}

.results-showcase__copy{
  max-width:620px;
}

.results-showcase__copy .mini-kicker{
  margin-bottom:12px;
}

.results-showcase__copy h2{
  margin-top:0;
}

.results-showcase__copy p{
  max-width:560px;
  color:#4a5565;
}

.mini-ba-card--slider{
  background:#fff;
  border:1px solid rgba(252,85,1,.16);
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 22px 56px rgba(0,0,0,.10);
}

.mini-ba-card--slider .ba-compare{
  aspect-ratio:16 / 10;
}

.mini-ba-card--slider .ba-badge{
  background:rgba(17,17,17,.82);
}

.mini-ba-copy{
  padding:24px 24px 26px;
  background:linear-gradient(180deg,#fff 0%, #fff8f4 100%);
  border-top:1px solid rgba(252,85,1,.10);
}

.mini-ba-copy span{
  display:inline-flex;
  align-items:center;
  padding:7px 12px;
  border-radius:999px;
  margin-bottom:14px;
  background:rgba(252,85,1,.10);
  color:var(--orange);
  font-size:.76rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.mini-ba-copy h3{
  margin:0 0 10px;
  font-size:1.7rem;
  line-height:1.05;
  color:var(--black);
}

.mini-ba-copy p{
  margin:0 0 18px;
  color:#495264;
  font-size:1rem;
  line-height:1.6;
}

@media(max-width:980px){
  .results-showcase__grid{
    grid-template-columns:1fr;
  }

  .results-showcase__copy{
    max-width:none;
  }
}

@media(max-width:640px){
  .results-showcase{
    background:linear-gradient(180deg,#fff7f1 0%, #fff 92%);
  }

  .mini-ba-card--slider{
    border-radius:24px;
  }

  .mini-ba-copy{
    padding:20px 20px 22px;
  }

  .mini-ba-copy h3{
    font-size:1.35rem;
  }
}



/* Localized city service cards */
.city-service-grid .service-preview-note{
  color:#111;
  font-weight:900;
}

.city-service-grid .service-preview-card h3{
  line-height:1.15;
}



/* City page image caption cleanup */
.service-areas-page .image-caption,
.service-areas-page .photo-caption,
.service-areas-page .project-caption,
.service-areas-page figcaption,
.city-photo-card .caption,
.project-photo-card .caption,
.media-card .caption,
.image-card .caption,
.photo-card .caption{
  display:none !important;
}


/* City page image cleanup and fit */
.city-page-photo-card{
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
}

.city-page-photo{
  display:block;
  width:100%;
  height:460px;
  object-fit:cover;
  object-position:center;
  border-radius:28px;
}

@media(max-width:980px){
  .city-page-photo{
    height:360px;
  }
}

@media(max-width:650px){
  .city-page-photo{
    height:300px;
  }
}



/* Appointment request form */
.nav-cta{
  background:var(--orange);
  color:#111 !important;
  padding:11px 16px;
  border-radius:999px;
  font-weight:950 !important;
}

.appointment-hero{
  background:linear-gradient(135deg,#111 0%,#1d1d1d 58%,#fc5501 160%);
  color:#fff;
}

.appointment-hero p{
  color:rgba(255,255,255,.82);
}

.appointment-section{
  background:#f6f6f2;
}

.appointment-grid{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(300px,.55fr);
  gap:28px;
  align-items:start;
}

.appointment-card,
.side-panel{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:28px;
  box-shadow:0 18px 48px rgba(0,0,0,.08);
}

.appointment-card{
  padding:30px;
}

.appointment-form{
  display:grid;
  gap:22px;
}

.hidden-field{
  display:none;
}

.form-section-title{
  display:flex;
  align-items:flex-start;
  gap:14px;
  margin-top:6px;
}

.form-section-title span{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:var(--orange);
  color:#111;
  font-weight:950;
  flex-shrink:0;
}

.form-section-title h2{
  margin:0 0 6px;
  font-size:1.45rem;
  line-height:1.15;
}

.form-section-title p{
  margin:0;
  color:#667085;
  line-height:1.5;
}

.form-grid{
  display:grid;
  gap:16px;
}

.form-grid.two{
  grid-template-columns:repeat(2,minmax(0,1fr));
}

.appointment-form label{
  display:grid;
  gap:8px;
  font-weight:900;
  color:#111827;
}

.appointment-form label strong{
  color:var(--orange);
}

.appointment-form input,
.appointment-form select,
.appointment-form textarea{
  width:100%;
  border:1px solid rgba(17,24,39,.16);
  border-radius:16px;
  padding:15px 16px;
  font:inherit;
  background:#fff;
  color:#111827;
  outline:none;
}

.appointment-form textarea{
  resize:vertical;
}

.appointment-form input:focus,
.appointment-form select:focus,
.appointment-form textarea:focus{
  border-color:var(--orange);
  box-shadow:0 0 0 4px rgba(252,85,1,.14);
}

.appointment-form small{
  color:#667085;
  font-weight:700;
  line-height:1.45;
}

.consent-check{
  display:flex !important;
  grid-template-columns:auto 1fr;
  align-items:flex-start;
  gap:12px !important;
  padding:16px;
  border-radius:18px;
  background:#fff7f1;
  border:1px solid rgba(252,85,1,.20);
}

.consent-check input{
  width:20px;
  height:20px;
  margin-top:2px;
  flex-shrink:0;
}

.consent-check span{
  font-weight:750;
  line-height:1.5;
  color:#374151;
}

.form-disclaimer{
  margin:0;
  color:#667085;
  font-size:.95rem;
  line-height:1.55;
}

.form-disclaimer a,
.legal-content a{
  color:var(--orange);
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px;
}

.appointment-side{
  position:sticky;
  top:110px;
}

.side-panel{
  padding:28px;
}

.side-panel h2{
  margin:10px 0 12px;
  font-size:2rem;
  line-height:1.05;
  letter-spacing:-.04em;
}

.side-panel p{
  color:#667085;
  line-height:1.6;
}

.side-panel ul{
  padding-left:18px;
  margin:18px 0 24px;
  color:#374151;
  font-weight:800;
  line-height:1.7;
}

.legal-content{
  max-width:920px;
}

.legal-content h2{
  margin:34px 0 10px;
  font-size:1.45rem;
}

.legal-content p{
  color:#374151;
  line-height:1.75;
}

@media(max-width:900px){
  .appointment-grid{
    grid-template-columns:1fr;
  }

  .appointment-side{
    position:static;
  }
}

@media(max-width:650px){
  .appointment-card,
  .side-panel{
    border-radius:22px;
    padding:22px;
  }

  .form-grid.two{
    grid-template-columns:1fr;
  }

  .form-section-title{
    gap:12px;
  }

  .form-section-title h2{
    font-size:1.2rem;
  }

  .nav-cta{
    display:inline-flex;
    justify-content:center;
  }
}



/* Book Now menu item */
.desktop-nav a[href$="request-appointment.html"],
.mobile-nav a[href$="request-appointment.html"]{
  color:var(--orange);
}



/* Booking/header cleanup */
.site-header .nav{
  min-height:86px;
  gap:22px;
}

.site-header .brand img{
  max-height:74px;
  width:auto;
}

.main-nav,
.desktop-nav{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:22px;
  flex-wrap:nowrap;
  white-space:nowrap;
}

.main-nav a,
.desktop-nav a{
  font-size:clamp(13px, .95vw, 15px);
  line-height:1;
  letter-spacing:.06em;
}

.nav-cta,
.desktop-nav a[href$="request-appointment.html"],
.mobile-nav a[href$="request-appointment.html"]{
  background:var(--orange);
  color:#111 !important;
  padding:12px 18px;
  border-radius:999px;
  font-weight:950 !important;
}

@media (max-width: 1200px){
  .main-nav,
  .desktop-nav{
    gap:14px;
  }

  .main-nav a,
  .desktop-nav a{
    font-size:13px;
  }

  .site-header .brand img{
    max-height:64px;
  }

  .nav-cta,
  .desktop-nav a[href$="request-appointment.html"]{
    padding:10px 14px;
  }
}

@media (max-width: 980px){
  .main-nav,
  .desktop-nav{
    display:none;
  }

  .menu-toggle{
    display:flex;
  }

  .site-header .brand img{
    max-height:62px;
  }
}

/* Keep required asterisks inline with labels */
.appointment-form label{
  display:block;
  font-weight:900;
  color:#111827;
}

.appointment-form label .required-star{
  color:var(--orange);
  font-weight:950;
  margin-left:4px;
}

.appointment-form label input,
.appointment-form label select,
.appointment-form label textarea{
  margin-top:8px;
}

.appointment-form label small{
  display:block;
  margin-top:8px;
}

.consent-check{
  display:flex !important;
}

.consent-check .required-star{
  margin-left:4px;
}

/* Make booking page header match the rest of the site instead of oversized logo layout */
.request-appointment-page .site-header,
body:has(form[name="appointment-request"]) .site-header{
  position:relative;
}

.request-appointment-page .promo-bar,
body:has(form[name="appointment-request"]) .promo-bar{
  font-size:14px;
}

/* Mobile refinement for premium quote/trust card */
@media(max-width:650px){
  .hero-book-card--premium{
    padding:24px 20px 26px;
    border-radius:28px;
  }

  .hero-book-card--premium p{
    font-size:17px;
    line-height:1.55;
    margin-bottom:20px;
  }

  .btn-book-premium{
    min-height:60px;
    border-radius:18px;
    font-size:16px;
    margin-bottom:16px;
  }

  .hero-card-list{
    gap:12px;
    margin-top:16px;
  }

  .hero-card-list div{
    padding:18px 16px 18px 62px !important;
    border-radius:22px;
    border-left-width:5px;
  }

  .hero-card-list div::before{
    left:18px;
    top:18px;
    width:28px;
    height:28px;
    font-size:15px;
  }

  .hero-card-list strong{
    font-size:13px;
    line-height:1.2;
    letter-spacing:.08em;
  }

  .hero-card-list span{
    font-size:15px;
    line-height:1.4;
    margin-top:7px;
  }

  .hero-card-note{
    margin-top:20px;
    font-size:16px;
    line-height:1.4;
  }
}

@media(max-width:390px){
  .hero-book-card--premium{
    padding:22px 18px 24px;
  }

  .hero-card-list div{
    padding:17px 14px 17px 58px !important;
  }

  .hero-card-list div::before{
    left:16px;
    top:18px;
    width:26px;
    height:26px;
  }

  .hero-card-list span{
    font-size:14px;
  }
}

/* Hero above-the-fold optimization */
@media (min-width:1081px){
  .promo-banner__inner{min-height:34px;padding:4px 0;}
  .promo-message{font-size:14px;}
  .promo-close{font-size:24px;width:24px;height:24px;}
  .top-strip__inner{min-height:34px;}
  .site-header .nav{min-height:74px;}
  .logo-link img{width:190px;}
  .desktop-nav{gap:18px;font-size:13px;}
  .nav-actions .btn{min-height:44px;padding:11px 18px;font-size:13px;}
  .hero{min-height:calc(100vh - 142px);}
  .hero-grid{min-height:calc(100vh - 142px);padding:44px 0 46px;gap:44px;}
  .hero-copy h1{font-size:clamp(48px,5.8vw,78px);line-height:.92;margin-bottom:16px;}
  .hero-copy p{font-size:18px;line-height:1.55;margin-bottom:22px;max-width:610px;}
  .hero-actions .btn-large{min-height:54px;padding:15px 24px;}
  .hero-meta{margin-top:20px;gap:10px 16px;}
  .hero-meta span{font-size:13px;}
  .hero-book-card--premium{max-width:520px;padding:30px 32px;border-radius:32px;}
  .hero-card-kicker{margin-bottom:12px;font-size:12px;}
  .hero-book-card--premium h2{font-size:clamp(34px,3.8vw,52px);margin-bottom:12px;}
  .hero-book-card--premium p{font-size:16px;line-height:1.5;margin-bottom:18px;}
  .btn-book-premium{min-height:58px;border-radius:18px;font-size:16px;}
  .hero-card-list{gap:10px;margin-top:16px;}
  .hero-card-list div{padding:12px 14px 12px 52px;border-radius:18px;}
  .hero-card-list div::before{left:16px;top:13px;width:26px;height:26px;font-size:14px;}
  .hero-card-list strong{font-size:12px;letter-spacing:.08em;}
  .hero-card-list span{font-size:13px;line-height:1.35;margin-top:4px;}
  .hero-card-note{margin-top:14px;font-size:14px;}
}

@media (max-width:650px){
  .hero{min-height:auto;}
  .hero-grid{min-height:auto;padding:34px 0 46px;gap:24px;align-content:start;}
  .hero-copy h1{font-size:clamp(40px,13vw,54px);line-height:.92;margin-bottom:14px;}
  .hero-copy p{font-size:17px;line-height:1.48;margin-bottom:20px;}
  .hero-actions{gap:10px;}
  .hero-actions .btn-large{min-height:56px;}
  .hero-meta{margin-top:18px;gap:10px;}
  .hero-meta span{font-size:12px;}
  .hero-book-card--premium{padding:24px 20px 26px;border-radius:26px;}
  .hero-card-kicker{font-size:12px;margin-bottom:10px;}
  .hero-book-card--premium h2{font-size:clamp(34px,11vw,44px);line-height:.96;margin-bottom:12px;}
  .hero-book-card--premium p{font-size:16px;line-height:1.48;margin-bottom:18px;}
  .btn-book-premium{min-height:58px;border-radius:18px;font-size:15px;}
  .hero-card-list{gap:10px;margin-top:16px;}
  .hero-card-list div{padding:13px 14px 13px 54px;border-radius:18px;}
  .hero-card-list div::before{left:16px;top:14px;width:27px;height:27px;font-size:14px;}
  .hero-card-list strong{font-size:12px;letter-spacing:.08em;}
  .hero-card-list span{font-size:14px;line-height:1.35;margin-top:3px;}
  .hero-card-note{font-size:14px;margin-top:14px;}
}

/* Mobile hero CTA cleanup: avoid bottom sticky buttons overlapping the first-screen hero actions */
@media (max-width:650px){
  body{
    padding-bottom:calc(104px + env(safe-area-inset-bottom));
  }

  .hero{
    padding-bottom:18px;
  }

  .hero-actions{
    display:none;
  }

  .hero-copy{
    padding-bottom:4px;
  }

  .hero-meta{
    margin-top:18px;
    display:grid;
    gap:8px;
  }

  .hero-meta span{
    display:flex;
    align-items:center;
    gap:8px;
    padding:0;
    background:transparent;
    border:0;
    color:rgba(255,255,255,.88);
  }

  .sticky-actions{
    left:16px;
    right:16px;
    bottom:calc(14px + env(safe-area-inset-bottom));
    gap:10px;
    z-index:120;
  }

  .sticky-actions a{
    min-height:54px;
    padding:13px 10px;
    font-size:15px;
    box-shadow:0 12px 30px rgba(0,0,0,.22);
  }
}

@media (max-width:390px){
  .sticky-actions{
    left:12px;
    right:12px;
    gap:8px;
  }

  .sticky-actions a{
    font-size:14px;
    min-height:52px;
  }
}

/* Mobile floating CTA buttons: cleaner than full-width sticky bar */
@media (max-width:650px){
  body{
    padding-bottom:calc(76px + env(safe-area-inset-bottom));
  }

  .sticky-actions{
    left:auto;
    right:18px;
    bottom:calc(18px + env(safe-area-inset-bottom));
    width:auto;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:10px;
    z-index:120;
    pointer-events:none;
  }

  .sticky-actions a{
    pointer-events:auto;
    flex:0 0 auto;
    box-shadow:0 16px 34px rgba(0,0,0,.25);
    border:2px solid rgba(255,255,255,.92);
  }

  .sticky-actions a:first-child{
    order:2;
    width:62px;
    height:62px;
    min-height:62px;
    padding:0;
    border-radius:999px;
    font-size:0;
    display:flex;
    align-items:center;
    justify-content:center;
    background:var(--orange);
    color:var(--black);
  }

  .sticky-actions a:first-child::before{
    content:"☎";
    font-size:28px;
    line-height:1;
    transform:translateY(-1px);
  }

  .sticky-actions a:last-child{
    order:1;
    width:auto;
    min-height:46px;
    padding:12px 18px;
    border-radius:999px;
    background:var(--white);
    color:var(--black);
    font-size:13px;
    letter-spacing:.04em;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:8px;
  }

  .sticky-actions a:last-child::before{
    content:"💬";
    font-size:16px;
    line-height:1;
  }
}

@media (max-width:390px){
  .sticky-actions{
    right:14px;
    bottom:calc(14px + env(safe-area-inset-bottom));
  }

  .sticky-actions a:first-child{
    width:58px;
    height:58px;
    min-height:58px;
  }

  .sticky-actions a:last-child{
    min-height:44px;
    padding:11px 15px;
    font-size:12px;
  }
}


/* Thank-you page mobile actions: keep confirmation buttons visible on phones */
@media (max-width:650px){
  .thank-you-page{
    padding-bottom:calc(34px + env(safe-area-inset-bottom));
  }

  .thank-you-page .page-hero{
    padding:64px 0 58px;
    min-height:calc(100vh - 118px);
    display:flex;
    align-items:center;
  }

  .thank-you-page .page-hero h1{
    font-size:clamp(40px,12vw,56px);
    line-height:.96;
    margin-bottom:18px;
  }

  .thank-you-page .page-hero p{
    font-size:18px;
    line-height:1.55;
    margin-bottom:26px;
  }

  .thank-you-page .hero-actions{
    display:flex !important;
    flex-direction:column;
    gap:12px;
    width:100%;
  }

  .thank-you-page .hero-actions .btn-large{
    width:100%;
    min-height:58px;
    border-radius:18px;
    padding:16px 22px;
    font-size:15px;
  }
}
