@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@600;700;800&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --navy:#5088d0;
  --navy-dark:#4070a8;
  --red:#7030a0;
  --ink:#111111;
  --text:#3f4652;
  --muted:#707786;
  --line:#d9dde5;
  --bg:#f3f4f7;
  --soft:#fbfbfd;
  --white:#ffffff;
  --chip:#eef4fd;
  --shadow:0 14px 32px rgba(39,52,79,.12);
  --radius:24px;
  --radius-sm:16px;
  --container:1440px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font:inherit}
.container{width:min(var(--container),calc(100% - 2rem));margin:0 auto}
.section{padding:3.8rem 0}
.section-sm{padding:2.2rem 0}
.section-lg{padding:5rem 0}
h1,h2,h3,h4{
  font-family:"Montserrat",sans-serif;
  color:var(--ink);
  margin:0 0 1rem;
  line-height:1.12;
}
h1{font-size:clamp(2.1rem,4vw,3.9rem);letter-spacing:-.03em}
h2{font-size:clamp(1.8rem,3vw,2.9rem);letter-spacing:-.02em}
h3{font-size:clamp(1.08rem,2vw,1.4rem)}
p{margin:0 0 1rem}
.lead{font-size:1.08rem}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.78rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  color:var(--navy);background:#eef5fb;padding:.55rem .8rem;border-radius:999px;margin-bottom:1rem
}
.eyebrow::before{content:"";width:.45rem;height:.45rem;border-radius:50%;background:var(--navy)}
.btn-row{display:flex;gap:.8rem;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.92rem 1.25rem;border-radius:10px;font-weight:700;border:1px solid transparent;transition:.22s ease
}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-dark)}
.btn-secondary{background:#fff;border-color:#dce1ea;color:var(--ink)}
.btn-secondary:hover{border-color:var(--navy);color:var(--navy)}
.btn-accent{background:var(--red);color:#fff}
.btn-light{background:#f1f3f7;color:var(--ink)}
.topline{background:#fff;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--muted)}
.trust-topline{background:linear-gradient(180deg,#ffffff 0%, #f7f9fc 100%)}
.trust-topline-inner{padding:.72rem 0 .82rem}
.trust-marquee-shell{
  position:relative;
  overflow:hidden;
  border:1px solid #dbe4ef;
  border-radius:18px;
  background:linear-gradient(90deg,#fbfdff 0%, #f2f7fc 100%);
  box-shadow:0 10px 24px rgba(111,132,165,.08);
}
.trust-marquee-shell::before,
.trust-marquee-shell::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:46px;
  z-index:2;
  pointer-events:none;
}
.trust-marquee-shell::before{left:0;background:linear-gradient(90deg,#fbfdff 25%, rgba(251,253,255,0));}
.trust-marquee-shell::after{right:0;background:linear-gradient(270deg,#f2f7fc 25%, rgba(242,247,252,0));}
.trust-marquee-track{
  display:flex;
  width:max-content;
  gap:3.5rem;
  align-items:center;
  padding:.78rem 0;
  will-change:transform;
  animation:trustMarquee 34s linear infinite;
}
.trust-marquee-item{
  display:inline-flex;
  align-items:center;
  gap:.9rem;
  padding:0 1.4rem;
  white-space:nowrap;
}
.dealer-label{
  display:inline-flex;
  align-items:center;
  padding:.52rem .95rem;
  border-radius:999px;
  background:linear-gradient(135deg,var(--navy),#6e8cc0);
  color:#fff;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:.94rem;
  letter-spacing:.02em;
  box-shadow:0 8px 18px rgba(82,106,158,.18);
}
.dealer-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:2.2rem;
  padding:.4rem .9rem;
  border-radius:999px;
  background:#fff;
  border:1px solid #d8e1ed;
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  font-size:.94rem;
  letter-spacing:.01em;
  line-height:1;
  box-shadow:0 5px 14px rgba(111,132,165,.08);
}
.dealer-sep{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#9db2cc;
  font-size:1.05rem;
  font-weight:800;
  margin:0 .05rem 0 -.1rem;
}
.dealer-pill--miele{color:#a2161e;border-color:#f0c9cc;background:#fff7f7}
.dealer-pill--cana-vac{color:#1754a1;border-color:#cddcf3;background:#f7fbff}
.dealer-pill--cyclo-vac{color:#b68418;border-color:#ecdcae;background:#fffaf0}
.dealer-pill--sebo{color:#df2b2f;border-color:#f3cccc;background:#fff7f7}
.dealer-pill--sanitaire{color:#d12f2f;border-color:#f4d1d1;background:#fff8f8}
.dealer-pill--karcher{color:#111827;border-color:#f2d64f;background:#fffbe8}
.dealer-pill--hibbert{color:#3e5f8a;border-color:#d4deea;background:#f8fbff}
.dealer-pill--trovac{color:#2f8f86;border-color:#cde8e3;background:#f5fcfa}
.dealer-pill--beam{color:#5a85e8;border-color:#d9e3fb;background:#f7faff}
.dealer-pill--hoover{color:#d81920;border-color:#f4c9cc;background:#fff8f8}
.dealer-pill--dyson{color:#7c65d1;border-color:#ddd4fb;background:#faf8ff}
.dealer-pill--eureka{color:#d32e2e;border-color:#f2cccc;background:#fff8f8}
.dealer-pill--kenmore{color:#1f3f6f;border-color:#d3ddec;background:#f8fbff}
.dealer-pill--filter-queen{color:#563d87;border-color:#ddd3f1;background:#faf8ff}
.dealer-pill--electrolux{color:#164a9e;border-color:#cfddf4;background:#f7fbff}
@keyframes trustMarquee{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 1.75rem))}
}
.topline strong{color:var(--ink)}
.site-header{background:#fff;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px rgba(0,0,0,.03)}
.brand-row{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;min-height:108px;padding:.45rem 0}
.brand{
  display:flex;
  align-items:center;
  gap:1.25rem;
  min-width:0;
}
.brand-logo{
  width:118px;
  height:102px;
  border-radius:22px;
  flex:none;
  object-fit:contain;
}
.brand-copy{
  display:flex;
  flex-direction:column;
  min-width:0;
}
.brand-name{
  font-family:"Montserrat",sans-serif;
  font-weight:800;
  color:var(--ink);
  font-size:clamp(1.35rem,1.6vw,2rem);
  letter-spacing:-.02em;
  line-height:1.06;
}
.brand-tagline{
  margin-top:.18rem;
  font-size:.98rem;
  font-weight:700;
  color:#677793;
  line-height:1.35;
}
.brand-since{
  margin-top:.12rem;
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#8ea0b8;
}
.brand--intro .brand-logo--intro{
  animation:brandLogoSlideIn .95s cubic-bezier(.22,.84,.22,1) both;
}
.brand--intro .brand-copy--intro{
  animation:brandCopyFadeIn 1.05s ease both;
  animation-delay:.12s;
}
@keyframes brandLogoSlideIn{
  0%{opacity:0;transform:translateX(-26px) scale(.84)}
  65%{opacity:1;transform:translateX(4px) scale(1.04)}
  100%{opacity:1;transform:translateX(0) scale(1)}
}
@keyframes brandCopyFadeIn{
  0%{opacity:0;transform:translateX(-10px)}
  100%{opacity:1;transform:translateX(0)}
}
.header-actions{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.header-actions-compact{justify-content:flex-end}
.search-shell{
  background:#f2f4f8;border:1px solid #e7ebf1;border-radius:999px;padding:.2rem .45rem;display:flex;align-items:center;gap:.55rem;min-width:min(420px,42vw)
}
.search-shell input{border:0;background:transparent;outline:none;width:100%;padding:.6rem .2rem;color:var(--ink)}
.search-shell button{border:0;background:var(--navy);color:#fff;border-radius:999px;padding:.65rem .95rem;font-weight:700}
.category-nav{
  background:var(--navy);color:#fff;overflow:auto;white-space:nowrap
}
.category-nav .container{display:flex;align-items:center}
.category-nav a{
  color:#fff;padding:1rem 1.15rem;font-family:"Montserrat",sans-serif;font-weight:700;font-size:.98rem;flex:none;
  border-right:1px solid rgba(255,255,255,.08)
}
.category-nav a.accent{background:var(--red)}
.utility-nav{
  background:#fff;border-bottom:1px solid var(--line)
}
.utility-nav .container{display:flex;gap:1rem;align-items:center;justify-content:space-between;padding:.8rem 0}
.utility-nav-simple-inner{justify-content:center}
.utility-links{display:flex;gap:1rem;flex-wrap:wrap;font-weight:600;color:var(--ink)}
.notice-badges{display:flex;gap:.75rem;flex-wrap:wrap}

.notice-title{
  width:100%;
  text-align:center;
  font-family:"Montserrat",sans-serif;
  font-size:clamp(1.05rem,1.7vw,1.35rem);
  font-weight:800;
  color:var(--ink);
  line-height:1.3;
}
.badge{
  display:inline-flex;align-items:center;gap:.45rem;background:#f2f4f8;color:var(--ink);
  border-radius:999px;padding:.55rem .8rem;font-size:.9rem;font-weight:700
}
.hero-retail{
  padding:2.6rem 0 2rem;background:#eef2f7
}
.hero-retail-clean{padding-top:2.4rem}
.hero-box{
  display:grid;grid-template-columns:1.05fr 1fr;gap:0;background:#e5ebf2;border-radius:32px;overflow:hidden
}
.hero-box-clean{box-shadow:var(--shadow)}
.hero-copy{
  background:rgba(255,255,255,.92);padding:3rem 2.45rem;margin:1.2rem;border-radius:26px;align-self:start;box-shadow:var(--shadow)
}
.hero-copy-clean p{max-width:780px}
.hero-cta-row .btn{min-width:200px}
.hero-copy h1{margin-bottom:1rem;color:#4e6188;max-width:720px}
.hero-image-wrap{
  position: relative;
  min-height: 440px;
  background: #eef2f7;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  overflow: hidden;
}

.hero-image-wrap-clean{
  min-height: 440px;
}

.hero-image-wrap-banner{
  margin: 0;
  border-radius: 26px;
  border: 1px solid #dbe3ee;
  box-shadow: 0 18px 40px rgba(39, 55, 86, 0.10);
  background: #eef2f7;
}

.hero-image-wrap::after{
  display: none;
}

.hero-image{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.hero-image-banner{
  position: static;
  inset: auto;
  mix-blend-mode: normal;
  opacity: 1;
}

.hero-media-column{
  display:grid;
  grid-template-rows:minmax(0,1fr) minmax(0,.88fr);
  gap:1.25rem;
  align-content:start;
  padding:1.2rem 1.2rem 1.2rem 0;
}

.hero-image-wrap-secondary{
  min-height:280px;
  margin:0;
}
.breadcrumbs{font-size:1.15rem;color:#6f7d95;margin:0 0 1.25rem}
.breadcrumbs a{color:#5f6d86}
.breadcrumbs span{margin:0 .4rem}
.category-scroll{
  display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:1rem;align-items:start;margin-top:1.25rem
}
.category-tile{
  display:flex;gap:.9rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:22px;padding:.95rem .9rem;box-shadow:var(--shadow);min-width:0
}
.category-tile > div:last-child{min-width:0}
.category-icon{
  width:88px;height:88px;border-radius:50%;background:#ebebee;display:grid;place-items:center;flex:none
}
.category-icon img{width:66px;height:66px;object-fit:contain}
.category-title{font-family:"Montserrat",sans-serif;font-weight:700;color:#596685;font-size:1.05rem;line-height:1.18}
.category-count{margin-top:.22rem;font-size:.95rem;color:#7f8796}
.shop-section{background:#fff}
.section-head{
  display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:1.6rem
}
.section-head-compact{align-items:center;margin-bottom:1rem}
.browse-categories-section{background:#fff;padding-top:1rem;padding-bottom:3rem}
.section-head p{max-width:820px}
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.product-card{
  background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column
}
.product-media{
  background:#efeff2;min-height:310px;display:grid;place-items:center;padding:1.4rem;position:relative
}
.product-media img{max-height:260px;object-fit:contain}
.product-badge{
  position:absolute;top:1rem;left:1rem;background:#fff;border:1px solid #dfe4ec;color:#5b6881;border-radius:999px;padding:.35rem .7rem;font-size:.8rem;font-weight:700
}
.product-body{padding:1.2rem 1.15rem 1.25rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.product-brand{font-size:.82rem;text-transform:uppercase;letter-spacing:.09em;color:#8b94a5;font-weight:800}
.product-title{font-family:"Montserrat",sans-serif;font-weight:700;color:var(--ink);font-size:1.05rem;line-height:1.35}
.product-desc{font-size:.95rem;color:#697386}
.product-best{font-size:.93rem;color:#4f5c76;background:#f4f7fb;border:1px solid #dbe4f1;border-radius:14px;padding:.7rem .8rem;line-height:1.5}
.product-best strong{color:#384760}
.product-details{border:1px solid var(--line);border-radius:16px;background:#fafbfc}
.product-details summary{cursor:pointer;list-style:none;padding:.85rem .95rem;font-weight:700;color:#48546c;font-size:.92rem}
.product-details summary::-webkit-details-marker{display:none}
.product-details[open] summary{border-bottom:1px solid var(--line)}
.product-detail-copy{padding:.9rem .95rem 1rem;display:grid;gap:.9rem}
.product-detail-section h4{font-size:.88rem;text-transform:uppercase;letter-spacing:.08em;color:#75819b;margin:0 0 .45rem}
.product-detail-section ul{margin:0;padding-left:1rem;color:#667187;font-size:.92rem;line-height:1.55}
.product-detail-section li+li{margin-top:.28rem}
.product-tags{display:flex;flex-wrap:wrap;gap:.45rem}
.tag{background:#f2f4f7;border-radius:999px;padding:.35rem .65rem;font-size:.78rem;font-weight:700;color:#5f6980}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-top:auto;padding-top:.3rem}
.price{font-family:"Montserrat",sans-serif;font-weight:800;color:#394660;font-size:1.1rem}
.panel{
  background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.55rem;box-shadow:var(--shadow)
}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.service-card{
  background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.35rem;box-shadow:var(--shadow)
}
.service-card h3{color:var(--ink)}
.icon-box{
  width:56px;height:56px;border-radius:16px;background:#eef5fb;color:var(--navy);display:grid;place-items:center;
  font-family:"Montserrat",sans-serif;font-weight:800;margin-bottom:1rem
}
.feature-band{
  background:#edf3fa;border-top:1px solid var(--line);border-bottom:1px solid var(--line)
}
.feature-band .container{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1rem 0}
.feature-band-home{background:#f3f7fb}
.feature-band-home-grid{grid-template-columns:repeat(6,1fr)!important}
.feature-chip{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1rem;text-align:center;box-shadow:var(--shadow)}
.feature-chip strong{display:block;color:var(--ink);font-family:"Montserrat",sans-serif;margin-bottom:.2rem}
.split-banner{
  display:grid;grid-template-columns:1.08fr .92fr;gap:1.4rem
}
.image-panel{
  background:#edf3fa;border-radius:28px;min-height:340px;padding:1rem;display:grid;place-items:center
}
.image-panel img{max-height:280px;object-fit:contain}
.callout-dark{
  background:linear-gradient(135deg,#93c6e7,#b8a7dc);color:#fff;border-radius:28px;padding:2rem 2.1rem
}
.callout-dark h2,.callout-dark h3,.callout-dark p{color:#fff}
.tick-list{display:grid;gap:.8rem}
.tick{display:flex;gap:.75rem;align-items:flex-start}
.tick::before{
  content:"✓";display:grid;place-items:center;flex:none;width:1.5rem;height:1.5rem;border-radius:50%;
  background:rgba(255,255,255,.18);font-size:.9rem;font-weight:800;margin-top:.08rem
}
.footer{
  background:#f1f2f5;border-top:1px solid var(--line);padding:3rem 0 1.6rem;margin-top:3rem
}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:1.4rem}
.footer h4{color:var(--ink);margin-bottom:.9rem}
.footer-links{display:grid;gap:.55rem}
.footer-bottom{margin-top:1.7rem;padding-top:1rem;border-top:1px solid #dce1ea;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:#7f8898;font-size:.94rem}
.review-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.4rem;box-shadow:var(--shadow)}
.stars{letter-spacing:.15em;color:#d39d22;margin-bottom:.7rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.info-box{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.2rem;box-shadow:var(--shadow)}
label{display:grid;gap:.45rem;font-weight:700;color:var(--ink)}
input,textarea,select{width:100%;border:1px solid #dce1ea;border-radius:12px;padding:.95rem;background:#fff}
textarea{min-height:150px;resize:vertical}
.map-frame{width:100%;min-height:380px;border:0;border-radius:24px;box-shadow:var(--shadow)}
.page-hero{
  background:#f4f5f7;padding:2.4rem 0 2.8rem;border-bottom:1px solid var(--line)
}
.page-hero .lead{max-width:900px}
.page-banner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:1.6rem;align-items:center
}
.page-banner .panel{padding:2rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden}
.faq-q{width:100%;background:none;border:0;text-align:left;padding:1.05rem 1.15rem;font-weight:800;color:var(--ink);display:flex;justify-content:space-between;gap:1rem}
.faq-a{display:none;padding:0 1.15rem 1.15rem}
.faq-item.open .faq-a{display:block}
.filter-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.2rem}
.filter-chip{
  border:1px solid #dce1ea;background:#fff;color:#596685;border-radius:999px;padding:.55rem .85rem;font-weight:700;font-size:.92rem;cursor:pointer
}
.filter-chip.active{background:var(--navy);border-color:var(--navy);color:#fff}
.hero-mini{
  background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.5rem;box-shadow:var(--shadow)
}
.support-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.center{text-align:center}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mt-3{margin-top:3rem}
.hidden{display:none}



/* --- footer layout fix --- */
.footer-grid{
  align-items:start;
}
.footer .brand{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:.9rem;
  margin-bottom:.85rem;
}
.footer .brand img{
  width:100%;
  max-width:290px;
  height:auto;
  object-fit:contain;
  border-radius:12px;
}
.footer .brand-name{
  font-size:1.55rem;
  line-height:1.08;
  letter-spacing:-.02em;
}
.footer .brand-sub{
  max-width:320px;
  font-size:1rem;
  line-height:1.55;
  color:#6c7890;
}
.footer p{
  max-width:460px;
  font-size:1rem;
  line-height:1.65;
  color:#617089;
}
.footer h4{
  font-size:1.2rem;
  line-height:1.2;
}
.footer-links a,
.footer-links span{
  font-size:1rem;
  line-height:1.55;
  color:#5a6880;
}

@media (max-width:1200px){
  .card-grid,.grid-4{grid-template-columns:repeat(3,1fr)}
  .category-scroll{grid-template-columns:repeat(3,1fr)}
  .feature-band-home-grid{grid-template-columns:repeat(3,1fr)!important}
}
@media (max-width:960px){
  .search-shell{min-width:0;flex:1}
  .trust-topline-inner{padding:.7rem 0 .8rem}
  .hero-box,.split-banner,.page-banner,.contact-grid,.grid-2,.footer-grid,.feature-band .container,.feature-band-home-grid{grid-template-columns:1fr!important}
  .card-grid,.grid-3,.grid-4,.info-grid,.support-grid{grid-template-columns:repeat(2,1fr)}
  .category-scroll{grid-template-columns:repeat(2,1fr)}
  .hero-image-wrap{min-height:320px}
}
@media (max-width:720px){
  .brand-row{align-items:flex-start}
  .brand-logo{width:96px;height:84px}
  .brand-tagline{font-size:.88rem}
  .hero-copy{padding:2rem 1.25rem;margin:.8rem}
  .hero-cta-row .btn{min-width:0;width:100%}
  .trust-marquee-item{padding:0 1rem}

  .topline-inner,.brand-row,.utility-nav .container{flex-direction:column;align-items:flex-start;padding:.7rem 0}
  .header-actions{width:100%}
  .search-shell{width:100%;min-width:0}
  .category-nav a{padding:.9rem .85rem;font-size:.92rem}
  .hero-copy{margin:.8rem;padding:1.6rem}
  .hero-image-wrap{min-height:260px}
  .card-grid,.grid-3,.grid-4,.info-grid,.support-grid,.category-scroll{grid-template-columns:1fr}
  .product-media{min-height:260px}
}

/* --- homepage + quote updates --- */
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:1.4rem;align-items:start}
.story-panel p strong{color:var(--navy)}
.stats-stack{display:grid;gap:1rem}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1.25rem;box-shadow:var(--shadow)}
.stat-card strong{display:block;font-family:"Montserrat",sans-serif;color:var(--navy);font-size:1.1rem;margin-bottom:.35rem}
.service-grid-extended .service-card{min-height:100%}
.service-check-panel{display:grid;gap:1rem}
.service-checks{margin:0;padding:0;list-style:none;display:grid;gap:.75rem}
.service-checks li{position:relative;padding-left:1.8rem;color:var(--muted)}
.service-checks li::before{content:"✓";position:absolute;left:0;top:.05rem;width:1.2rem;height:1.2rem;border-radius:50%;display:grid;place-items:center;background:#e9eef7;color:var(--navy);font-size:.78rem;font-weight:800}
.compact-checks li{font-size:.96rem}
.accent-panel{background:linear-gradient(180deg,#f8fafc,#eef3fb)}
.quote-home-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.4rem;align-items:start}
.mini-process-grid .service-card{height:100%}
.quote-panel,.quote-panel-wide{background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.55rem;box-shadow:var(--shadow)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.file-note{background:#f4f6fa;border:1px dashed #ccd5e4;border-radius:14px;padding:.85rem 1rem;color:#6b7485;font-size:.92rem}
.compact-map{min-height:280px}
.thanks-panel{max-width:720px;margin:0 auto}
@media (max-width:960px){.story-grid,.quote-home-grid,.form-grid-2{grid-template-columns:1fr}}


.miele-partner-card{display:grid;grid-template-columns:220px 1fr auto;gap:1.4rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:28px;padding:1.5rem;box-shadow:var(--shadow)}
.miele-logo-box{background:#f7f8fb;border:1px solid var(--line);border-radius:22px;padding:1rem;display:grid;place-items:center;min-height:130px}
.miele-logo-box img{max-width:180px;width:100%;height:auto;object-fit:contain}
.miele-note{font-size:.92rem;color:var(--muted)}
.miele-inline-logo{margin-top:1rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.miele-inline-logo img{width:180px;max-width:100%;height:auto;border-radius:12px;box-shadow:var(--shadow)}
.review-note{font-size:.92rem;color:var(--muted);margin-top:.9rem}
@media (max-width:960px){.miele-partner-card{grid-template-columns:1fr}.miele-logo-box{max-width:240px}}


/* Sales page filtering */
.sales-filter-bar{display:flex;justify-content:flex-start;align-items:center;gap:1rem;flex-wrap:wrap;padding:1rem 1.1rem;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:var(--shadow)}
.filter-chip-row{display:flex;flex-wrap:wrap;gap:.65rem}
.filter-chip{appearance:none;border:1px solid #cfd8e7;background:#fff;color:#495879;padding:.85rem 1.1rem;min-height:54px;border-radius:999px;font-weight:800;cursor:pointer;transition:.2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;line-height:1;position:relative;white-space:nowrap}
.filter-chip:hover{border-color:#9bb8d7;background:#f5f9fd;color:#31466a;transform:translateY(-1px)}
.filter-chip:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(156,204,235,.32)}
.filter-chip.is-active{background:linear-gradient(135deg,#bfe4fb,#d9d3fb);color:#233a59;border-color:#8fbadd;box-shadow:0 0 0 2px rgba(156,204,235,.18),0 10px 22px rgba(111,132,165,.14)}
.filter-chip.is-active::before{content:"✓";display:inline-grid;place-items:center;width:1.28rem;height:1.28rem;border-radius:50%;background:rgba(255,255,255,.92);color:#5b84b1;font-size:.82rem;font-weight:900;box-shadow:0 2px 8px rgba(91,132,177,.15)}
.filter-chip-brand{background:#fff}
.sales-filter-meta{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1rem}
.filter-summary{color:var(--muted);font-weight:600}
.filter-reset{background:none;border:none;color:var(--navy);font-weight:800;cursor:pointer;padding:0}
.catalog-empty{margin-top:1.5rem;padding:1.5rem;border:1px dashed #cfd9e7;border-radius:18px;background:#fff}
.catalog-empty h3{margin-bottom:.5rem}
@media (max-width: 860px){.sales-filter-bar{align-items:flex-start}.sales-filter-meta{align-items:flex-start}.filter-chip-row{width:100%}.filter-chip{flex:0 0 auto}}

.accessory-filter-bar.hidden,.sales-filter-bar.hidden{display:none}
.accessory-filter-stack{display:grid;gap:1rem}
.accessory-filter-bar{width:100%;align-items:flex-start}
.accessory-filter-bar-primary{padding:1.3rem 1.35rem 1.4rem}
.accessory-filter-bar-secondary{margin-top:.05rem;padding:1rem 1.2rem 1.1rem;background:#fbfcff}
.accessory-filter-label{width:100%;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:900;color:var(--navy-dark);margin-bottom:.15rem}
.accessory-filter-row{width:100%}
.accessory-filter-row-primary .filter-chip{min-height:58px;padding:1rem 1.2rem;font-size:.98rem}
.accessory-filter-row-secondary .filter-chip{min-height:50px;padding:.8rem 1rem;font-size:.94rem}
@media (min-width: 861px){
  .accessory-filter-bar-primary{border-radius:24px}
  .accessory-filter-bar-secondary{max-width:980px;border-radius:22px}
}
@media (max-width: 860px){
  .accessory-filter-bar-primary,.accessory-filter-bar-secondary{padding:1rem}
  .accessory-filter-label{margin-bottom:.3rem}
}


.page-banner{padding:3.8rem 0;background:#eef3f8;border-bottom:1px solid var(--line)}
.services-hero-grid{display:grid;max-width:1180px;margin:0 auto;grid-template-columns:minmax(0,1.18fr) minmax(360px,430px);gap:2.2rem;align-items:center}
.services-hero-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.7rem;box-shadow:var(--shadow);width:100%;justify-self:end}
.compact-checks{padding-left:1.1rem;margin:0;color:var(--ink)}
.compact-checks li+li{margin-top:.7rem}
.services-head-center{justify-content:center;text-align:center}
.services-overview-grid .service-soft-card,.simple-benefits-grid .service-soft-card{background:#fbfcfe}
.services-problem-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:1.4rem;align-items:start}
.service-problems-panel{padding:1.8rem}
.services-problem-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem;margin-top:1.2rem}
.problem-item{background:#f8fafc;border:1px solid #dfe6f0;border-radius:18px;padding:1rem}
.problem-item strong{display:block;color:var(--ink);font-family:"Montserrat",sans-serif;margin-bottom:.25rem}
.problem-item span{font-size:.95rem;color:var(--text)}
.services-builder-callout{min-height:100%}
.retractable-section{background:#fff}
.retractable-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.4rem;align-items:start}
.simple-benefits-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.retractable-visual-stack{display:grid;gap:1rem}
.retractable-image-panel{padding:1rem;background:#f5f8fc}
.retractable-image-panel img{width:100%;border-radius:16px}
.video-panel h3{margin-bottom:.45rem}
.video-frame-wrap{position:relative;padding-top:56.25%;border-radius:18px;overflow:hidden;background:#dfe8f2}
.video-frame-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.cta-strip{background:linear-gradient(135deg,#eaf4fb,#f1edfb);border:1px solid #dbe5f0;border-radius:26px;padding:1.6rem 1.8rem;display:grid;grid-template-columns:1.1fr .9fr;gap:1.2rem;align-items:center}
.simple-service-grid .service-card{min-height:100%}
.home-services-link-row{justify-content:center}
.services-teaser-banner .retractable-teaser-panel p{margin-bottom:0}
.retractable-image-mini{display:grid;place-items:center;background:#f7f9fc}
.retractable-image-mini img{width:100%;max-height:360px;object-fit:contain}
@media (max-width: 980px){.services-hero-grid,.services-problem-grid,.retractable-grid,.cta-strip{grid-template-columns:1fr}.services-problem-list,.simple-benefits-grid{grid-template-columns:1fr}}

.services-hero-copy{max-width:720px}
.services-hero-copy .lead{font-size:1.13rem;max-width:680px}
.services-highlight-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.4rem}
.services-highlight-strip .service-card{background:#fff7;backdrop-filter:blur(2px)}
.service-soft-card p:last-child{margin-bottom:0}
.service-number{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;background:#e9f3fb;color:var(--navy);font-weight:800;font-family:"Montserrat",sans-serif;margin-bottom:.8rem}
.problem-item{min-height:100%}
.brand-spotlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media (max-width:980px){.brand-spotlight-grid,.services-highlight-strip{grid-template-columns:1fr}}


/* Services page layout refinement */
.services-hero{padding:4.75rem 0 3.5rem;}
.services-hero-grid{display:grid;max-width:1200px;margin:0 auto;grid-template-columns:minmax(0,1.25fr) minmax(340px,420px);gap:3rem;align-items:start;}
.services-hero-copy{max-width:760px;}
.services-hero-copy h1{font-size:clamp(2.7rem,4.3vw,4.6rem);line-height:1.06;max-width:11.5ch;letter-spacing:-0.045em;margin-bottom:1.15rem;}
.services-hero-copy .lead{font-size:1.14rem;max-width:60ch;}
.services-hero-card{position:relative;top:0;background:#fff;border:1px solid var(--line);border-radius:26px;padding:1.85rem 1.9rem;box-shadow:0 24px 50px rgba(26,40,70,.08);width:100%;justify-self:stretch;}
.services-hero-card h3{margin-bottom:1rem;font-size:1.85rem;}
.compact-checks{padding-left:0;list-style:none;margin:0;}
.compact-checks li{position:relative;padding-left:2rem;font-size:1.02rem;line-height:1.6;color:var(--ink);}
.compact-checks li+li{margin-top:.95rem;}
.compact-checks li::before{content:"✓";position:absolute;left:0;top:.06rem;width:1.3rem;height:1.3rem;border-radius:50%;display:grid;place-items:center;background:#e8f2ff;color:#5f7aa6;font-weight:800;font-size:.78rem;}
.services-overview-grid,.services-problem-grid,.retractable-grid{align-items:stretch;}
.service-soft-card{padding:1.6rem 1.55rem;}
.services-builder-callout{padding:2rem;}
@media (max-width: 1100px){.services-hero-grid{grid-template-columns:1fr;gap:1.6rem;}.services-hero-copy,.services-hero-copy .lead{max-width:none;}.services-hero-copy h1{max-width:13ch;}.services-hero-card{justify-self:start;max-width:760px;}}
@media (max-width: 768px){.services-hero{padding:3.25rem 0 2.4rem;}.services-hero-copy h1{font-size:clamp(2.2rem,9vw,3.25rem);max-width:none;}.services-hero-card{padding:1.35rem 1.2rem;border-radius:20px;}.compact-checks li{font-size:.98rem;padding-left:1.8rem;}}

@media (prefers-reduced-motion: reduce){
  .trust-marquee-track{animation:none;transform:none}
}


@media (max-width: 1100px){
  .hero-box{grid-template-columns:1fr;}
  .hero-media-column{padding:0 1.2rem 1.2rem 1.2rem;grid-template-rows:auto auto;}
  .hero-copy{margin:1.2rem 1.2rem .6rem 1.2rem;}
}

@media (max-width: 768px){
  .hero-media-column{padding:0 1rem 1rem 1rem;gap:1rem;}
  .hero-copy{padding:2.2rem 1.4rem;}
  .hero-image-wrap-secondary{min-height:220px;}
}


.reviews-contact-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(320px,.95fr);gap:1.6rem;align-items:start}
.reviews-showcase-panel{min-width:0}
.home-review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem}
.google-review-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:1.35rem 1.35rem 1.2rem;box-shadow:var(--shadow)}
.google-review-card__top{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.9rem;margin-bottom:1rem}
.google-review-card__avatar{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#4aa0e6;color:#fff;font-family:"Montserrat",sans-serif;font-size:1.7rem;font-weight:800}
.google-review-card__meta{display:grid;gap:.15rem;min-width:0}
.google-review-card__meta strong{font-family:"Montserrat",sans-serif;font-size:1rem;line-height:1.15;color:#1f2f4d}
.google-review-card__meta span{font-size:.95rem;color:#7e8ba0}
.google-review-card__badge{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #dbe4ef;box-shadow:0 8px 18px rgba(111,132,165,.12);font-family:"Montserrat",sans-serif;font-size:1.2rem;font-weight:800;color:#4285F4}
.google-review-stars{font-size:1.28rem;letter-spacing:.08em;color:#f4b400;margin-bottom:.9rem;line-height:1}
.google-review-card__text{font-size:1rem;line-height:1.55;color:#273655;font-weight:700;margin-bottom:1rem}
.google-review-card__read{font-weight:700;color:#7b8799}
.contact-store-panel{padding:1.85rem}
.contact-store-stack{display:grid;gap:.95rem}
.contact-store-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.05rem 1.15rem;box-shadow:0 10px 22px rgba(111,132,165,.08)}
.contact-store-item h3{margin:0 0 .35rem;font-size:1.15rem}
.contact-store-item p{margin:0;font-weight:700;color:#5d6d85}
.contact-store-actions .btn{flex:1 1 180px}
.contact-store-map{min-height:220px}

@media (max-width: 1180px){
  .reviews-contact-grid{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .home-review-grid{grid-template-columns:1fr}
}


/* Brand palette and typography refinement */
body,
input,
textarea,
select,
button{font-family:"Inter",system-ui,-apple-system,Segoe UI,sans-serif}

h1,h2,h3,h4,
.btn,
.brand-name,
.brand-tagline,
.brand-since,
.category-nav a,
.notice-title,
.badge,
.dealer-label,
.dealer-pill,
.category-title,
.product-title,
.price,
.feature-chip strong,
.footer h4,
.product-detail-section h4,
.google-review-card__meta strong,
.google-review-card__avatar,
.google-review-card__badge{
  font-family:"Montserrat",sans-serif;
}

.topline,
.utility-nav,
.shop-section,
.browse-categories-section,
.page-hero,
.page-banner,
.footer{
  background:#f6f7f9;
}

.trust-topline{background:linear-gradient(180deg,#ffffff 0%, #f7f8fb 100%)}
.trust-marquee-shell{
  border-color:#d6dde8;
  background:linear-gradient(90deg,#fcfdff 0%, #f3f6fb 100%);
  box-shadow:0 10px 24px rgba(39,52,79,.08);
}
.trust-marquee-shell::before{background:linear-gradient(90deg,#fcfdff 25%, rgba(252,253,255,0));}
.trust-marquee-shell::after{background:linear-gradient(270deg,#f3f6fb 25%, rgba(243,246,251,0));}

.eyebrow{
  color:var(--navy);
  background:var(--chip);
}
.eyebrow::before{background:var(--red)}

.btn-primary{
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
}
.btn-primary:hover{
  background:linear-gradient(135deg,var(--navy-dark),#315988);
}
.btn-accent{
  background:linear-gradient(135deg,var(--red),#562281);
}
.btn-secondary:hover{
  border-color:var(--red);
  color:var(--red);
}

.dealer-label{
  background:linear-gradient(135deg,var(--navy),var(--red));
  box-shadow:0 8px 18px rgba(80,136,208,.22);
}

.brand-name,
.hero-copy h1,
.notice-title,
.product-title,
.price,
.google-review-card__meta strong,
.google-review-card__text{
  color:var(--ink);
}
.brand-tagline{color:var(--navy-dark)}
.brand-since{color:var(--red)}
.topline strong,
.utility-links,
label,
.feature-chip strong,
.footer h4,
.contact-store-item h3{color:var(--ink)}

.category-nav{
  background:linear-gradient(90deg,var(--navy) 0%, var(--navy-dark) 55%, var(--red) 100%);
}
.category-nav a.accent{
  background:rgba(255,255,255,.14);
}
.search-shell button{
  background:linear-gradient(135deg,var(--navy),var(--navy-dark));
}

.hero-retail,
.hero-image-wrap,
.hero-image-wrap-banner,
.feature-band,
.feature-band-home,
.image-panel,
.retractable-image-panel,
.retractable-image-mini,
.page-banner,
.callout-dark,
.cta-strip{
  background-color:#eef1f6;
}
.hero-box{background:#e3e8ef}
.hero-copy{
  background:rgba(255,255,255,.95);
}
.callout-dark{
  background:linear-gradient(135deg,var(--navy),var(--red));
}
.cta-strip{
  background:linear-gradient(135deg,rgba(80,136,208,.12),rgba(112,48,160,.12));
  border-color:#d8deea;
}

.icon-box,
.service-number{
  background:rgba(80,136,208,.12);
  color:var(--navy);
}
.service-checks li::before,
.compact-checks li::before{
  background:rgba(80,136,208,.12);
  color:var(--navy-dark);
}

.filter-chip.active,
.filter-chip.is-active{
  background:linear-gradient(135deg,rgba(80,136,208,.18),rgba(112,48,160,.18));
  border-color:rgba(80,136,208,.45);
  color:var(--ink);
}
.filter-chip:hover{
  border-color:rgba(80,136,208,.45);
  background:#f6f9fe;
  color:var(--ink);
}
.filter-chip:focus-visible{
  box-shadow:0 0 0 3px rgba(80,136,208,.18);
}
.filter-chip.is-active::before{
  color:var(--navy);
  box-shadow:0 2px 8px rgba(80,136,208,.18);
}

.google-review-card__avatar{background:var(--navy)}
.google-review-card__badge{
  color:var(--red);
  border-color:#d9deea;
}
.google-review-card__read,
.filter-reset{color:var(--navy-dark)}

a:hover{color:inherit}
