/* ==========================================================================
   Lynch Haul — Consolidated Design System
   Merged from the homepage, trailer-rental, junk-hauling and storm-debris
   mockups. Class names are kept VERBATIM from the mockups.
   ========================================================================== */

/* ----- Self-hosted fonts (drop .woff2 files in assets/fonts/) ----- */
@font-face{font-family:'Barlow Semi Condensed';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/barlow-semi-condensed-600.woff2') format('woff2')}
@font-face{font-family:'Barlow Semi Condensed';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/barlow-semi-condensed-700.woff2') format('woff2')}
@font-face{font-family:'Barlow Semi Condensed';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/barlow-semi-condensed-800.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/inter-400.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/inter-500.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/inter-600.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/inter-700.woff2') format('woff2')}

/* ----- Design tokens ----- */
:root{
  --navy:#14304F;
  --navy-deep:#0E2238;
  --amber:#F2A100;
  --amber-hover:#D98C00;
  --charcoal:#1B2026;
  --slate:#5B6670;
  --light:#F5F7FA;
  --white:#FFFFFF;
  --green:#1E7A3D;
  --line:#E2E7EE;
  --shadow-sm:0 1px 3px rgba(20,48,79,.08), 0 1px 2px rgba(20,48,79,.06);
  --shadow-md:0 6px 18px rgba(20,48,79,.10);
  --shadow-lg:0 18px 50px rgba(20,48,79,.18);
  --radius:16px;
  --radius-sm:10px;
  --maxw:1180px;
}

/* ----- Base typography (scoped so we don't fight GeneratePress globals) ----- */
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--charcoal);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
html{scroll-behavior:smooth}
h1,h2,h3,h4,.display{font-family:'Barlow Semi Condensed','Inter',sans-serif;line-height:1.05;letter-spacing:-.01em}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:'Barlow Semi Condensed';font-weight:700;text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:var(--amber)}
.muted{color:var(--slate)}

/* Focus states */
a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:6px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:'Inter';font-weight:700;font-size:1rem;padding:.85rem 1.4rem;border-radius:50px;border:2px solid transparent;cursor:pointer;transition:transform .12s ease,background .15s ease,box-shadow .15s ease;white-space:nowrap;text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-amber{background:var(--amber);color:var(--navy);box-shadow:0 6px 16px rgba(242,161,0,.32)}
.btn-amber:hover{background:var(--amber-hover);color:var(--navy)}
.btn-navy{background:var(--navy);color:var(--white)}
.btn-navy:hover{background:var(--navy-deep);color:var(--white)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--navy);background:var(--light)}
.btn-ghost-light{background:transparent;color:var(--white);border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{border-color:var(--white);background:rgba(255,255,255,.08)}
.btn-lg{font-size:1.08rem;padding:1rem 1.7rem}

/* Top bar (injected via generate_before_header) */
.topbar{background:var(--navy-deep);color:#D6E0EC;font-size:.86rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.5rem;padding-bottom:.5rem}
.topbar a{font-weight:600;color:var(--white);text-decoration:none}
.topbar a:hover{color:var(--amber)}
.topbar .trust{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.topbar .dot{opacity:.5}

/* ----- Header / sticky nav -----
   GeneratePress outputs the header as <header id="masthead">. We make it
   sticky and add a .scrolled shadow class via site.js. We also style the
   CTAs injected into the nav via generate_menu_bar_items. */
.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:50;background:var(--white);border-bottom:1px solid var(--line);transition:box-shadow .2s ease}
.site-header.scrolled{box-shadow:0 4px 20px rgba(20,48,79,.10)}

/* Lynch Haul brand wordmark + mark (used in GP site title / footer) */
.brand{display:flex;align-items:center;gap:.6rem;font-family:'Barlow Semi Condensed';font-weight:800;font-size:1.5rem;color:var(--navy);letter-spacing:-.01em;text-decoration:none}
.brand .mark{width:38px;height:38px;flex:none}

/* Header CTA cluster injected into GP nav */
.lh-nav-cta{display:flex;align-items:center;gap:.7rem;flex:none}
.nav-phone{display:flex;align-items:center;gap:.45rem;font-weight:700;color:var(--navy);font-size:1rem;text-decoration:none}
.nav-phone svg{flex:none}

/* Original mockup nav-link underline animation (applies if GP menu items used) */
.nav-links a,.main-navigation .menu-item a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--amber);transition:width .18s ease}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--navy)}
.nav-links a.active::after{width:100%}
.mobile-menu a.active{color:var(--navy);background:var(--light)}

/* Hero */
.hero{background:radial-gradient(1100px 540px at 78% -8%, #1d4068 0%, var(--navy) 48%, var(--navy-deep) 100%);color:var(--white);position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:linear-gradient(120deg,#000,transparent 70%);mask-image:linear-gradient(120deg,#000,transparent 70%);opacity:.6}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.08fr .92fr;gap:3rem;align-items:center;padding-top:4.2rem;padding-bottom:4.6rem}
.hero .eyebrow{color:var(--amber)}
.hero h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:800;margin:.7rem 0 1rem;color:var(--white)}
.hero h1 .hl{color:var(--amber)}
.hero p.sub{font-size:1.18rem;color:#CDD8E6;max-width:33rem;margin-bottom:1.6rem}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.7rem}
.trust-row{display:flex;gap:.5rem 1.3rem;flex-wrap:wrap;align-items:center;font-size:.92rem;color:#CDD8E6;font-weight:500}
.trust-row span{display:inline-flex;align-items:center;gap:.45rem}
.trust-row svg{color:var(--amber)}
.price-chip{position:absolute;top:1.4rem;right:1.4rem;background:var(--amber);color:var(--navy);font-family:'Barlow Semi Condensed';font-weight:800;font-size:1.05rem;padding:.55rem 1rem;border-radius:50px;box-shadow:var(--shadow-md);z-index:3;display:flex;align-items:center;gap:.4rem}
.hero-media{position:relative}
.ph{position:relative;background:linear-gradient(150deg,#234a72,#14304F 60%,#0E2238);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#A9BBD0;border:1px solid rgba(255,255,255,.08);overflow:hidden}
.ph::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:30px 30px;opacity:.4}
.ph .ph-ic{color:rgba(242,161,0,.85);margin-bottom:.7rem;position:relative;z-index:1}
.ph .ph-label{position:relative;z-index:1;font-size:.82rem;font-weight:600;letter-spacing:.02em;padding:0 1rem;max-width:90%}
.ph .ph-tag{position:absolute;top:.7rem;left:.7rem;background:rgba(255,255,255,.12);color:#fff;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.22rem .55rem;border-radius:6px;z-index:2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.hero-media .ph{height:380px}

/* Sections */
section{padding:4.6rem 0}
.sec-head{text-align:center;max-width:46rem;margin:0 auto 2.6rem}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:800;color:var(--navy);margin:.5rem 0 .6rem}
.sec-head p{font-size:1.08rem;color:var(--slate)}
.bg-light{background:var(--light)}
.bg-navy{background:var(--navy);color:var(--white)}
.bg-navy h2{color:var(--white)}

/* Service cards */
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.svc-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .15s ease,box-shadow .15s ease}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.svc-card .ph{height:210px;border-radius:0}
.svc-body{padding:1.6rem 1.7rem 1.8rem}
.svc-body .price{display:inline-block;background:var(--light);color:var(--navy);font-weight:700;font-size:.85rem;padding:.3rem .75rem;border-radius:50px;margin-bottom:.7rem}
.svc-body h3{font-size:1.7rem;font-weight:800;color:var(--navy);margin-bottom:.6rem}
.svc-body>p{color:var(--slate);margin-bottom:1rem}
.blist{list-style:none;margin:0 0 1.4rem}
.blist li{display:flex;gap:.6rem;align-items:flex-start;padding:.35rem 0;font-weight:500}
.blist svg{color:var(--green);flex:none;margin-top:3px}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.step{text-align:center;padding:1.6rem 1.2rem;position:relative}
.step .num{width:62px;height:62px;border-radius:50%;background:var(--navy);color:var(--amber);font-family:'Barlow Semi Condensed';font-weight:800;font-size:1.6rem;display:flex;align-items:center;justify-content:center;margin:0 auto .9rem;box-shadow:var(--shadow-md)}
.step .step-ic{color:var(--navy);margin:0 auto .6rem;display:flex;justify-content:center}
.step h3{font-size:1.3rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.step p{color:var(--slate);font-size:.98rem}
.step:not(:last-child)::after{content:"";position:absolute;top:54px;right:-1rem;width:2rem;height:2px;background:repeating-linear-gradient(90deg,var(--amber) 0 6px,transparent 6px 12px)}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;align-items:stretch}
.price-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.price-card.feature{border:2px solid var(--amber);position:relative}
.price-card.feature .badge{position:absolute;top:-13px;left:2rem;background:var(--amber);color:var(--navy);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;padding:.28rem .7rem;border-radius:50px}
.price-card h3{font-size:1.5rem;font-weight:800;color:var(--navy);margin-bottom:.2rem}
.price-card .amt{font-family:'Barlow Semi Condensed';font-weight:800;font-size:3rem;color:var(--navy);line-height:1;margin:.5rem 0}
.price-card .amt small{font-size:1rem;font-weight:600;color:var(--slate)}
.price-card .sublabel{color:var(--slate);font-size:.95rem;margin-bottom:1.1rem}
.incl{list-style:none;margin:.4rem 0 1.4rem}
.incl li{display:flex;gap:.6rem;align-items:flex-start;padding:.4rem 0;border-bottom:1px solid var(--line);font-weight:500;font-size:.97rem}
.incl li:last-child{border-bottom:none}
.incl svg{color:var(--green);flex:none;margin-top:3px}
.incl li svg[stroke="currentColor"]{color:var(--green)}
.fineprint{font-size:.84rem;color:var(--slate);margin-top:auto}

.tiers{display:flex;gap:1rem;margin:.4rem 0 1.3rem}
.tier{flex:1;text-align:center;background:var(--light);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.1rem .5rem;transition:transform .12s ease}
.tier:hover{transform:translateY(-3px)}
.tier .bar{height:54px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:.6rem}
.tier .fill{width:30px;background:var(--amber);border-radius:6px 6px 0 0}
.tier:nth-child(1) .fill{height:30%}
.tier:nth-child(2) .fill{height:62%}
.tier:nth-child(3) .fill{height:100%}
.tier strong{display:block;font-family:'Barlow Semi Condensed';font-weight:700;color:var(--navy);font-size:1.1rem}
.tier span{font-size:.82rem;color:var(--slate)}
.text-callout{background:var(--navy);color:var(--white);border-radius:var(--radius-sm);padding:1.1rem 1.3rem;display:flex;align-items:center;gap:1rem;margin-top:auto}
.text-callout svg{color:var(--amber);flex:none}
.text-callout strong{font-family:'Barlow Semi Condensed';font-size:1.15rem;font-weight:700;display:block}
.text-callout span{font-size:.88rem;color:#CDD8E6}
.text-callout a{color:var(--amber);font-weight:700}

/* Comparison */
.compare{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--line)}
.compare-row{display:grid;grid-template-columns:1.6fr 1fr 1fr;align-items:center}
.compare-row+.compare-row{border-top:1px solid var(--line)}
.compare-row>div{padding:1rem 1.2rem}
.compare-head{background:var(--navy);color:var(--white)}
.compare-head>div{font-family:'Barlow Semi Condensed';font-weight:700;font-size:1.05rem;text-align:center}
.compare-head>div:first-child{text-align:left;font-size:1.15rem}
.compare-head .us{background:var(--amber);color:var(--navy);border-radius:0}
.compare-row .feat{font-weight:600}
.compare-row .cell{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.2rem;font-size:.86rem}
.compare-row .cell.us{background:#FBF4E3}
.compare-row .cell .yes{color:var(--green)}
.compare-row .cell .no{color:#B23A3A}
.compare-row .cell .meh{color:var(--slate)}
.ck{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.ck.yes{background:rgba(30,122,61,.12);color:var(--green)}
.ck.no{background:rgba(178,58,58,.10);color:#B23A3A}
.ck.meh{background:rgba(91,102,112,.12);color:var(--slate)}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.gallery .ph{height:200px}

/* Reviews */
.rev-head{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:.5rem}
.rev-score{font-family:'Barlow Semi Condensed';font-weight:800;font-size:2.4rem;color:var(--navy);line-height:1}
.stars{color:var(--amber);font-size:1.4rem;letter-spacing:2px}
.rev-note{text-align:center;font-size:.82rem;color:var(--slate);font-style:italic;margin-bottom:2.2rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.rev-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm)}
.rev-card .stars{font-size:1.05rem;margin-bottom:.7rem}
.rev-card p{font-size:.97rem;margin-bottom:1.1rem}
.rev-who{display:flex;align-items:center;gap:.7rem}
.rev-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(150deg,#234a72,#14304F);color:var(--amber);display:flex;align-items:center;justify-content:center;font-family:'Barlow Semi Condensed';font-weight:700;flex:none}
.rev-who strong{font-size:.95rem;color:var(--navy)}
.rev-who span{font-size:.8rem;color:var(--slate)}

/* Service area */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:.7rem;margin:1.2rem 0}
.chip{display:inline-flex;align-items:center;gap:.45rem;background:var(--white);border:1px solid var(--line);color:var(--navy);font-weight:600;padding:.55rem 1rem;border-radius:50px;box-shadow:var(--shadow-sm)}
.chip svg{color:var(--amber)}
.chip.primary{background:var(--navy);color:var(--white);border-color:var(--navy)}
.area-grid .ph{height:320px}

/* About */
.about-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:2.6rem;align-items:center}
.about-grid .ph{height:400px}
.about-grid .sig{font-family:'Barlow Semi Condensed';font-weight:700;color:var(--navy);font-size:1.2rem;margin-top:1.2rem}
.about-grid .sig span{display:block;font-family:'Inter';font-weight:500;font-size:.9rem;color:var(--slate)}

/* Final CTA */
.final{background:linear-gradient(120deg,var(--navy) 0%,var(--navy-deep) 100%);color:var(--white);text-align:center}
.final h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:.7rem;color:var(--white)}
.final p{font-size:1.15rem;color:#CDD8E6;margin-bottom:1.6rem}
.final-phone{font-family:'Barlow Semi Condensed';font-weight:800;font-size:2rem;color:var(--amber);display:inline-block;margin-bottom:1.4rem}
.final-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ==========================================================================
   PAGE-SPECIFIC SECTIONS (trailer rental, junk hauling, storm debris)
   ========================================================================== */

/* Feature grid ("What you get") — trailer page */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.feat-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.6rem;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feat-card h3{font-size:1.25rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.feat-card p{color:var(--slate);font-size:.97rem}
.feat-card .tagflag{display:inline-block;margin-top:.7rem;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--amber-hover);background:#FBF4E3;padding:.2rem .55rem;border-radius:50px}
.feat-ic{width:54px;height:54px;border-radius:14px;background:var(--light);color:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}

/* Two-column media row — trailer page */
.media-row{display:grid;grid-template-columns:1.05fr .95fr;gap:2.6rem;align-items:center}
.media-row h2{font-size:clamp(1.8rem,3.4vw,2.5rem);color:var(--navy);margin:.5rem 0 .8rem;text-align:left}
.media-row .ph{height:360px}
.media-row.flip .copy{order:2}

/* Fits / weight — trailer page */
.fits-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;align-items:stretch}
.fits-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem;box-shadow:var(--shadow-sm)}
.fits-card.heavy{border-top:5px solid var(--amber)}
.fits-card.light{border-top:5px solid var(--green)}
.fits-card h3{font-size:1.35rem;font-weight:800;color:var(--navy);margin-bottom:.3rem;display:flex;align-items:center;gap:.55rem}
.fits-card .lead{color:var(--slate);font-size:.97rem;margin-bottom:1rem}
.gauge{height:12px;border-radius:50px;background:var(--line);overflow:hidden;margin:.3rem 0 .5rem}
.gauge i{display:block;height:100%;border-radius:50px}
.gauge.hv i{width:92%;background:var(--amber)}
.gauge.lt i{width:34%;background:var(--green)}
.gauge-cap{font-size:.84rem;color:var(--slate);font-weight:600}
.tag-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}
.tag-list span{background:var(--light);border:1px solid var(--line);color:var(--navy);font-weight:600;font-size:.85rem;padding:.4rem .8rem;border-radius:50px}

/* Who rents — trailer page */
.who-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.who-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.who-card .ph{height:190px;border-radius:0}
.who-body{padding:1.7rem 1.8rem 1.9rem}
.who-body h3{font-size:1.5rem;font-weight:800;color:var(--navy);margin-bottom:.5rem}
.who-body>p{color:var(--slate);margin-bottom:1rem}
.who-body .contractor-link{display:inline-flex;align-items:center;gap:.45rem;font-weight:700;color:var(--navy);border-bottom:2px solid var(--amber);padding-bottom:2px;margin-top:.3rem}
.who-body .contractor-link:hover{color:var(--amber-hover)}
.who-body .contractor-link svg{flex:none}

/* FAQ accordion (native <details>) — trailer page */
.faq{max-width:50rem;margin:0 auto}
.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:.8rem;box-shadow:var(--shadow-sm);overflow:hidden}
.faq details[open]{border-color:var(--amber)}
.faq summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;font-family:'Barlow Semi Condensed';font-weight:700;font-size:1.12rem;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q-ic{flex:none;width:28px;height:28px;border-radius:50%;background:var(--light);color:var(--navy);display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease}
.faq details[open] summary .q-ic{transform:rotate(45deg);background:var(--amber)}
.faq .faq-body{padding:0 1.4rem 1.25rem;color:var(--slate);font-size:.98rem}
.faq .faq-body strong{color:var(--charcoal)}

/* Can't-take callout — trailer page (navy variant) */
.cant{background:var(--navy);color:#CDD8E6;border-radius:var(--radius);padding:1.7rem 1.9rem;margin-top:1.6rem}
.cant h3{color:#fff;font-size:1.2rem;font-weight:700;margin-bottom:.3rem;display:flex;align-items:center;gap:.55rem}
.cant h3 svg{color:var(--amber)}
.cant p.sub{color:#9FB2C8;font-size:.92rem;margin-bottom:1rem}
.cant-list{display:flex;flex-wrap:wrap;gap:.55rem}
.cant-list span{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#E2E9F2;font-weight:500;font-size:.86rem;padding:.4rem .8rem;border-radius:50px}
.cant-list span svg{color:#E08A8A;flex:none}
.cant .note{margin-top:1rem;font-size:.82rem;color:#9FB2C8}

/* Add-on row — trailer page */
.addon{display:flex;align-items:flex-start;gap:.7rem;background:var(--light);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem 1.1rem;margin:.2rem 0 1.2rem}
.addon svg{color:var(--navy);flex:none;margin-top:2px}
.addon strong{display:block;color:var(--navy);font-size:1rem}
.addon span{font-size:.9rem;color:var(--slate)}

/* No-hidden-fees badge — trailer page */
.nohidden{display:flex;align-items:center;gap:.6rem;background:rgba(30,122,61,.08);color:var(--green);font-weight:700;font-size:.92rem;padding:.7rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.2rem}
.nohidden svg{flex:none}

/* ----- Junk Hauling page ----- */

/* Cant-take callout (light/white variant on junk page) */
.cant.light,.cant--light{background:var(--white);color:var(--slate);border:1px solid var(--line);border-left:4px solid var(--amber);border-radius:var(--radius);padding:1.5rem 1.7rem;margin-top:1.8rem;box-shadow:var(--shadow-sm)}
.cant.light h3,.cant--light h3{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:.6rem;display:flex;align-items:center;gap:.55rem}
.cant.light h3 svg,.cant--light h3 svg{color:var(--amber);flex:none}
.cant.light .cant-list span,.cant--light .cant-list span{background:var(--light);border:1px solid var(--line);color:var(--charcoal);font-weight:600;font-size:.85rem}
.cant.light .cant-list span svg,.cant--light .cant-list span svg{color:#B23A3A;flex:none}
.cant.light p,.cant--light p{font-size:.9rem;color:var(--slate);margin-top:.9rem}

/* Generic icon-tile grid (what we take / cleanouts) — junk page */
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.tile{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem 1.4rem;box-shadow:var(--shadow-sm);display:flex;gap:1rem;align-items:flex-start;transition:transform .15s ease,box-shadow .15s ease}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.tile .t-ic{width:48px;height:48px;flex:none;border-radius:12px;background:var(--light);color:var(--navy);display:flex;align-items:center;justify-content:center}
.tile h3{font-size:1.12rem;font-weight:700;color:var(--navy);margin-bottom:.2rem}
.tile p{font-size:.92rem;color:var(--slate);line-height:1.5}

/* Load-size visual (5 tiers) — junk page */
.loadbar{display:flex;gap:.7rem;align-items:stretch;margin:1.6rem auto 0;max-width:46rem}
.load-step{flex:1;text-align:center;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1rem .4rem 1.1rem;box-shadow:var(--shadow-sm);transition:transform .12s ease}
.load-step:hover{transform:translateY(-3px)}
.load-step .bar{height:90px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:.7rem}
.load-step .fill{width:34px;background:var(--amber);border-radius:7px 7px 0 0}
.load-step:nth-child(1) .fill{height:14%}
.load-step:nth-child(2) .fill{height:28%}
.load-step:nth-child(3) .fill{height:55%}
.load-step:nth-child(4) .fill{height:78%}
.load-step:nth-child(5) .fill{height:100%}
.load-step strong{display:block;font-family:'Barlow Semi Condensed';font-weight:800;color:var(--navy);font-size:1.15rem}
.load-step span{font-size:.78rem;color:var(--slate);display:block;margin-top:.1rem}

/* Demolition add-on — junk page */
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:center}
.demo-grid .ph{height:360px}
.demo-list{list-style:none;margin:1.2rem 0 1.6rem}
.demo-list li{display:flex;gap:.7rem;align-items:flex-start;padding:.45rem 0;font-weight:500;font-size:1rem}
.demo-list svg{color:var(--green);flex:none;margin-top:4px}

/* Cross-sell band — junk page */
.crosssell{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-md);display:grid;grid-template-columns:1.3fr 1fr;gap:0;overflow:hidden}
.crosssell .ph{border-radius:0;min-height:280px}
.crosssell .cs-body{padding:2.4rem 2.6rem}
.crosssell .cs-body h2{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;color:var(--navy);text-align:left;margin-bottom:.6rem}
.crosssell .cs-body p{color:var(--slate);font-size:1.05rem;margin-bottom:1.3rem}

/* ----- Storm Debris page ----- */

/* Two ways cards (reuses svc patterns) */
.svc-card .ph{height:200px;border-radius:0}

/* What we clear grid — storm page */
.clear-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.clear-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem 1.6rem;box-shadow:var(--shadow-sm);transition:transform .15s ease,box-shadow .15s ease}
.clear-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.clear-card h3{font-size:1.25rem;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.clear-card p{color:var(--slate);font-size:.96rem}
.clear-ic{width:56px;height:56px;border-radius:14px;background:var(--light);color:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:1rem}

/* Why / checklist — storm page */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem 2rem}
.why-item{display:flex;gap:.9rem;align-items:flex-start;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.3rem 1.4rem;box-shadow:var(--shadow-sm)}
.why-item h3{font-size:1.12rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.why-item p{color:var(--slate);font-size:.95rem}
.why-ck{width:34px;height:34px;border-radius:50%;background:rgba(30,122,61,.12);color:var(--green);display:flex;align-items:center;justify-content:center;flex:none;margin-top:2px}

/* Before-storm callout — storm page */
.prep{display:grid;grid-template-columns:1.1fr .9fr;gap:2.4rem;align-items:center;background:linear-gradient(120deg,var(--navy) 0%,var(--navy-deep) 100%);color:var(--white);border-radius:var(--radius);padding:2.6rem;box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.prep::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:linear-gradient(120deg,#000,transparent 75%);mask-image:linear-gradient(120deg,#000,transparent 75%);opacity:.6}
.prep>div{position:relative;z-index:1}
.prep .eyebrow{color:var(--amber)}
.prep h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:800;color:var(--white);margin:.5rem 0 .8rem}
.prep p{color:#CDD8E6;font-size:1.05rem;margin-bottom:1rem}
.prep .prep-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.4rem}
.prep-list{list-style:none;margin:0}
.prep-list li{display:flex;gap:.7rem;align-items:flex-start;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.12);font-weight:500;color:#E4ECF5}
.prep-list li:last-child{border-bottom:none}
.prep-list svg{color:var(--amber);flex:none;margin-top:2px}

/* Insurance / FEMA note — storm page */
.doc-note{display:flex;gap:1.1rem;align-items:flex-start;background:var(--light);border:1px solid var(--line);border-left:4px solid var(--amber);border-radius:var(--radius-sm);padding:1.4rem 1.6rem;max-width:880px;margin:0 auto}
.doc-note svg{color:var(--navy);flex:none;margin-top:2px}
.doc-note h3{font-size:1.15rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.doc-note p{color:var(--slate);font-size:.96rem}
.reassure{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:#CDD8E6;margin-bottom:1.5rem;font-weight:500}
.reassure svg{color:var(--amber);flex:none}

/* ==========================================================================
   CUSTOM FOOTER (injected via generate_footer hook)
   ========================================================================== */
.lh-footer{background:var(--navy-deep);color:#B8C6D6;padding:3.4rem 0 1.6rem;font-size:.93rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;margin-bottom:2.2rem}
.lh-footer .brand{color:var(--white);margin-bottom:.7rem}
.lh-footer h4{font-family:'Barlow Semi Condensed';font-weight:700;color:var(--white);font-size:1.05rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.9rem}
.lh-footer ul{list-style:none;margin:0;padding:0}
.lh-footer ul li{padding:.25rem 0}
.lh-footer a{color:inherit;text-decoration:none}
.lh-footer a:hover{color:var(--amber)}
.lh-footer .tagline{color:#94A7BC;max-width:20rem;margin-bottom:1rem}
.lh-footer .foot-phone{font-family:'Barlow Semi Condensed';font-weight:700;font-size:1.4rem;color:var(--white)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.6rem;font-size:.84rem;color:#8597AC}
.foot-bottom .badge-line{display:flex;align-items:center;gap:.5rem}
.foot-bottom .badge-line svg{color:var(--amber)}

/* Hide GeneratePress default footer/site-info bar (kept clean for our footer) */
.site-info{display:none}

/* ==========================================================================
   RESPONSIVE (merged from all four mockups)
   ========================================================================== */
@media(max-width:1080px){
  .lh-nav-cta .nav-phone,.lh-nav-cta .btn-ghost{display:none}
}
@media(max-width:960px){
  .hero .wrap{grid-template-columns:1fr;gap:2rem;padding-top:3rem;padding-bottom:3.4rem}
  .hero-media .ph{height:300px}
  .about-grid{grid-template-columns:1fr;gap:1.6rem}
  .about-grid .ph{height:300px;order:-1}
  .area-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:1.6rem}
  .media-row{grid-template-columns:1fr;gap:1.6rem}
  .media-row .ph{height:280px;order:-1}
  .media-row.flip .copy{order:0}
  .demo-grid{grid-template-columns:1fr;gap:1.6rem}
  .demo-grid .ph{height:280px;order:-1}
  .crosssell{grid-template-columns:1fr}
  .crosssell .ph{min-height:220px;order:-1}
  .crosssell .cs-body{padding:1.8rem 1.6rem}
  .prep{grid-template-columns:1fr;gap:1.6rem;padding:2rem}
  .why-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .svc-grid,.steps,.pricing-grid,.rev-grid,.gallery,.feat-grid,.fits-grid,.who-grid,.tile-grid,.clear-grid{grid-template-columns:1fr}
  .step:not(:last-child)::after{display:none}
  .topbar .trust span:not(.always){display:none}
  .compare-head>div:first-child{font-size:.95rem}
  .compare-row>div{padding:.8rem .6rem}
  .compare-row .cell{font-size:.74rem}
  .loadbar{flex-wrap:wrap;gap:.5rem}
  .load-step{flex:1 1 28%}
  .clear-grid{grid-template-columns:1fr 1fr}
  .prep .prep-cta .btn{width:100%}
  section{padding:3.4rem 0}
}
@media(max-width:520px){
  .foot-grid{grid-template-columns:1fr}
  .price-chip{position:static;display:inline-flex;margin-bottom:1rem}
  .hero-cta .btn{width:100%}
  .clear-grid{grid-template-columns:1fr}
}
