:root{
  --navy:#0B1733;
  --navy-deep:#070F22;
  --blue:#1F6FEB;
  --blue-dark:#1857BD;
  --yellow:#FFC233;
  --red:#E11D2A;
  --red-dark:#B81621;
  --text:#1A1A1A;
  --muted:#5A6478;
  --bg-light:#F4F6FB;
  --white:#FFFFFF;
  --border:#E5E8EF;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:17px;line-height:1.6;color:var(--text);
  background:var(--white);-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* HEADER */
.header{
  position:sticky;top:0;z-index:50;background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.header-inner{
  max-width:1280px;margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{
  color:var(--white);font-weight:900;font-size:22px;letter-spacing:-0.02em;
  display:flex;align-items:center;gap:12px;
}
.logo-mark{
  width:38px;height:38px;border-radius:9px;background:var(--blue);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 6px 18px rgba(31,111,235,0.35);
}
.logo-mark svg{width:22px;height:22px;display:block}
.nav{display:flex;gap:28px;align-items:center}
.nav-item{
  color:rgba(255,255,255,0.86);font-weight:600;font-size:15px;
  padding:8px 0;position:relative;cursor:pointer;
}
.nav-item:hover{color:var(--white)}
.nav-item.active{color:var(--yellow)}
.nav-item .caret{display:inline-block;margin-left:4px;font-size:10px;opacity:0.7}
.cta-call{
  background:var(--blue);color:#fff;font-weight:700;font-size:15px;
  padding:12px 22px;border-radius:8px;display:inline-flex;align-items:center;gap:10px;
  transition:background .15s ease, transform .05s ease;
}
.cta-call:hover{background:var(--blue-dark)}
.cta-call:active{transform:translateY(1px)}
.hamburger{display:none;width:42px;height:42px;border-radius:8px;background:rgba(255,255,255,0.08);align-items:center;justify-content:center;color:#fff;font-size:22px;cursor:pointer}

/* HERO */
.hero{
  position:relative;
  background:url('../images/domino-water-heater-service-vans-long-island.jpg') center/cover no-repeat,var(--navy);
  color:#fff;text-align:center;
  padding:96px 24px 88px;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,15,34,0.82) 0%,rgba(7,15,34,0.92) 100%);
}
.hero-inner{position:relative;max-width:960px;margin:0 auto}
.eyebrow{
  display:inline-block;font-weight:700;color:var(--yellow);
  letter-spacing:0.22em;text-transform:uppercase;font-size:13px;
  margin-bottom:18px;
}
.hero h1{
  font-weight:700;font-size:clamp(40px,6.5vw,76px);
  line-height:1.12;letter-spacing:-0.02em;margin-bottom:18px;
}
.hero p{
  font-size:clamp(17px,2vw,21px);color:rgba(255,255,255,0.88);
  max-width:680px;margin:0 auto 28px;
}
.hero-stars{margin:8px 0 22px;color:var(--yellow);font-size:22px;letter-spacing:4px}
.hero-cta{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--blue);color:#fff;font-weight:800;font-size:18px;
  padding:18px 32px;border-radius:10px;
  box-shadow:0 8px 30px rgba(31,111,235,0.35);
  transition:background .15s ease, transform .05s ease;
}
.hero-cta:hover{background:var(--blue-dark)}
.hero-cta:active{transform:translateY(1px)}
.hero-phone{display:block;margin-top:16px;color:rgba(255,255,255,0.86);font-size:15px}
.hero-phone strong{color:#fff;font-weight:700}
.trust-ticks{
  display:flex;flex-wrap:wrap;justify-content:center;gap:18px 28px;
  margin-top:42px;padding-top:32px;border-top:1px solid rgba(255,255,255,0.12);
}
.tick{
  display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.92);
  font-weight:600;font-size:14px;
}
.tick::before{
  content:"✓";display:inline-grid;place-items:center;width:22px;height:22px;
  background:var(--yellow);color:var(--navy);border-radius:50%;font-weight:900;font-size:12px;
}

/* SECTION BASE */
.section{padding:84px 24px}
.section.alt{background:var(--bg-light)}
.container{max-width:1180px;margin:0 auto}
.section-head{text-align:center;max-width:760px;margin:0 auto 56px}
.section-head .eyebrow{color:var(--blue)}
.section-head h2{
  font-weight:900;font-size:clamp(30px,4vw,46px);
  line-height:1.15;letter-spacing:-0.02em;margin-bottom:14px;
}
.section-head p{color:var(--muted);font-size:18px}
.eyebrow-blue{color:var(--blue);font-weight:700;letter-spacing:0.22em;text-transform:uppercase;font-size:13px;display:inline-block;margin-bottom:14px}

/* STORY */
.story{display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center}
.story h2{
  font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1.15;
  letter-spacing:-0.02em;margin-bottom:20px;
}
.story p{color:var(--muted);font-size:17px;margin-bottom:16px}
.story p strong{color:var(--text)}
.story-image{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(11,23,51,0.16)}
.story-image img{aspect-ratio:4/3;object-fit:cover;width:100%}
.story-stamp{
  position:absolute;left:24px;bottom:24px;
  background:var(--yellow);color:var(--navy);
  padding:14px 18px;border-radius:12px;font-weight:900;font-size:15px;line-height:1.1;
  box-shadow:0 10px 30px rgba(11,23,51,0.25);
}
.story-stamp span{display:block;font-size:30px;line-height:1}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:42px}
.stat{
  background:var(--white);border:1px solid var(--border);border-radius:14px;
  padding:28px 22px;text-align:center;
}
.stat-num{font-weight:900;color:var(--navy);font-size:38px;line-height:1;letter-spacing:-0.02em}
.stat-num .accent{color:var(--blue)}
.stat-label{margin-top:8px;color:var(--muted);font-weight:600;font-size:14px;letter-spacing:0.03em;text-transform:uppercase}

/* WHY US (cards) */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:var(--white);border:1px solid var(--border);border-radius:16px;
  padding:32px;transition:transform .15s ease, box-shadow .15s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:0 22px 50px rgba(11,23,51,0.10)}
.card-icon{
  width:56px;height:56px;border-radius:14px;background:rgba(31,111,235,0.10);
  color:var(--blue);display:grid;place-items:center;font-size:24px;font-weight:900;margin-bottom:18px;
}
.card h3{font-size:20px;font-weight:800;margin-bottom:10px;letter-spacing:-0.01em}
.card p{color:var(--muted);font-size:16px}

/* TECHNICIANS */
.tech-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.tech-row .copy h2{
  font-weight:900;font-size:clamp(28px,3.6vw,40px);line-height:1.15;
  letter-spacing:-0.02em;margin-bottom:18px;
}
.tech-row .copy p{color:var(--muted);margin-bottom:18px}
.tech-row ul{list-style:none;margin:8px 0 0}
.tech-row li{
  padding:10px 0 10px 32px;position:relative;color:var(--text);font-weight:500;
  border-bottom:1px solid var(--border);
}
.tech-row li:last-child{border-bottom:none}
.tech-row li::before{
  content:"✓";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:22px;height:22px;background:var(--yellow);color:var(--navy);
  border-radius:50%;display:grid;place-items:center;font-weight:900;font-size:12px;
}
.tech-image{border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(11,23,51,0.16)}
.tech-image img{aspect-ratio:5/4;object-fit:cover;width:100%}

/* WARRANTY BANNER */
.banner{
  background:var(--navy);color:#fff;border-radius:18px;
  padding:48px;display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center;
}
.banner h3{font-size:clamp(24px,3vw,32px);font-weight:900;letter-spacing:-0.01em;margin-bottom:10px}
.banner p{color:rgba(255,255,255,0.78);font-size:17px}
.banner .actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}
.btn-blue{background:var(--blue);color:#fff;padding:16px 26px;border-radius:10px;font-weight:800;font-size:16px;display:inline-flex;align-items:center;gap:10px;transition:background .15s ease}
.btn-blue:hover{background:var(--blue-dark)}
.btn-outline{border:2px solid rgba(255,255,255,0.3);color:#fff;padding:14px 24px;border-radius:10px;font-weight:700;font-size:16px;display:inline-flex;align-items:center;gap:10px;transition:border-color .15s ease, background .15s ease}
.btn-outline:hover{border-color:var(--yellow);color:var(--yellow)}

/* URGENT CTA STRIP */
.urgent-strip{
  background:var(--red);color:#fff;padding:24px;text-align:center;
}
.urgent-strip .container{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:18px}
.urgent-strip .label{font-weight:900;font-size:18px;letter-spacing:0.02em}
.urgent-strip .label-sub{color:rgba(255,255,255,0.86);font-weight:500}
.urgent-strip .call-btn{
  background:#fff;color:var(--red);font-weight:900;padding:14px 24px;border-radius:10px;
  display:inline-flex;align-items:center;gap:10px;font-size:17px;
}
.urgent-strip .call-btn:hover{color:var(--red-dark)}

/* SERVICE AREA STRIP */
.areas{text-align:center}
.areas h2{font-weight:900;font-size:clamp(28px,3.6vw,40px);line-height:1.15;letter-spacing:-0.02em;margin:8px 0 14px}
.areas p{color:var(--muted);max-width:780px;margin:0 auto}
.area-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px}
.tag{
  background:var(--white);border:1px solid var(--border);
  padding:8px 16px;border-radius:999px;font-weight:600;font-size:14px;color:var(--text);
}
.areas-cta{margin-top:32px}

/* FOOTER */
.footer{background:var(--navy-deep);color:rgba(255,255,255,0.78);padding:64px 24px 24px}
.footer-grid{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;
}
.footer h4{color:#fff;font-weight:800;font-size:14px;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:18px}
.footer .col p{font-size:15px;line-height:1.7}
.footer .col ul{list-style:none}
.footer .col li{padding:6px 0;font-size:15px}
.footer .col li a:hover{color:#fff}
.footer-bar{
  max-width:1180px;margin:48px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.08);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  color:rgba(255,255,255,0.6);font-size:13px;
}
.footer-brand{margin-bottom:14px}

/* MOBILE STICKY CALL */
.mobile-call{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;
  padding:10px 14px env(safe-area-inset-bottom);
  background:var(--navy);
  transform:translateY(100%);
  transition:transform .25s ease;
}
.mobile-call.visible{transform:translateY(0)}
.mobile-call a{
  display:flex;align-items:center;justify-content:center;gap:12px;
  background:var(--blue);color:#fff;font-weight:900;font-size:17px;
  padding:16px;border-radius:12px;box-shadow:0 10px 24px rgba(31,111,235,0.4);
}

/* RESPONSIVE */
@media (max-width: 960px){
  .story,.tech-row,.banner,.footer-grid{grid-template-columns:1fr;gap:36px}
  .banner{padding:36px;text-align:left}
  .banner .actions{justify-content:flex-start}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .section{padding:64px 22px}
  .hero{padding:72px 22px 64px}
}
@media (max-width: 720px){
  .nav,.cta-call{display:none}
  .hamburger{display:inline-flex}
  .mobile-call{display:block}
  body{padding-bottom:84px}
  .stats{grid-template-columns:1fr 1fr;gap:12px}
  .stat{padding:22px 14px}
  .stat-num{font-size:30px}
  .trust-ticks{gap:14px 20px;margin-top:32px;padding-top:24px}
  .tick{font-size:13px}
  .urgent-strip .container{flex-direction:column}
}

/* COMPACT HERO (for non-homepage interior pages without big hero image) */
.hero-compact{
  background:var(--navy);
  color:#fff;text-align:center;
  padding:80px 24px 64px;
}
.hero-compact h1{
  font-weight:700;font-size:clamp(34px,5vw,56px);
  line-height:1.1;letter-spacing:-0.02em;margin-bottom:14px;
}
.hero-compact p{
  font-size:clamp(16px,2vw,19px);color:rgba(255,255,255,0.85);
  max-width:680px;margin:0 auto;
}
.hero-compact .eyebrow{margin-bottom:14px}

/* CONTACT BIG-CALL PANEL */
.call-panel{
  background:var(--navy);color:#fff;border-radius:18px;
  padding:48px 40px;text-align:center;
  box-shadow:0 24px 60px rgba(11,23,51,0.18);
}
.call-panel .eyebrow{color:var(--yellow);margin-bottom:14px}
.call-panel h2{
  font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1.1;
  letter-spacing:-0.02em;margin-bottom:16px;
}
.call-panel p{color:rgba(255,255,255,0.82);max-width:640px;margin:0 auto 28px;font-size:17px}
.call-panel .big-number{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--blue);color:#fff;
  font-size:clamp(24px,4vw,38px);font-weight:900;letter-spacing:-0.01em;
  padding:22px 36px;border-radius:14px;
  box-shadow:0 10px 40px rgba(31,111,235,0.45);
  transition:background .15s ease, transform .05s ease;
}
.call-panel .big-number:hover{background:var(--blue-dark)}
.call-panel .big-number:active{transform:translateY(1px)}
.call-panel .sub{
  display:block;margin-top:18px;color:rgba(255,255,255,0.75);font-size:15px;
}
.call-panel .stars{margin-top:14px;color:var(--yellow);font-size:22px;letter-spacing:4px}

/* CONTACT INFO GRID */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.info-card{
  background:var(--white);border:1px solid var(--border);border-radius:16px;
  padding:28px 24px;text-align:center;
}
.info-card .icon{
  width:54px;height:54px;border-radius:14px;background:rgba(31,111,235,0.10);
  color:var(--blue);display:grid;place-items:center;font-size:26px;margin:0 auto 14px;
}
.info-card h3{font-size:18px;font-weight:800;margin-bottom:8px}
.info-card p{color:var(--muted);font-size:15px;line-height:1.6}
.info-card strong{color:var(--text)}

/* WHAT TO EXPECT (numbered steps) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px}
.step{position:relative;padding:32px 22px;background:var(--white);border:1px solid var(--border);border-radius:14px}
.step-num{
  position:absolute;top:-18px;left:22px;
  width:38px;height:38px;border-radius:10px;background:var(--yellow);color:var(--navy);
  display:grid;place-items:center;font-weight:900;font-size:18px;
}
.step h4{font-size:16px;font-weight:800;margin-top:14px;margin-bottom:8px}
.step p{color:var(--muted);font-size:14px;line-height:1.6}

/* LEGAL / PROSE PAGES */
.prose{max-width:820px;margin:0 auto;padding:64px 24px 80px}
.prose .last-updated{
  display:inline-block;background:var(--bg-light);color:var(--muted);
  font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;margin-bottom:28px;
}
.prose h2{
  font-size:24px;font-weight:900;color:var(--navy);letter-spacing:-0.01em;
  margin:36px 0 14px;line-height:1.2;
}
.prose h2:first-of-type{margin-top:0}
.prose h3{
  font-size:18px;font-weight:800;color:var(--text);
  margin:24px 0 10px;
}
.prose p{margin-bottom:14px;color:var(--text);font-size:16px;line-height:1.75}
.prose ul{margin:0 0 18px 22px;padding:0}
.prose li{margin-bottom:8px;color:var(--text);font-size:16px;line-height:1.7}
.prose strong{font-weight:700}
.prose a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.prose a:hover{color:var(--blue-dark)}
.prose .toc{
  background:var(--bg-light);border:1px solid var(--border);border-radius:12px;
  padding:22px 26px;margin-bottom:32px;
}
.prose .toc h4{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:0.14em;color:var(--muted);margin-bottom:10px}
.prose .toc ol{margin:0 0 0 22px;padding:0}
.prose .toc li{margin-bottom:4px;font-size:15px}
.prose .toc a{font-weight:500;text-decoration:none}
.prose .toc a:hover{text-decoration:underline}
.prose .legal-note{
  background:#FFF8E7;border:1px solid #FCE7B5;color:#5C4609;
  padding:16px 18px;border-radius:10px;margin:24px 0;font-size:14px;line-height:1.6;
}

@media (max-width: 720px){
  .info-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .call-panel{padding:36px 24px}
  .prose{padding:48px 20px 64px}
}

/* Inline icon helper (used for phone, etc. inside buttons and links) */
.ic{
  width:1em;height:1em;display:inline-block;vertical-align:-0.12em;
  fill:currentColor;
  flex:none;
}
.ic-lg{width:1.15em;height:1.15em}

/* ===== NAV DROPDOWNS (desktop) ===== */
.nav{align-items:stretch}
.nav-item{
  position:relative;display:flex;align-items:center;
  color:rgba(255,255,255,0.86);font-weight:600;font-size:15px;
  padding:18px 0;cursor:pointer;
}
.nav-item > a{
  color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:6px;
  transition:color .15s ease;
}
.nav-item:hover > a,.nav-item:focus-within > a{color:var(--white)}
.nav-item.active > a{color:var(--yellow)}
.nav-item .caret{font-size:10px;opacity:0.7;transition:transform .15s ease}
.nav-item:hover .caret{transform:rotate(180deg)}

.dropdown{
  position:absolute;top:100%;left:-16px;
  min-width:280px;padding-top:10px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .15s ease,transform .15s ease,visibility .15s ease;
  z-index:60;
}
.dropdown-panel{
  background:var(--white);border-radius:14px;padding:10px;
  box-shadow:0 18px 50px rgba(11,23,51,0.18),0 2px 6px rgba(11,23,51,0.06);
  border:1px solid var(--border);
}
.dropdown-panel a{
  display:block;padding:11px 14px;border-radius:9px;
  color:var(--text);font-size:14.5px;font-weight:600;
  transition:background .12s ease,color .12s ease;
}
.dropdown-panel a:hover{background:var(--bg-light);color:var(--blue)}
.dropdown-panel a.lead{
  background:linear-gradient(135deg,rgba(31,111,235,0.07),rgba(31,111,235,0.02));
  color:var(--blue);margin-bottom:6px;border-bottom:1px solid var(--border);border-radius:9px 9px 0 0;
}
.dropdown-panel a.lead:hover{background:linear-gradient(135deg,rgba(31,111,235,0.12),rgba(31,111,235,0.04))}
.nav-item:hover .dropdown,
.nav-item:focus-within .dropdown{
  opacity:1;visibility:visible;transform:translateY(0);
}

/* ===== MOBILE MENU ===== */
.mobile-menu{
  display:none;position:fixed;inset:0;z-index:200;
  background:var(--navy-deep);overflow-y:auto;
  padding:18px 18px env(safe-area-inset-bottom);
}
.mobile-menu.open{display:block}
body.menu-open{overflow:hidden}
.mobile-menu-top{
  display:flex;align-items:center;justify-content:space-between;padding:6px 4px 18px;
}
.mobile-menu-top .logo{color:#fff;font-size:18px}
.mobile-menu-close{
  background:rgba(255,255,255,0.08);border:none;color:#fff;
  width:42px;height:42px;border-radius:10px;font-size:24px;cursor:pointer;
  display:grid;place-items:center;
}
.mobile-menu details{
  background:rgba(255,255,255,0.04);border-radius:12px;margin-bottom:8px;
  border:1px solid rgba(255,255,255,0.06);overflow:hidden;
}
.mobile-menu details summary{
  list-style:none;padding:16px 18px;color:#fff;font-weight:700;font-size:16px;
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;
}
.mobile-menu details summary::-webkit-details-marker{display:none}
.mobile-menu details summary::after{
  content:"▾";color:var(--yellow);font-size:12px;transition:transform .2s ease;
}
.mobile-menu details[open] summary::after{transform:rotate(180deg)}
.mobile-menu details .submenu{padding:4px 8px 12px}
.mobile-menu details .submenu a{
  display:block;padding:11px 14px;border-radius:8px;
  color:rgba(255,255,255,0.85);font-weight:500;font-size:15px;
  transition:background .12s ease,color .12s ease;
}
.mobile-menu details .submenu a:hover{background:rgba(255,255,255,0.06);color:#fff}
.mobile-menu .menu-cta{
  display:block;background:var(--blue);color:#fff;text-align:center;
  font-weight:900;font-size:18px;padding:18px;border-radius:12px;margin-top:14px;
  box-shadow:0 10px 24px rgba(31,111,235,0.4);
}

@media (max-width: 720px){
  .nav,.cta-call{display:none}
  .hamburger{display:inline-flex}
}

/* MightyForms wrapper */
.form-wrap{
  max-width:760px;margin:0 auto;
  background:var(--white);border:1px solid var(--border);border-radius:18px;
  padding:36px 32px;box-shadow:0 18px 60px rgba(11,23,51,0.08);
}
@media (max-width: 720px){
  .form-wrap{padding:24px 18px}
}

/* ===== REBATE PROGRAM CARDS ===== */
.rebate-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.rebate-card{
  background:var(--white);border:1px solid var(--border);border-radius:18px;
  padding:28px;display:flex;flex-direction:column;
  transition:transform .15s ease,box-shadow .15s ease;
}
.rebate-card:hover{transform:translateY(-3px);box-shadow:0 22px 50px rgba(11,23,51,0.10)}
.rebate-card.featured{background:linear-gradient(135deg,#0F1F47,#070F22);color:#fff;border-color:transparent;position:relative;overflow:hidden}
.rebate-card.featured::before{
  content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;
  background:radial-gradient(circle,rgba(255,194,51,0.18),transparent 70%);
}
.rebate-logo{
  height:46px;display:flex;align-items:center;margin-bottom:18px;
}
.rebate-logo img{max-height:100%;max-width:170px;object-fit:contain;display:block}
.rebate-tag{
  display:inline-block;background:rgba(31,111,235,0.10);color:var(--blue);
  font-weight:800;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;margin-bottom:14px;
}
.rebate-card.featured .rebate-tag{background:rgba(255,194,51,0.18);color:var(--yellow)}
.rebate-card h3{font-size:22px;font-weight:900;margin-bottom:10px;letter-spacing:-0.01em;line-height:1.2}
.rebate-card .amount{
  font-size:42px;font-weight:900;line-height:1;letter-spacing:-0.03em;
  color:var(--navy);margin:14px 0 4px;
}
.rebate-card.featured .amount{color:var(--yellow)}
.rebate-card .amount-sub{font-size:13px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px}
.rebate-card.featured .amount-sub{color:rgba(255,255,255,0.7)}
.rebate-card p{color:var(--muted);font-size:15px;margin-bottom:16px;flex:1}
.rebate-card.featured p{color:rgba(255,255,255,0.82)}
.rebate-card ul{list-style:none;margin:0;padding:0;margin-bottom:16px}
.rebate-card li{
  padding:6px 0 6px 24px;font-size:14px;color:var(--text);position:relative;line-height:1.55;
}
.rebate-card.featured li{color:rgba(255,255,255,0.85)}
.rebate-card li::before{content:"✓";position:absolute;left:0;color:var(--blue);font-weight:900}
.rebate-card.featured li::before{color:var(--yellow)}
.rebate-card .footer-note{font-size:12px;color:var(--muted);margin-top:auto}
.rebate-card.featured .footer-note{color:rgba(255,255,255,0.55)}

/* ===== RESOURCE / ARTICLE CARDS ===== */
.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.resource-card{
  background:var(--white);border:1px solid var(--border);border-radius:16px;
  padding:28px;display:flex;flex-direction:column;
  transition:transform .15s ease,box-shadow .15s ease;text-decoration:none;color:inherit;
}
.resource-card:hover{transform:translateY(-3px);box-shadow:0 24px 52px rgba(11,23,51,0.10)}
.resource-card .tag-pill{
  display:inline-block;background:rgba(31,111,235,0.10);color:var(--blue);
  font-weight:800;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;align-self:flex-start;margin-bottom:14px;
}
.resource-card h3{font-size:20px;font-weight:800;margin-bottom:10px;letter-spacing:-0.01em;line-height:1.25}
.resource-card p{color:var(--muted);font-size:15px;line-height:1.6;flex:1;margin-bottom:16px}
.resource-card .read-more{color:var(--blue);font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:6px}
.resource-card:hover .read-more{color:var(--blue-dark)}

/* ===== ARTICLE / POST EXTRAS ===== */
.article-meta{
  display:flex;align-items:center;gap:14px;color:var(--muted);font-size:14px;
  margin-bottom:16px;flex-wrap:wrap;
}
.article-meta .dot{opacity:0.45}
.article-meta .pill{
  background:rgba(31,111,235,0.10);color:var(--blue);font-weight:800;
  font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  padding:6px 12px;border-radius:999px;
}

.compare-table{
  width:100%;border-collapse:collapse;margin:24px 0;
  background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden;
}
.compare-table th,.compare-table td{
  padding:14px 16px;text-align:left;font-size:15px;
  border-bottom:1px solid var(--border);vertical-align:top;
}
.compare-table tr:last-child td{border-bottom:none}
.compare-table thead th{
  background:var(--bg-light);color:var(--navy);font-weight:800;
  font-size:14px;letter-spacing:0.02em;
}
.compare-table tbody th{
  background:var(--bg-light);color:var(--text);font-weight:700;width:32%;
}
.compare-table .yes{color:#0F8A48;font-weight:700}
.compare-table .no{color:var(--red);font-weight:700}

.callout{
  background:var(--bg-light);border-left:4px solid var(--blue);
  padding:18px 22px;border-radius:0 12px 12px 0;margin:24px 0;
  font-size:15.5px;line-height:1.65;
}
.callout strong{color:var(--navy)}

.related{
  background:var(--bg-light);padding:48px 24px;margin-top:64px;border-radius:18px;
}
.related h3{font-size:22px;font-weight:900;text-align:center;margin-bottom:24px}
.related .resource-grid{margin-top:0;grid-template-columns:repeat(2,1fr)}

@media (max-width: 720px){
  .rebate-grid,.resource-grid{grid-template-columns:1fr}
  .related .resource-grid{grid-template-columns:1fr}
  .compare-table{font-size:14px}
  .compare-table th,.compare-table td{padding:11px 12px}
}

/* ===== FAQ ACCORDION ===== */
.faq-section{max-width:880px;margin:0 auto;padding:64px 24px 80px}
.faq-cat{
  margin-bottom:36px;
}
.faq-cat-title{
  font-size:13px;font-weight:800;color:var(--blue);
  letter-spacing:0.18em;text-transform:uppercase;
  display:flex;align-items:center;gap:12px;margin-bottom:18px;
}
.faq-cat-title::after{content:"";flex:1;height:1px;background:var(--border)}
.faq{
  background:var(--white);border:1px solid var(--border);border-radius:14px;
  margin-bottom:12px;overflow:hidden;transition:box-shadow .15s ease,border-color .15s ease;
}
.faq[open]{border-color:rgba(31,111,235,0.4);box-shadow:0 14px 36px rgba(11,23,51,0.08)}
.faq summary{
  list-style:none;padding:20px 24px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  font-weight:700;font-size:17px;color:var(--text);line-height:1.4;
  transition:background .12s ease;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{background:var(--bg-light)}
.faq summary::after{
  content:"+";color:var(--blue);font-weight:900;font-size:24px;line-height:1;
  flex:none;width:30px;height:30px;display:grid;place-items:center;
  background:rgba(31,111,235,0.10);border-radius:8px;
  transition:transform .2s ease,background .15s ease;
}
.faq[open] summary::after{content:"−";background:var(--blue);color:#fff}
.faq .answer{
  padding:0 24px 22px;color:var(--muted);font-size:16px;line-height:1.7;
}
.faq .answer p{margin-bottom:12px}
.faq .answer p:last-child{margin-bottom:0}
.faq .answer a{color:var(--blue);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.faq .answer a:hover{color:var(--blue-dark)}
.faq .answer ul{margin:8px 0 12px 22px;padding:0}
.faq .answer li{margin-bottom:6px}

@media (max-width: 720px){
  .faq summary{padding:16px 18px;font-size:16px;gap:12px}
  .faq .answer{padding:0 18px 18px;font-size:15px}
  .faq-section{padding:48px 18px 64px}
}

/* ===== SERVICE AREAS GRID ===== */
.county-block{margin-bottom:48px}
.county-head{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  margin-bottom:18px;flex-wrap:wrap;
}
.county-head h3{
  font-size:24px;font-weight:900;color:var(--navy);letter-spacing:-0.01em;
  display:flex;align-items:center;gap:12px;
}
.county-head .county-meta{
  color:var(--muted);font-size:14px;font-weight:600;
}
.towns-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px 16px;
  background:var(--white);border:1px solid var(--border);border-radius:14px;
  padding:22px 24px;
}
.towns-grid .town{
  padding:7px 0;font-size:15px;color:var(--text);
  border-bottom:1px dashed transparent;
}
.towns-grid a.town{
  color:var(--blue);font-weight:700;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
}
.towns-grid a.town::after{
  content:"→";font-size:13px;transition:transform .15s ease;
}
.towns-grid a.town:hover{color:var(--blue-dark)}
.towns-grid a.town:hover::after{transform:translateX(3px)}

/* ===== TOWN PAGE: local highlight strip ===== */
.local-strip{
  background:var(--bg-light);padding:32px;border-radius:18px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:42px;
}
.local-fact{
  text-align:center;
}
.local-fact .label{
  font-size:11px;font-weight:800;color:var(--blue);
  letter-spacing:0.16em;text-transform:uppercase;display:block;margin-bottom:6px;
}
.local-fact .value{
  font-size:18px;font-weight:800;color:var(--navy);line-height:1.3;
}

@media (max-width: 960px){
  .towns-grid{grid-template-columns:repeat(3,1fr)}
  .local-strip{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 720px){
  .towns-grid{grid-template-columns:repeat(2,1fr);padding:18px 20px}
  .local-strip{grid-template-columns:1fr 1fr;padding:24px;gap:16px}
}

/* Outline button used on financing page for the calculator CTA */
.btn-blue-outline{
  border:2px solid var(--blue);color:var(--blue);background:transparent;
  padding:14px 24px;border-radius:10px;font-weight:800;font-size:16px;
  display:inline-flex;align-items:center;gap:10px;
  transition:background .15s ease,color .15s ease;
}
.btn-blue-outline:hover{background:var(--blue);color:#fff}

/* ===== SERVICE TILES (hub grid) ===== */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.service-tile{
  background:var(--white);border:1px solid var(--border);border-radius:18px;
  padding:32px 28px;display:flex;flex-direction:column;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
  text-decoration:none;color:inherit;
}
.service-tile:hover{transform:translateY(-3px);box-shadow:0 24px 52px rgba(11,23,51,0.12);border-color:rgba(31,111,235,0.3)}
.service-tile .icon{
  width:60px;height:60px;border-radius:14px;background:rgba(31,111,235,0.10);
  color:var(--blue);display:grid;place-items:center;font-size:28px;font-weight:900;margin-bottom:18px;
}
.service-tile.urgent .icon{background:rgba(225,29,42,0.10);color:var(--red)}
.service-tile h3{font-size:22px;font-weight:900;margin-bottom:10px;letter-spacing:-0.01em;line-height:1.2}
.service-tile p{color:var(--muted);font-size:15.5px;line-height:1.6;flex:1;margin-bottom:18px}
.service-tile .link{color:var(--blue);font-weight:800;font-size:14px;display:inline-flex;align-items:center;gap:6px;letter-spacing:0.01em}
.service-tile:hover .link{color:var(--blue-dark)}
.service-tile.urgent .link{color:var(--red)}

@media (max-width: 720px){.service-grid{grid-template-columns:1fr}}

/* ===== STORY ROW LOCKUP (reuse story styles for service pages with prose) ===== */
.story-image .badge{
  position:absolute;left:24px;bottom:24px;
  background:var(--blue);color:#fff;
  padding:10px 16px;border-radius:999px;font-weight:800;font-size:13px;letter-spacing:0.06em;text-transform:uppercase;
  box-shadow:0 10px 30px rgba(31,111,235,0.45);
}
.story-image .badge.red{background:var(--red);box-shadow:0 10px 30px rgba(225,29,42,0.4)}
.story-image .badge.yellow{background:var(--yellow);color:var(--navy);box-shadow:0 10px 30px rgba(255,194,51,0.45)}

/* ===== HOMEPAGE: FINANCING BAND ===== */
.financing-band{
  background:linear-gradient(135deg,#0F1F47 0%,#1F6FEB 100%);
  color:#fff;border-radius:22px;padding:48px;margin:0 auto;
  display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:center;
  position:relative;overflow:hidden;
}
.financing-band::before{
  content:"";position:absolute;top:-80px;right:-80px;width:280px;height:280px;
  background:radial-gradient(circle,rgba(255,194,51,0.22),transparent 70%);
}
.financing-band .copy{position:relative;z-index:1}
.financing-band .badge{
  display:inline-block;background:rgba(255,194,51,0.18);color:var(--yellow);
  font-weight:800;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;margin-bottom:18px;
}
.financing-band h2{
  font-size:clamp(28px,3.6vw,40px);font-weight:800;letter-spacing:-0.02em;
  line-height:1.15;margin-bottom:14px;
}
.financing-band p{color:rgba(255,255,255,0.85);font-size:17px;margin-bottom:22px}
.financing-band .perks{display:flex;flex-wrap:wrap;gap:8px 14px;margin-bottom:24px}
.financing-band .perks span{
  background:rgba(255,255,255,0.10);padding:8px 14px;border-radius:999px;
  font-weight:600;font-size:14px;color:#fff;
}
.financing-band .actions{display:flex;flex-wrap:wrap;gap:12px}
.financing-band .btn-yellow{
  background:var(--yellow);color:var(--navy);font-weight:800;
  padding:14px 24px;border-radius:10px;font-size:16px;
}
.financing-band .btn-ghost{
  background:transparent;border:2px solid rgba(255,255,255,0.32);color:#fff;
  padding:12px 22px;border-radius:10px;font-weight:700;font-size:15px;
}
.financing-band .visual{position:relative;z-index:1;text-align:center}
.financing-band .visual .num{font-weight:900;font-size:72px;color:var(--yellow);line-height:1;letter-spacing:-0.04em}
.financing-band .visual .num-sub{color:rgba(255,255,255,0.8);margin-top:8px;font-size:14px;letter-spacing:0.08em;text-transform:uppercase;font-weight:700}
.financing-band .visual .ladder{display:flex;flex-direction:column;gap:8px;margin-top:24px}
.financing-band .visual .ladder div{
  background:rgba(255,255,255,0.08);padding:10px 14px;border-radius:8px;
  display:flex;justify-content:space-between;font-size:14px;font-weight:600;
}
@media (max-width: 960px){.financing-band{grid-template-columns:1fr;padding:36px}}

/* ===== HOMEPAGE: REVIEW STRIP ===== */
.reviews-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{
  background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px;
  position:relative;
}
.review-card .stars{color:var(--yellow);font-size:16px;letter-spacing:2px;margin-bottom:8px}
.review-card p{color:var(--text);font-size:15.5px;line-height:1.55;margin-bottom:14px}
.review-card .name{color:var(--muted);font-size:13px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase}
.review-card .name .town{color:var(--blue)}
@media (max-width:960px){.reviews-strip{grid-template-columns:1fr}}

/* ===== HOMEPAGE: TOWNS MARQUEE ===== */
.towns-banner{
  background:var(--navy);color:#fff;border-radius:18px;padding:36px 32px;
  text-align:center;
}
.towns-banner h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin-bottom:12px;letter-spacing:-0.02em}
.towns-banner p{color:rgba(255,255,255,0.78);margin-bottom:24px;max-width:780px;margin-left:auto;margin-right:auto}
.towns-banner .towns{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px 12px;margin-bottom:24px;
}
.towns-banner .towns span,.towns-banner .towns a{
  background:rgba(255,255,255,0.08);color:#fff;
  padding:8px 14px;border-radius:999px;font-weight:600;font-size:14px;
  border:1px solid rgba(255,255,255,0.08);
}
.towns-banner .towns a{background:rgba(255,194,51,0.16);color:var(--yellow);border-color:rgba(255,194,51,0.32);text-decoration:none}
.towns-banner .towns a:hover{background:rgba(255,194,51,0.25)}

/* ===== HOMEPAGE: BIG NUMBER STATS ROW ===== */
.big-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--navy);color:#fff;border-radius:18px;overflow:hidden}
.big-stats .item{padding:32px 22px;text-align:center;border-right:1px solid rgba(255,255,255,0.08)}
.big-stats .item:last-child{border-right:none}
.big-stats .num{font-size:42px;font-weight:900;color:var(--yellow);line-height:1;letter-spacing:-0.03em}
.big-stats .lbl{color:rgba(255,255,255,0.78);font-size:13px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;margin-top:8px}
@media (max-width:720px){.big-stats{grid-template-columns:1fr 1fr}.big-stats .item:nth-child(2){border-right:none}.big-stats .item:nth-child(1),.big-stats .item:nth-child(2){border-bottom:1px solid rgba(255,255,255,0.08)}}


/* ==================================================================== */
/* MOBILE: VERTICAL STACKED CARDS                                       */
/* All card grids collapse to a single full-width column on phones      */
/* so the user can scroll the page normally, no horizontal swiping.     */
/* ==================================================================== */
@media (max-width: 720px) {

  /* All card grids -> single column */
  .service-grid,
  .cards,
  .resource-grid,
  .reviews-strip,
  .rebate-grid,
  .info-grid,
  .steps {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px;
    overflow: visible;
    padding-left: 0;
    padding-right: 0;
    margin-left: 0;
    margin-right: 0;
  }
  .service-grid > *,
  .cards > *,
  .resource-grid > *,
  .reviews-strip > *,
  .rebate-grid > *,
  .info-grid > *,
  .steps > * {
    flex: none;
    min-width: 0;
    max-width: 100%;
    width: 100%;
  }

  /* Stats (4-up on desktop): 2x2 on mobile is fine, keep numbers readable */
  .stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 12px;
  }
  .big-stats {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    border-radius: 18px;
  }
  .big-stats .item {
    border-right: 1px solid rgba(255,255,255,0.08) !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  }
  .big-stats .item:nth-child(2) { border-right: none !important; }
  .big-stats .item:nth-child(3),
  .big-stats .item:nth-child(4) { border-bottom: none !important; }
  .big-stats .item:nth-child(4) { border-right: none !important; }

  /* Local strip on town pages: 2x2 stacked */
  .local-strip {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px;
    padding: 22px !important;
  }

  /* TOWNS grid on service-areas — clean 2 column text list */
  .towns-grid {
    grid-template-columns: 1fr 1fr !important;
    padding: 16px 18px !important;
    display: grid !important;
    gap: 6px 14px !important;
    overflow: visible;
  }
  .towns-grid .town {
    font-size: 14px;
    padding: 6px 0;
  }

  /* Compare tables still scroll horizontally because they have many columns */
  .compare-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}

/* Layout stability — keep paint isolated to reduce reflow as you scroll */
.story-image, .tech-image, .hero, .hero-compact {
  contain: layout paint;
}



/* ==================================================================== */
/* LAYOUT STABILITY: prevent CLS dance from images and hero sections.   */
/* ==================================================================== */
.story-image, .tech-image {
  contain: layout paint;
}
.hero, .hero-compact {
  contain: layout paint;
}


/* Mobile: keep "Domino Home Services" on one line, smaller mark */
@media (max-width: 720px) {
  .header-inner .logo {
    font-size: 16px;
    gap: 8px;
    white-space: nowrap;
    letter-spacing: -0.01em;
  }
  .header-inner .logo-mark {
    width: 30px;
    height: 30px;
    border-radius: 7px;
  }
  .header-inner .logo-mark svg {
    width: 17px;
    height: 17px;
  }
}
@media (max-width: 380px) {
  .header-inner .logo {
    font-size: 14px;
  }
}
