/* W Contracting Inc. — brand colours carried from the original Wix site.
   Edit the :root variables to retheme the whole site. */
:root{
  --action:#D13800; --action-dark:#A82C00;
  --blue:#2081C3; --blue-bright:#0088CB; --navy:#0B2B41;
  --red:#ED1C24; --ink:#1A1A1A; --ink-2:#3a3a3a; --muted:#5a6470;
  --white:#fff; --grey:#F5F5F5; --ice:#eef4f8; --border:#D9D9D9;
  --container:1180px; --radius:12px; --shadow:0 8px 30px rgba(11,43,65,.10);
  --ff-head:'Poppins',system-ui,sans-serif; --ff-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--ink);background:var(--white);line-height:1.6;font-size:17px}
img{max-width:100%;display:block;height:auto}
a{color:var(--action);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--ff-head);line-height:1.15;color:var(--navy);margin:.2em 0 .5em;font-weight:700}
h1{font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-.5px}
h2{font-size:clamp(1.9rem,3.4vw,2.8rem)}
h3{font-size:1.3rem}
.display{font-size:clamp(2.4rem,5vw,3.6rem);letter-spacing:-.5px}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.section{padding:64px 0}
.section--white{background:var(--white)}
.section--grey{background:var(--grey)}
.section--ice{background:var(--ice)}
.section--navy{background:var(--navy);color:#dce6ee}
.section--navy h2,.section--navy h3{color:#fff}
.section__title{text-align:center;margin-bottom:1.5rem}
.section__lead{max-width:760px;margin:0 auto 2rem;text-align:center;color:var(--muted);font-size:1.1rem}
.lead{font-size:1.15rem;color:var(--ink-2)}

/* buttons — orange is the only click-me colour */
.btn{display:inline-block;background:var(--action);color:#fff;font-family:var(--ff-head);font-weight:600;
  padding:13px 24px;border-radius:10px;border:0;cursor:pointer;font-size:1rem;transition:.15s;text-align:center}
.btn:hover{background:var(--action-dark);text-decoration:none;transform:translateY(-1px)}
.btn--lg{padding:16px 32px;font-size:1.1rem}
.btn--sm{padding:9px 16px;font-size:.92rem}
.btn--block{display:block;width:100%}
.btn--ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn--ghost:hover{background:rgba(255,255,255,.12)}
/* dark outline button for use on LIGHT backgrounds (ghost is white, invisible there) */
.btn--outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn--outline:hover{background:var(--navy);color:#fff}
.btn--blue{background:var(--blue)}.btn--blue:hover{background:var(--blue-bright)}

/* header */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 8px rgba(0,0,0,.04);transition:box-shadow .2s ease}
.site-header__inner{display:flex;align-items:center;gap:14px;padding-top:14px;padding-bottom:14px;transition:padding .2s ease}
body.scrolled .site-header__inner{padding-top:7px;padding-bottom:7px}
body.scrolled .site-header{box-shadow:0 6px 22px rgba(0,0,0,.10)}

/* dynamic design: scroll reveals (JS-gated, respects reduced-motion) */
body.js-anim .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
body.js-anim .reveal.in{opacity:1;transform:none}
body.js-anim .svc-card.reveal,body.js-anim .trust-box.reveal{transition-duration:.5s}
@media(prefers-reduced-motion:reduce){body.js-anim .reveal{opacity:1!important;transform:none!important}}
.brand{display:flex;align-items:center;gap:10px;color:var(--navy);font-family:var(--ff-head);font-weight:800;font-size:1.12rem;white-space:nowrap}
.brand:hover{text-decoration:none}
.brand__tld{color:var(--action)}
.main-nav{margin-left:auto}
.main-nav>ul{display:flex;gap:2px;list-style:none;margin:0;padding:0}
.main-nav a{display:block;padding:8px 10px;color:var(--ink);font-family:var(--ff-head);font-weight:500;font-size:.92rem;border-radius:8px;white-space:nowrap}
.main-nav a:hover{background:var(--ice);text-decoration:none;color:var(--navy)}
.has-sub{position:relative}
.has-sub .sub{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow);min-width:240px;list-style:none;margin:0;padding:6px;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease,visibility .16s}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:none}
/* visible keyboard focus everywhere */
a:focus-visible,button:focus-visible,.btn:focus-visible,.chip:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--blue-bright);outline-offset:2px;border-radius:4px}
.site-header__cta{display:flex;align-items:center;gap:12px}
.header-phone{font-family:var(--ff-head);font-weight:700;color:var(--navy);white-space:nowrap}
.nav-toggle{display:none;font-size:1.6rem;background:none;border:0;color:var(--navy);cursor:pointer}

/* hero */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(100deg,rgba(8,31,48,.92) 0%,rgba(11,43,65,.62) 46%,rgba(11,43,65,.28) 100%),
  url(/assets/img/project-02.jpg) center/cover}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding:90px 0}
.hero h1{color:#fff;font-size:clamp(2.4rem,5.2vw,4rem);letter-spacing:-1px;text-shadow:0 2px 14px rgba(0,0,0,.35);max-width:14ch}
.hero__eyebrow{display:inline-block;background:var(--action);color:#fff;font-family:var(--ff-head);font-weight:600;
  font-size:.8rem;letter-spacing:.5px;text-transform:uppercase;padding:5px 12px;border-radius:30px;margin-bottom:14px}
.hero p{font-size:1.2rem;color:#cdd9e4;max-width:540px}
.hero__points{list-style:none;padding:0;margin:18px 0 26px;display:grid;gap:8px}
.hero__points li{padding-left:28px;position:relative;color:inherit}
.hero__points li::before{content:"\2713";position:absolute;left:0;color:var(--action);font-weight:700}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}

/* trust strip */
.trust-strip{background:var(--navy);border-top:3px solid var(--action)}
.trust-strip ul{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 36px;list-style:none;margin:0;padding:18px 20px;max-width:var(--container);margin:0 auto}
.trust-strip li{text-align:center}
.trust-strip a{display:flex;flex-direction:column;align-items:center;color:#a9bccd;font-size:.78rem;letter-spacing:.2px;text-transform:uppercase;transition:color .15s}
.trust-strip a:hover{text-decoration:none;color:#cfe0ee}
.trust-strip a:hover strong{color:var(--action)}
.trust-strip strong{font-family:var(--ff-head);color:#fff;font-size:1.5rem;font-weight:800;letter-spacing:-.5px;text-transform:none;transition:color .15s}

/* services grid */
.svc-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr));gap:16px}
.svc-card a{display:flex;flex-direction:column;gap:8px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;height:100%;color:var(--ink);transition:.15s}
.svc-card a:hover{text-decoration:none;border-color:var(--action);box-shadow:var(--shadow);transform:translateY(-2px)}
.svc-card__title{font-family:var(--ff-head);font-weight:600;color:var(--navy);font-size:1.1rem}
.svc-card__cta{color:var(--action);font-weight:600;font-size:.9rem;margin-top:auto}
/* image service cards (Blue Bird "What we do" — photo + title + blurb + CTA) */
.svc-card--photo a{padding:0;overflow:hidden;gap:0;box-shadow:var(--shadow)}
.svc-card__img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.svc-card__body{display:flex;flex-direction:column;gap:9px;padding:20px 22px 22px}
.svc-card__desc{color:var(--ink-2);font-size:.93rem;line-height:1.5}
.svc-card--photo .svc-card__cta{margin-top:4px}

/* service-area photo cards (Blue Bird "Areas" — photo + navy band + name + button) */
.area-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,270px),1fr));gap:20px;margin-top:12px}
.area-card{display:block;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;transition:.18s}
.area-card:hover{text-decoration:none;transform:translateY(-3px);box-shadow:0 16px 40px rgba(11,43,65,.18)}
.area-card__img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.area-card__band{display:block;background:var(--navy);padding:18px 20px;text-align:center}
.area-card__name{display:block;font-family:var(--ff-head);font-weight:800;color:#fff;font-size:1.2rem;text-transform:uppercase;letter-spacing:.4px;margin-bottom:12px}
.area-card__cta{display:inline-block;background:var(--action-dark);color:#fff;font-family:var(--ff-head);font-weight:700;font-size:.88rem;padding:9px 18px;border-radius:30px}
.area-card:hover .area-card__cta{background:#8a2400}
@media(max-width:600px){.area-card__img{aspect-ratio:16/9}}
.img-credits{color:var(--muted);font-size:.78rem;line-height:1.7;text-align:center;max-width:920px;margin:18px auto 0}
/* site-wide footer map (D2.6) — compact so it doesn't bloat the footer */
.footer-map{margin:20px auto 0}
.footer-map .map-embed{border-color:rgba(255,255,255,.18)}
.footer-map .map-embed iframe{height:200px}

/* generic content */
.prose{max-width:820px;margin:0 auto}
.prose p{margin:0 0 1.1em}
.cols-2{display:grid;grid-template-columns:1.4fr .9fr;gap:40px;align-items:start}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.trust-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.trust-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;text-align:center;box-shadow:var(--shadow)}
.trust-box h3{color:var(--action)}

/* accordion */
.acc{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:#fff;margin-bottom:10px}
.acc summary{cursor:pointer;padding:16px 20px;font-family:var(--ff-head);font-weight:600;color:var(--navy);list-style:none}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";float:right;color:var(--action);font-weight:700}
.acc[open] summary::after{content:"\2013"}
.acc__body{padding:0 20px 18px;color:var(--ink-2)}

/* photo grid + slider */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.photo-grid img{border-radius:10px;aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .25s ease}
.photo-grid a,.photo-grid figure{overflow:hidden;border-radius:10px;margin:0;display:block}
.photo-grid img:hover{transform:scale(1.04)}
.ba-slider{position:relative;max-width:760px;margin:0 auto;border-radius:var(--radius);overflow:hidden}

/* maps */
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.map-embed iframe{width:100%;height:320px;border:0;display:block}
.maps-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.map-link{display:inline-block;font-weight:600}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.chip{background:#fff;border:1px solid var(--border);border-radius:30px;padding:7px 15px;font-size:.9rem;color:var(--navy);font-weight:500}
.chip:hover{border-color:var(--action);text-decoration:none}
.chip--all{background:var(--navy);color:#fff;border-color:var(--navy)}

/* quote form — the focal conversion object */
.quote-form{background:#fff;border-radius:14px;padding:26px 24px;box-shadow:0 24px 60px rgba(0,0,0,.34);border-top:4px solid var(--action);position:relative}
.quote-form .quote-form__title{margin-top:0;color:var(--navy)}
.quote-form .quote-form__sub{color:var(--ink);font-size:.95rem;margin-top:-.4rem}
.quote-form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quote-form label{display:block;font-size:.85rem;font-weight:600;color:var(--ink-2);margin-bottom:10px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;margin-top:4px;padding:11px 12px;border:1px solid var(--border);
  border-radius:8px;font:inherit;font-size:.95rem;background:#fff;color:var(--ink)}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{outline:2px solid var(--blue);border-color:var(--blue)}
.quote-form__full{grid-column:1/-1}
.quote-form .quote-form__alt{text-align:center;font-size:.9rem;color:var(--muted);margin:.8rem 0 0}
.hp{position:absolute;left:-9999px}

/* cta band */
.cta-band{background:linear-gradient(100deg,var(--navy),#13405e);color:#fff}
.cta-band__inner{display:flex;gap:30px;align-items:center;justify-content:space-between;padding:48px 20px;flex-wrap:wrap}
.cta-band h2{color:#fff;margin:0 0 .3em}
.cta-band p{margin:0;color:#cdd9e4;max-width:520px}
.cta-band__actions{display:flex;gap:12px;flex-wrap:wrap}

/* review band (real content only) */
.review-band{background:var(--ice);text-align:center}

/* breadcrumb */
.crumbs{font-size:.85rem;color:var(--muted);padding:14px 0}
.crumbs a{color:var(--blue)}

/* footer */
.site-footer{background:var(--navy);color:#b9c7d4;padding-top:48px;font-size:.95rem}
.site-footer__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:32px}
.site-footer h3{color:#fff;font-size:1rem;margin-bottom:.8rem}
.site-footer a{color:#cdd9e4}.site-footer a:hover{color:#fff}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.site-footer__tag{font-family:var(--ff-head);font-weight:700;color:#fff;font-size:1.1rem;margin:.6rem 0 .2rem}
.site-footer address{font-style:normal;line-height:1.8}
.site-footer .hours{color:var(--action);font-weight:600}
.site-footer__bar{border-top:1px solid rgba(255,255,255,.12);margin-top:36px;padding:16px 0;font-size:.82rem}
.site-footer__bar .container{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8fa3b3}

/* sticky mobile call bar */
.sticky-call{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--navy);
  padding:8px;gap:8px;box-shadow:0 -4px 16px rgba(0,0,0,.2)}
.sticky-call a{flex:1;text-align:center;padding:12px;border-radius:8px;font-family:var(--ff-head);font-weight:700;color:#fff;background:var(--action)}
.sticky-call a:hover{text-decoration:none}
.sticky-call__quote{background:var(--blue)!important}

/* promo bar (site-wide, under header) */
.promo-bar{background:var(--navy);color:#fff;border-bottom:2px solid var(--action);font-size:.9rem}
.promo-bar .container{display:flex;align-items:center;justify-content:center;gap:10px 18px;padding:9px 20px;flex-wrap:wrap;text-align:center}
.promo-bar strong{color:#fff}
.promo-bar a{color:var(--action);font-weight:700;white-space:nowrap}
.promo-bar a:hover{color:#ff7a47}

/* storm urgency strip */
.storm-strip{background:linear-gradient(100deg,#7a1500,var(--action));color:#fff}
.storm-strip .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;flex-wrap:wrap}
.storm-strip p{margin:0;font-weight:600}
.storm-strip .btn{background:#fff;color:var(--action)}
.storm-strip .btn:hover{background:#f1f1f1}

/* comparison table */
.cmp-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.cmp-table th{background:var(--navy);color:#fff;font-family:var(--ff-head);padding:14px 16px;text-align:left;font-size:1rem}
.cmp-table td{padding:13px 16px;border-top:1px solid var(--border);vertical-align:top}
.cmp-table tr td:first-child{font-weight:600;color:var(--navy);width:34%}

/* financing callout */
.fin-callout{display:flex;gap:20px;align-items:center;justify-content:space-between;background:var(--ice);
  border:1px solid var(--border);border-left:5px solid var(--action);border-radius:var(--radius);padding:22px 24px;flex-wrap:wrap}
.fin-callout p{margin:0;max-width:560px}

/* ===== Bluebird-parity components (W Contracting brand) ===== */
/* eyebrow label above section titles */
.eyebrow{display:block;text-align:center;text-transform:uppercase;letter-spacing:1.6px;
  font-family:var(--ff-head);font-weight:700;font-size:.78rem;color:var(--action-dark);margin:0 0 .45rem}
.eyebrow--left{text-align:left}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.section--navy .eyebrow{color:#ffb38f}

/* hero Google rating strip (above the quote form, real numbers from reviews.mjs) */
.hero-proof{display:flex;align-items:center;justify-content:center;gap:11px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 14px;
  margin-bottom:12px;box-shadow:var(--shadow);font-family:var(--ff-head);font-weight:700;
  color:var(--navy);font-size:.95rem}
.hero-proof .stars{color:#f5a623;letter-spacing:2px;font-weight:400}
.hero-proof__g{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;
  border-radius:50%;background:#fff;border:1px solid var(--border);color:#4285F4;font-weight:800}

/* hero trust chips (checkmark pills on dark hero) */
.trust-chips{list-style:none;display:flex;flex-wrap:wrap;gap:8px 10px;padding:0;margin:18px 0 24px}
.trust-chips li{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);border-radius:30px;padding:7px 14px;font-size:.85rem;color:#eaf2f8;font-weight:500}
.trust-chips li::before{content:"\2713";color:#74c79b;font-weight:800}

/* inline review rating in service hero */

/* reviews grid (real Google reviews) */
.review-band .eyebrow{margin-bottom:.4rem}
.rev-head{color:var(--muted);font-weight:600;margin:-.3rem 0 1.7rem}
.rev-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}
.rev-card__stars{color:#f5a623;letter-spacing:2px;font-size:1.05rem}
.rev-card blockquote{margin:0;color:var(--ink-2);font-size:1rem;line-height:1.55}
.rev-card figcaption{font-family:var(--ff-head);font-weight:600;color:var(--navy);font-size:.95rem;margin-top:auto}
.rev-card figcaption span{display:block;color:var(--muted);font-weight:500;font-size:.8rem}
.rev-foot{margin:1.7rem 0 0}

/* reviews carousel (replaces the static grid — swipeable, snap, arrows) */
.rev-carousel{position:relative;display:flex;align-items:center;gap:8px}
.rev-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:4px 2px 14px;flex:1;text-align:left;scrollbar-width:thin}
.rev-track::-webkit-scrollbar{height:8px}
.rev-track::-webkit-scrollbar-thumb{background:#cdd9e4;border-radius:8px}
.rev-track .rev-card{flex:0 0 min(340px,80vw);scroll-snap-align:start}
.rev-track:focus-visible{outline:3px solid var(--blue-bright);outline-offset:2px;border-radius:10px}
.rev-nav{flex:0 0 auto;width:42px;height:42px;border-radius:50%;border:1px solid var(--border);background:#fff;
  color:var(--navy);font-size:1.5rem;line-height:1;cursor:pointer;box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;transition:.15s}
.rev-nav:hover{background:var(--action);color:#fff;border-color:var(--action)}
@media(max-width:600px){.rev-nav{display:none}}

/* sticky media column for long-form text+photo sections (service prose) */
.media-col__img{position:sticky;top:96px;width:100%;border-radius:var(--radius);box-shadow:var(--shadow);
  aspect-ratio:4/5;object-fit:cover;align-self:start}
@media(max-width:900px){.media-col__img{position:static;aspect-ratio:16/10;margin-top:8px}}

/* directions / transportation cards (now content-rich) */
.dir-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-top:8px}
.dir-card{background:#fff;border:1px solid var(--border);border-left:4px solid var(--blue);
  border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}
.dir-card h3{font-size:1.05rem;margin:.1em 0 .35em}
.dir-card p{margin:0;color:var(--ink-2);font-size:.95rem}

/* numbered process timeline (the signature service-page device) */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;counter-reset:step}
.process__step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:24px 20px;position:relative;box-shadow:var(--shadow)}
.process__step::before{counter-increment:step;content:"0" counter(step);display:block;
  font-family:var(--ff-head);font-weight:800;font-size:2rem;color:var(--action);line-height:1;margin-bottom:10px}
.process__step h3{font-size:1.08rem;margin:.1em 0 .4em}
.process__step p{margin:0;color:var(--ink-2);font-size:.93rem}

/* responsive */
/* header collapses to a hamburger before the one-row desktop header would overflow (~1060px) */
@media(max-width:1060px){
  .main-nav,.site-header__cta,.header-phone{display:none}
  .nav-toggle{display:block;margin-left:auto}
  body.nav-open .main-nav{display:block;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:10px;max-height:calc(100vh - 64px);overflow-y:auto;-webkit-overflow-scrolling:touch}
  body.nav-open .main-nav>ul{flex-direction:column}
  body.nav-open .has-sub .sub{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;padding-left:14px}
}
@media(max-width:900px){
  .process{grid-template-columns:1fr 1fr}
  .hero__inner,.cols-2,.maps-2{grid-template-columns:1fr}
  .hero__inner{padding:54px 0}
  .trust-boxes{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .sticky-call{display:flex}
  main{padding-bottom:64px}
}
@media(max-width:600px){
  .process{grid-template-columns:1fr}
  /* hero: keep everything inside the viewport (home H1 is the longest line) */
  .hero h1{font-size:clamp(1.45rem,6.1vw,2.05rem);letter-spacing:-.3px;max-width:100%;overflow-wrap:break-word;hyphens:none}
  .hero p,.hero__points li{overflow-wrap:break-word}
  .hero__points li{font-size:.95rem}
  .hero__actions{flex-direction:column}
  .hero__actions .btn{width:100%}
  .quote-form__row{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
  .cta-band__actions{width:100%}
  .cta-band__actions .btn{width:100%}
  .fin-callout,.storm-strip .container{flex-direction:column;align-items:flex-start}
  /* sticky bar: two buttons share the row, never overflow */
  .sticky-call{padding:8px 10px;gap:8px}
  .sticky-call a{flex:1 1 0;min-width:0;padding:13px 6px;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
}
