@font-face {
  font-family: "e-Ukraine Head";
  src: url("fonts/e-UkraineHead-Regular.otf") format("opentype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "e-Ukraine Head";
  src: url("fonts/e-UkraineHead-Medium.otf") format("opentype");
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
}

@font-face {
  font-family: "e-Ukraine Head";
  src: url("fonts/e-UkraineHead-Bold.otf") format("opentype");
  font-style: normal;
  font-weight: 800 950;
  font-display: swap;
}

:root {
  --milk: #F5F7F8;
  --milk-soft: #F5F7F8;
  --linen: #F5F7F8;
  --sage: #F5F7F8;
  --green: #8FAE35;
  --green-deep: #1A1D21;
  --font-body: "IBM Plex Sans", Arial, system-ui, sans-serif;
  --font-heading: "e-Ukraine Head", "IBM Plex Sans", Arial, sans-serif;
  --graphite: #1A1D21;
  --ink: #0B0D0F;
  --muted: #7C8791;
  --white: #F5F7F8;
  --line: #2B3137;
  --shadow-soft: 0 18px 48px rgba(11, 13, 15, 0.08);
  --shadow-panel: 0 24px 70px rgba(11, 13, 15, 0.11);
  --motion-ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --motion-ease-soft: cubic-bezier(0.19, 1, 0.22, 1);
  --motion-fast: 200ms;
  --motion-card: 300ms;
  --motion-reveal: 720ms;
  --elx-ink: #0B0D0F;
  --elx-graphite: #1A1D21;
  --elx-green: #8FAE35;
  --elx-surface: #F5F7F8;
  --elx-muted: rgba(26, 29, 33, 0.64);
  --elx-line: rgba(43, 49, 55, 0.12);
  --elx-line-strong: rgba(43, 49, 55, 0.18);
  --elx-radius: 8px;
  --elx-shadow: 0 22px 64px rgba(11, 13, 15, 0.08);
}

body,
button,
input,
select,
textarea {
  font-family: var(--font-body) !important;
}

h1,
h2,
h3,
h4,
.hero h1,
.catalog-hero h1,
.product-title,
.section-head h2,
.section-title,
.statement,
.lead-copy h2,
.lead-modal-dialog h2,
.call-popover h3,
.page-head h1,
.doc h1,
.doc h2,
.legal h1,
.legal h2,
.shop-card h3,
.package h3,
.answer-card h3,
.why-card strong,
.metric strong,
.trust-item strong,
.summary-card strong,
.program-card h3,
.service-card h3,
.footer-cta strong {
  font-family: var(--font-heading) !important;
  font-feature-settings: "kern" 1;
}

/* Final catalog page override. Keep the hub quieter than the homepage hero. */
body:has(.catalog-hero) .catalog-hero h1,
body:has(.catalog-hero) .hero.catalog-hero h1,
body:has(.catalog-hero) .catalog-hero .container > h1 {
  max-width: 820px !important;
  font-size: clamp(50px, 6vw, 82px) !important;
  line-height: 0.98 !important;
}

body:has(.catalog-hero) .catalog-hero .hero-actions .btn,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn::after {
  animation: none !important;
}

body:has(.catalog-hero) .catalog-hero .hero-actions .btn::after {
  content: none !important;
}

@media (max-width: 760px) {
  body:has(.catalog-hero) .catalog-hero h1,
  body:has(.catalog-hero) .hero.catalog-hero h1,
  body:has(.catalog-hero) .catalog-hero .container > h1 {
    max-width: 340px !important;
    font-size: clamp(34px, 9.4vw, 42px) !important;
    line-height: 1.06 !important;
  }
}

/* 10/10 visual system hardening: one disciplined language across the homepage. */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body,
.page {
  max-width: 100%;
  overflow-x: clip;
}

html {
  scroll-padding-top: 96px;
}

.skip-link {
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 1000;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 0 18px;
  border: 2px solid #8FAE35;
  border-radius: 8px;
  background: #0B0D0F;
  color: #F5F7F8;
  font-weight: 900;
  text-decoration: none;
  box-shadow: none;
  transform: translateY(-140%);
  transition: transform 160ms var(--motion-ease);
}

.skip-link:focus-visible {
  box-shadow: 0 16px 42px rgba(11, 13, 15, 0.2);
  transform: translateY(0);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid #8FAE35 !important;
  outline-offset: 3px !important;
  box-shadow: 0 0 0 5px rgba(11, 13, 15, 0.16) !important;
}

img,
picture,
svg {
  max-width: 100%;
}

img {
  height: auto;
}

.container {
  width: min(1180px, calc(100% - clamp(32px, 5vw, 72px))) !important;
}

section {
  padding: clamp(72px, 7vw, 104px) 0 !important;
}

.section-kicker,
.eyebrow {
  color: rgba(26, 29, 33, 0.70) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.section-head {
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.72fr) !important;
  gap: clamp(32px, 5vw, 64px) !important;
  margin-bottom: clamp(32px, 4vw, 52px) !important;
}

.section-head h2,
.process-copy h2,
.trust-copy h2,
.lead-copy h2 {
  color: var(--elx-ink) !important;
  font-size: clamp(34px, 4.2vw, 58px) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
}

.section-head p,
.process-copy p,
.trust-copy p,
.lead-copy p,
.system p,
.package p,
.review-card blockquote {
  color: var(--elx-muted) !important;
  line-height: 1.55 !important;
}

.btn,
.package-action,
.cart-button,
[data-add-cart] {
  min-height: 52px !important;
  border-radius: var(--elx-radius) !important;
  font-weight: 900 !important;
}

.btn-primary,
.package-action.primary,
.cart-button,
[data-add-cart] {
  background: var(--elx-graphite) !important;
  color: var(--elx-surface) !important;
  box-shadow: 0 16px 42px rgba(11, 13, 15, 0.14) !important;
}

.btn-primary:hover,
.package-action.primary:hover,
.cart-button:hover,
[data-add-cart]:hover {
  background: var(--elx-ink) !important;
  transform: translate3d(0, -1px, 0) !important;
  box-shadow: 0 18px 48px rgba(11, 13, 15, 0.18) !important;
}

.btn-soft,
.hero-secondary-link,
.cart-continue,
.item-details {
  border: 1px solid var(--elx-line) !important;
  background: rgba(245, 247, 248, 0.72) !important;
  color: var(--elx-graphite) !important;
  box-shadow: none !important;
}

.hero {
  padding: 22px 0 0 !important;
  background: var(--elx-surface) !important;
}

.hero-inner.container {
  width: min(100% - 48px, 1680px) !important;
  max-width: 1680px !important;
}

.hero-inner {
  display: grid !important;
  grid-template-columns: minmax(560px, 0.9fr) minmax(680px, 1.1fr) !important;
  height: clamp(620px, calc(100vh - 124px), 760px) !important;
  min-height: 0 !important;
  border: 1px solid var(--elx-line) !important;
  border-radius: 10px !important;
  background: var(--elx-surface) !important;
  box-shadow: var(--elx-shadow) !important;
  overflow: hidden !important;
}

.hero-copy {
  width: auto !important;
  min-width: 0 !important;
  padding: clamp(72px, 7vw, 112px) clamp(54px, 6.5vw, 96px) clamp(50px, 5vw, 78px) !important;
  overflow: visible !important;
}

.hero h1 {
  max-width: 640px !important;
  margin-bottom: 22px !important;
  color: var(--elx-ink) !important;
  font-size: clamp(52px, 4.35vw, 68px) !important;
  line-height: 1.02 !important;
}

.hero-text {
  max-width: 540px !important;
  margin-bottom: 28px !important;
  color: rgba(26, 29, 33, 0.66) !important;
  font-size: clamp(18px, 1.35vw, 22px) !important;
}

.hero-copy .hero-actions {
  display: grid !important;
  grid-template-columns: max-content max-content !important;
  align-items: center !important;
  gap: 18px !important;
  width: auto !important;
  max-width: none !important;
}

.hero-actions .btn,
.hero-secondary-link {
  width: auto !important;
  min-height: 54px !important;
  padding: 0 28px !important;
}

@media (prefers-reduced-data: reduce), (max-width: 520px) {
  :root {
    --elx-shadow: 0 12px 34px rgba(11, 13, 15, 0.06);
    --motion-reveal: 1ms;
    --motion-card: 1ms;
    --motion-fast: 1ms;
  }

  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }

  .hero-media::after,
  .site-footer::before {
    opacity: 0.45 !important;
  }
}

.hero-cats {
  display: flex !important;
  gap: 24px 42px !important;
  margin-top: clamp(56px, 7vw, 92px) !important;
}

.hero-cats a {
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: 13px !important;
}

.hero-cats a::before {
  color: var(--elx-green) !important;
}

.hero-media {
  height: 100% !important;
  min-height: 0 !important;
  clip-path: polygon(12% 0, 100% 0, 100% 100%, 0 100%) !important;
}

.hero-media::before {
  inset: 0 auto 0 11.7% !important;
  width: 2px !important;
  background: var(--elx-green) !important;
  opacity: 0.62 !important;
}

.hero-media picture,
.hero-media img {
  height: 100% !important;
  min-height: 0 !important;
}

.hero-media img {
  object-fit: cover !important;
  object-position: 58% center !important;
}

.category-line {
  display: none !important;
}

.manifest {
  padding: 76px 0 68px !important;
  border-top: 1px solid var(--elx-line) !important;
  border-bottom: 1px solid var(--elx-line) !important;
  background: var(--elx-surface) !important;
}

.statement {
  max-width: 1040px !important;
  font-size: clamp(30px, 3.5vw, 48px) !important;
  line-height: 1.08 !important;
}

.why-slider {
  margin-top: 38px !important;
}

.why-controls {
  display: none !important;
}

.why-track {
  display: grid !important;
  grid-auto-flow: initial !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  overflow: visible !important;
  padding: 10px 0 0 !important;
  scroll-snap-type: none !important;
}

.why-card {
  min-height: 176px !important;
  padding: 24px 28px !important;
  border: 0 !important;
  border-left: 1px solid var(--elx-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.why-card:nth-child(4n + 1) {
  border-left: 0 !important;
}

.why-card strong {
  color: var(--elx-ink) !important;
  font-size: clamp(22px, 2vw, 30px) !important;
  line-height: 1.08 !important;
}

.why-card p {
  max-width: 280px !important;
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 14px !important;
}

.systems {
  gap: 16px !important;
  border: 0 !important;
}

.system {
  min-height: 520px !important;
  border: 1px solid var(--elx-line) !important;
  border-radius: var(--elx-radius) !important;
  background: rgba(245, 247, 248, 0.72) !important;
  box-shadow: none !important;
}

.system h3 {
  color: var(--elx-ink) !important;
}

.deep-band {
  padding: 78px 0 !important;
  background: var(--elx-ink) !important;
}

.metrics {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 0 !important;
  border-top: 1px solid rgba(245, 247, 248, 0.12) !important;
}

.metric {
  min-height: 230px !important;
  padding: 28px 34px 22px !important;
  border: 0 !important;
  border-right: 1px solid rgba(245, 247, 248, 0.16) !important;
  background: transparent !important;
}

.metric:last-child {
  border-right: 0 !important;
}

.metric small {
  margin-bottom: 28px !important;
  color: var(--elx-green) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.metric strong {
  margin-bottom: 12px !important;
  color: var(--elx-surface) !important;
  font-size: clamp(24px, 2.2vw, 34px) !important;
}

.metric span {
  max-width: 300px !important;
  color: rgba(245, 247, 248, 0.66) !important;
  font-size: 15px !important;
}

#process {
  padding: 78px 0 86px !important;
  background: var(--elx-surface) !important;
}

.process {
  display: block !important;
}

.process-copy {
  position: static !important;
  margin-bottom: 34px !important;
}

.process-copy h2 {
  max-width: 720px !important;
}

.process-copy p {
  max-width: 620px !important;
}

.timeline {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 22px !important;
  border-top: 1px solid var(--elx-line-strong) !important;
  padding-top: 22px !important;
}

.step {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 18px !important;
  padding: 0 !important;
  border: 0 !important;
}

.step span {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
  color: var(--elx-green) !important;
  font-size: 18px !important;
}

.step span::after {
  content: "";
  height: 1px;
  flex: 1;
  background: rgba(43, 49, 55, 0.18);
}

.step h3 {
  color: var(--elx-ink) !important;
  font-size: clamp(20px, 1.7vw, 26px) !important;
}

.step p {
  max-width: 260px !important;
  margin: 0 !important;
  color: rgba(26, 29, 33, 0.66) !important;
  font-size: 15px !important;
}

.package,
.review-card,
.lead-panel,
.cart-dialog,
.trust-item,
.range-note {
  border-radius: var(--elx-radius) !important;
}

@media (max-width: 1100px) {
  .hero-inner {
    grid-template-columns: 1fr !important;
    height: auto !important;
  }

  .hero-copy {
    padding: 34px 28px 26px !important;
  }

  .hero-media {
    clip-path: none !important;
    height: clamp(260px, 48vw, 430px) !important;
  }

  .hero-media::before {
    inset: 0 0 auto 0 !important;
    width: auto !important;
    height: 2px !important;
    transform: none !important;
  }

  .why-track,
  .metrics,
  .timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .why-card:nth-child(odd),
  .why-card:nth-child(4n + 1) {
    border-left: 0 !important;
  }

  .metric:nth-child(2n) {
    border-right: 0 !important;
  }
}

@media (max-width: 760px) {
  html,
  body,
  .page,
  main,
  section {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .container,
  .hero-inner.container {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }

  section {
    padding: 56px 0 !important;
  }

  .hero {
    padding: 16px 0 0 !important;
  }

  .hero-copy {
    width: 100% !important;
    max-width: calc(100vw - 28px) !important;
    padding: 26px 18px 20px !important;
    overflow: hidden !important;
  }

  .hero h1 {
    max-width: 100% !important;
    font-size: clamp(31px, 8.4vw, 36px) !important;
    line-height: 1.08 !important;
  }

  .hero-text {
    max-width: 100% !important;
    font-size: 15px !important;
  }

  .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    width: calc(100vw - 64px) !important;
    max-width: calc(100vw - 64px) !important;
    gap: 10px !important;
  }

  .hero-actions .btn,
  .hero-actions .btn-primary {
    width: calc(100vw - 64px) !important;
    max-width: calc(100vw - 64px) !important;
    min-width: 0 !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .hero-secondary-link {
    width: auto !important;
    min-height: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  .hero-cats {
    gap: 8px 12px !important;
    margin-top: 22px !important;
  }

  .hero-cats a {
    padding-left: 12px !important;
    font-size: 10.5px !important;
  }

  .hero-media {
    width: 100% !important;
    max-width: 100% !important;
    height: 246px !important;
    overflow: hidden !important;
  }

  .hero-media picture,
  .hero-media img {
    width: 100% !important;
    max-width: 100% !important;
  }

  .hero-media img {
    object-position: 58% center !important;
  }

  .section-head,
  .why-track,
  .metrics,
  .timeline,
  .systems {
    grid-template-columns: 1fr !important;
  }

  .why-track {
    gap: 12px !important;
  }

  .why-card {
    min-height: 0 !important;
    border: 1px solid var(--elx-line) !important;
    border-radius: var(--elx-radius) !important;
    padding: 20px !important;
  }

  .metric {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(245, 247, 248, 0.14) !important;
  }
}

/* Final contrast pass: this must stay at the end of the cascade. */
::selection {
  background: rgba(143, 174, 53, 0.34);
  color: inherit;
}

.deep,
.deep-band,
.catalog-compare,
section[class*="deep"] {
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
}

.deep h1,
.deep h2,
.deep h3,
.deep h4,
.deep strong,
.deep-band h1,
.deep-band h2,
.deep-band h3,
.deep-band h4,
.deep-band strong,
.catalog-compare h1,
.catalog-compare h2,
.catalog-compare h3,
.catalog-compare h4,
.catalog-compare strong,
section[class*="deep"] h1,
section[class*="deep"] h2,
section[class*="deep"] h3,
section[class*="deep"] h4,
section[class*="deep"] strong {
  color: #F5F7F8 !important;
}

.deep p,
.deep li,
.deep span,
.deep-band p,
.deep-band li,
.deep-band span,
.catalog-compare p,
.catalog-compare li,
.catalog-compare span,
section[class*="deep"] p,
section[class*="deep"] li,
section[class*="deep"] span {
  color: rgba(245, 247, 248, 0.74) !important;
}

.deep .section-kicker,
.deep .eyebrow,
.deep .kicker,
.deep small,
.deep-band .section-kicker,
.deep-band .eyebrow,
.deep-band .kicker,
.deep-band small,
.catalog-compare .section-kicker,
.catalog-compare .eyebrow,
.catalog-compare .kicker,
.catalog-compare small,
section[class*="deep"] .section-kicker,
section[class*="deep"] .eyebrow,
section[class*="deep"] .kicker,
section[class*="deep"] small {
  color: #8FAE35 !important;
}

.deep .item,
.deep .system,
.deep .package,
.deep .metric,
.deep-band .item,
.deep-band .system,
.deep-band .package,
.deep-band .metric,
.catalog-compare .item,
.catalog-compare .system,
.catalog-compare .package {
  border-color: rgba(245, 247, 248, 0.14) !important;
  background: rgba(245, 247, 248, 0.035) !important;
}

.deep .item.featured,
.deep-band .item.featured,
.catalog-compare .item.featured {
  background: rgba(245, 247, 248, 0.055) !important;
  border-color: rgba(143, 174, 53, 0.30) !important;
}

.badge,
.dot,
.step-number,
.system-tap,
.check-dot,
.bundle-sale {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
}

.cart-button.is-added,
.cart-button.is-just-added,
[data-add-cart].is-added,
[data-add-cart].is-just-added {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
  border-color: rgba(11, 13, 15, 0.10) !important;
}

.badge *,
.dot *,
.step-number *,
.system-tap *,
.check-dot *,
.bundle-sale *,
.cart-button.is-added *,
.cart-button.is-just-added *,
[data-add-cart].is-added *,
[data-add-cart].is-just-added * {
  color: #0B0D0F !important;
}

/* Homepage hero should feel like a full editorial split, not a framed card. */
body:has(.hero-inner) .hero {
  padding: clamp(20px, 3.4vw, 44px) 0 clamp(34px, 5vw, 70px) !important;
  background: #F5F7F8 !important;
  overflow: hidden !important;
}

body:has(.hero-inner) .hero-inner.container {
  width: min(1540px, calc(100% - 32px)) !important;
  max-width: min(1540px, calc(100% - 32px)) !important;
}

body:has(.hero-inner) .hero-inner {
  height: clamp(620px, 48vw, 760px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

body:has(.hero-inner) .hero-copy {
  padding-left: clamp(38px, 6.4vw, 108px) !important;
  padding-right: clamp(42px, 5.4vw, 86px) !important;
  background: #F5F7F8 !important;
}

body:has(.hero-inner) .hero-media {
  clip-path: polygon(8% 0, 100% 0, 100% 100%, 0 100%) !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

body:has(.hero-inner) .hero-media img {
  object-position: 74% center !important;
}

@media (max-width: 980px) {
  body:has(.hero-inner) .hero-inner.container {
    width: min(100% - 28px, 760px) !important;
    max-width: min(100% - 28px, 760px) !important;
  }

  body:has(.hero-inner) .hero-inner {
    height: auto !important;
    overflow: hidden !important;
  }

  body:has(.hero-inner) .hero-copy {
    padding-left: clamp(20px, 6vw, 42px) !important;
    padding-right: clamp(20px, 6vw, 42px) !important;
  }

  body:has(.hero-inner) .hero-media {
    clip-path: none !important;
  }
}

/* Final category page spacing: keep hero content clear of the sticky header. */
body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
  padding: clamp(104px, 8.6vw, 144px) 0 clamp(52px, 5.5vw, 78px) !important;
  background: #F5F7F8 !important;
  overflow: visible !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
  width: min(1180px, calc(100% - 64px)) !important;
  max-width: min(1180px, calc(100% - 64px)) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  align-items: start !important;
  gap: clamp(48px, 6vw, 86px) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
  max-width: 860px !important;
  margin: 18px 0 24px !important;
  font-size: clamp(58px, 6.6vw, 96px) !important;
  line-height: 0.98 !important;
  letter-spacing: 0 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero p {
  max-width: 780px !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: clamp(19px, 1.65vw, 25px) !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-actions {
  margin-top: 34px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
  align-self: start !important;
  margin-top: 0 !important;
  padding: 24px !important;
  border-radius: 14px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty h2 {
  font-size: clamp(34px, 3.2vw, 48px) !important;
  line-height: 1 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty p {
  font-size: 15px !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty-logo {
  min-height: 128px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero:not(:has(.hero-warranty)) {
  padding-bottom: clamp(34px, 4.2vw, 58px) !important;
}

@media (max-width: 980px) {
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
    padding: 56px 0 42px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
    width: min(100% - 28px, 760px) !important;
    max-width: min(100% - 28px, 760px) !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
    font-size: clamp(42px, 12vw, 64px) !important;
  }
}

/* Final warranty rows geometry: all rows keep the same two-column structure. */
.trust .trust-list {
  border-top: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust .trust-item {
  display: grid !important;
  grid-template-columns: minmax(190px, 250px) minmax(0, 1fr) !important;
  align-items: center !important;
  gap: clamp(30px, 4vw, 48px) !important;
  min-height: 0 !important;
  padding: 30px 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust .trust-item strong,
.trust .trust-item .trust-brand {
  display: block !important;
  max-width: 100% !important;
  color: #8FAE35 !important;
  font-size: clamp(34px, 4vw, 56px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  overflow-wrap: normal !important;
  white-space: normal !important;
}

.trust .trust-item .trust-brand {
  font-size: clamp(34px, 3.8vw, 52px) !important;
}

.trust .trust-item span {
  max-width: 430px !important;
  color: rgba(11, 13, 15, 0.74) !important;
  font-size: 17px !important;
  font-weight: 750 !important;
  line-height: 1.5 !important;
}

@media (max-width: 760px) {
  .trust .trust-item {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    min-height: 0 !important;
    padding: 28px 0 !important;
  }

  .trust .trust-item strong,
  .trust .trust-item .trust-brand {
    font-size: clamp(42px, 16vw, 64px) !important;
  }

  .trust .trust-item span {
    font-size: clamp(19px, 6vw, 25px) !important;
  }
}

body:has(.product-layout) .section-card p {
  color: rgba(26, 29, 33, 0.66) !important;
  font-weight: 520 !important;
  line-height: 1.58 !important;
}

/* Category pages: restore safe top rhythm under sticky navigation. */
body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
  padding: clamp(92px, 8vw, 132px) 0 clamp(56px, 6vw, 86px) !important;
  background: #F5F7F8 !important;
  overflow: visible !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
  width: min(1180px, calc(100% - 64px)) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(310px, 360px) !important;
  gap: clamp(48px, 6vw, 86px) !important;
  align-items: start !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
  max-width: 860px !important;
  margin: 18px 0 24px !important;
  font-size: clamp(58px, 6.6vw, 96px) !important;
  line-height: 0.98 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero p {
  max-width: 780px !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: clamp(19px, 1.65vw, 25px) !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-actions {
  margin-top: 34px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
  align-self: start !important;
  margin-top: 0 !important;
  padding: 24px !important;
  border-radius: 14px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty-logo {
  min-height: 128px !important;
}

@media (max-width: 980px) {
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
    padding: 54px 0 42px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
    width: min(100% - 28px, 760px) !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
    font-size: clamp(42px, 12vw, 64px) !important;
  }
}

/* Trust rows: keep the same two-column geometry for all rows. */
.trust-list {
  border-top: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust-item {
  display: grid !important;
  grid-template-columns: minmax(360px, 0.42fr) minmax(0, 1fr) !important;
  align-items: center !important;
  gap: clamp(44px, 6vw, 86px) !important;
  min-height: 220px !important;
  padding: clamp(34px, 4.2vw, 56px) 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust-item strong,
.trust-item .trust-brand {
  display: block !important;
  max-width: 100% !important;
  color: #1A1D21 !important;
  font-size: clamp(54px, 5.8vw, 88px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
}

.trust-item span {
  max-width: 620px !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: clamp(22px, 2.1vw, 34px) !important;
  font-weight: 820 !important;
  line-height: 1.48 !important;
}

@media (max-width: 760px) {
  .trust-item {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    gap: 12px !important;
    padding: 28px 0 !important;
  }

  .trust-item strong,
  .trust-item .trust-brand {
    font-size: clamp(40px, 12vw, 56px) !important;
  }

  .trust-item span {
    font-size: 17px !important;
  }
}

.note,
.range-note,
.trust-note,
.warranty-card,
.legal-card {
  color: rgba(26, 29, 33, 0.76) !important;
}

.cart-button.is-added,
.cart-button.is-just-added,
[data-add-cart].is-added,
[data-add-cart].is-just-added {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
  border-color: rgba(11, 13, 15, 0.10) !important;
}

.cart-button.is-added *,
.cart-button.is-just-added *,
[data-add-cart].is-added *,
[data-add-cart].is-just-added * {
  color: #0B0D0F !important;
}

/* Product pages: quieter engineering-grade product presentation. */
body:has(.product-layout) {
  background:
    linear-gradient(180deg, #F5F7F8 0%, #F5F7F8 58%, rgba(124, 135, 145, 0.08) 100%) !important;
}

body:has(.product-layout) main {
  padding: clamp(34px, 4.4vw, 62px) 0 clamp(72px, 8vw, 110px) !important;
}

body:has(.product-layout) .product-layout {
  grid-template-columns: minmax(390px, 0.92fr) minmax(0, 1.08fr) !important;
  gap: clamp(34px, 5vw, 64px) !important;
  align-items: start !important;
}

body:has(.product-layout) .gallery {
  gap: 14px !important;
}

body:has(.product-layout) .gallery-main {
  position: relative !important;
  min-height: clamp(430px, 42vw, 560px) !important;
  overflow: hidden !important;
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-radius: 14px !important;
  background:
    linear-gradient(145deg, #F5F7F8 0%, #F5F7F8 58%, #F5F7F8 100%) !important;
  box-shadow:
    0 28px 72px rgba(11, 13, 15, 0.11),
    inset 0 1px 0 rgba(245, 247, 248, 0.72) !important;
}

body:has(.product-layout) .gallery-main::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.045;
  background:
    linear-gradient(116deg, transparent 0 56%, #1A1D21 56.15% 56.45%, transparent 56.6% 100%);
}

body:has(.product-layout) .gallery-main::after {
  content: "";
  position: absolute;
  inset: auto 28px 24px 28px;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(43, 49, 55, 0.18), transparent);
}

body:has(.product-layout) .gallery-main img {
  position: relative !important;
  z-index: 1 !important;
  width: min(64%, 370px) !important;
  max-height: 440px !important;
  filter: drop-shadow(0 30px 34px rgba(11, 13, 15, 0.16)) !important;
}

body:has(.product-layout) .battery-gallery .gallery-main img {
  width: min(70%, 400px) !important;
}

body:has(.product-layout) .thumb {
  height: 88px !important;
  border-radius: 10px !important;
  border-color: rgba(43, 49, 55, 0.12) !important;
  background: rgba(245, 247, 248, 0.82) !important;
  box-shadow: none !important;
  transition: transform var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease) !important;
}

body:has(.product-layout) .thumb:hover,
body:has(.product-layout) .thumb.is-active {
  transform: translate3d(0, -1px, 0) !important;
  border-color: rgba(143, 174, 53, 0.62) !important;
  background: #F5F7F8 !important;
}

body:has(.product-layout) .product-info {
  max-width: 700px !important;
}

body:has(.product-layout) .crumb {
  margin-bottom: 22px !important;
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

body:has(.product-layout) .kicker {
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

body:has(.product-layout) h1 {
  max-width: 640px !important;
  margin: 10px 0 18px !important;
  font-size: clamp(34px, 3.25vw, 50px) !important;
  line-height: 1.04 !important;
}

body:has(.product-layout) .badges {
  gap: 8px !important;
  margin-bottom: 22px !important;
}

body:has(.product-layout) .badge {
  min-height: 34px !important;
  padding: 0 12px !important;
  border-color: rgba(43, 49, 55, 0.12) !important;
  background: rgba(245, 247, 248, 0.76) !important;
  color: rgba(26, 29, 33, 0.68) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  box-shadow: none !important;
}

body:has(.product-layout) .price {
  margin: 18px 0 24px !important;
  color: #0B0D0F !important;
  font-size: clamp(38px, 3.6vw, 54px) !important;
  letter-spacing: 0 !important;
}

body:has(.product-layout) .actions {
  grid-template-columns: minmax(180px, 0.92fr) minmax(220px, 1fr) !important;
  gap: 10px !important;
  max-width: 560px !important;
  margin-bottom: 22px !important;
}

body:has(.product-layout) .actions .btn {
  min-height: 52px !important;
  border-radius: 10px !important;
  box-shadow: 0 15px 32px rgba(11, 13, 15, 0.14) !important;
}

body:has(.product-layout) .actions .btn.secondary {
  border-color: rgba(43, 49, 55, 0.14) !important;
  background: rgba(245, 247, 248, 0.82) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

body:has(.product-layout) .section-tabs {
  gap: 8px !important;
  margin-bottom: 16px !important;
}

body:has(.product-layout) .section-tab {
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 10px !important;
  background: rgba(245, 247, 248, 0.72) !important;
  color: rgba(26, 29, 33, 0.66) !important;
  font-size: 14px !important;
}

body:has(.product-layout) .section-tab:hover,
body:has(.product-layout) .section-tab.is-active {
  border-color: rgba(26, 29, 33, 0.86) !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
}

body:has(.product-layout) .section-card,
body:has(.product-layout) .delivery-payment-block,
body:has(.product-layout) .bundle-card {
  border-color: rgba(43, 49, 55, 0.11) !important;
  border-radius: 14px !important;
  background: rgba(245, 247, 248, 0.78) !important;
  box-shadow: 0 12px 38px rgba(11, 13, 15, 0.045) !important;
}

body:has(.product-layout) .section-card {
  padding: clamp(20px, 2.4vw, 28px) !important;
}

body:has(.product-layout) .section-card p,
body:has(.product-layout) .kit-list li,
body:has(.product-layout) .delivery-list li,
body:has(.product-layout) .spec-row {
  color: rgba(26, 29, 33, 0.68) !important;
  font-size: 16px !important;
  line-height: 1.55 !important;
}

body:has(.product-layout) .kit-list li::before,
body:has(.product-layout) .delivery-list li::before {
  width: 6px !important;
  height: 6px !important;
  background: #8FAE35 !important;
}

body:has(.product-layout) .spec-panel {
  border-color: rgba(43, 49, 55, 0.11) !important;
}

body:has(.product-layout) .spec-row {
  grid-template-columns: minmax(150px, 0.34fr) 1fr !important;
  border-color: rgba(43, 49, 55, 0.09) !important;
}

body:has(.product-layout) .spec-row strong,
body:has(.product-layout) .delivery-payment-block h3,
body:has(.product-layout) .bundle-price strong {
  color: #1A1D21 !important;
}

body:has(.product-layout) .bundle-highlight {
  border-color: rgba(43, 49, 55, 0.12) !important;
  border-radius: 14px !important;
  background: rgba(245, 247, 248, 0.78) !important;
  color: #1A1D21 !important;
}

body:has(.product-layout) .bundle-visual {
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-radius: 12px !important;
  background:
    linear-gradient(145deg, #F5F7F8 0%, #F5F7F8 60%, #F5F7F8 100%) !important;
  color: rgba(26, 29, 33, 0.48) !important;
}

body:has(.product-layout) .bundle-sale,
body:has(.product-layout) .bundle-chip {
  border-color: rgba(43, 49, 55, 0.11) !important;
  background: rgba(245, 247, 248, 0.82) !important;
  color: rgba(26, 29, 33, 0.70) !important;
  box-shadow: none !important;
}

@media (max-width: 900px) {
  body:has(.product-layout) .product-layout {
    grid-template-columns: 1fr !important;
  }

  body:has(.product-layout) .gallery {
    position: static !important;
  }

  body:has(.product-layout) .gallery-main {
    min-height: clamp(340px, 72vw, 460px) !important;
  }

  body:has(.product-layout) .actions {
    grid-template-columns: 1fr !important;
    max-width: none !important;
  }
}

@media (max-width: 560px) {
  body:has(.product-layout) main {
    padding-top: 24px !important;
  }

  body:has(.product-layout) .gallery-main {
    min-height: 320px !important;
    border-radius: 12px !important;
  }

  body:has(.product-layout) .gallery-main img,
  body:has(.product-layout) .battery-gallery .gallery-main img {
    width: min(78%, 300px) !important;
    max-height: 270px !important;
  }

  body:has(.product-layout) .thumb {
    height: 70px !important;
  }

  body:has(.product-layout) h1 {
    font-size: clamp(30px, 8.2vw, 36px) !important;
  }

  body:has(.product-layout) .spec-row {
    grid-template-columns: 1fr !important;
    gap: 5px !important;
  }
}

/* Final contrast pass: green is an accent, dark sections must keep readable primary text. */
::selection {
  background: rgba(143, 174, 53, 0.34);
  color: inherit;
}

.deep,
.deep-band,
.catalog-compare,
section[class*="deep"] {
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
}

.deep h1,
.deep h2,
.deep h3,
.deep h4,
.deep strong,
.deep-band h1,
.deep-band h2,
.deep-band h3,
.deep-band h4,
.deep-band strong,
.catalog-compare h1,
.catalog-compare h2,
.catalog-compare h3,
.catalog-compare h4,
.catalog-compare strong,
section[class*="deep"] h1,
section[class*="deep"] h2,
section[class*="deep"] h3,
section[class*="deep"] h4,
section[class*="deep"] strong {
  color: #F5F7F8 !important;
}

.deep p,
.deep li,
.deep span,
.deep-band p,
.deep-band li,
.deep-band span,
.catalog-compare p,
.catalog-compare li,
.catalog-compare span,
section[class*="deep"] p,
section[class*="deep"] li,
section[class*="deep"] span {
  color: rgba(245, 247, 248, 0.74) !important;
}

.deep .section-kicker,
.deep .eyebrow,
.deep .kicker,
.deep small,
.deep-band .section-kicker,
.deep-band .eyebrow,
.deep-band .kicker,
.deep-band small,
.catalog-compare .section-kicker,
.catalog-compare .eyebrow,
.catalog-compare .kicker,
.catalog-compare small,
section[class*="deep"] .section-kicker,
section[class*="deep"] .eyebrow,
section[class*="deep"] .kicker,
section[class*="deep"] small {
  color: #8FAE35 !important;
}

.deep .metric strong,
.deep-band .metric strong {
  color: #F5F7F8 !important;
}

.deep .metric span,
.deep-band .metric span {
  color: rgba(245, 247, 248, 0.72) !important;
}

.deep .item,
.deep .system,
.deep .package,
.deep .metric,
.deep-band .item,
.deep-band .system,
.deep-band .package,
.deep-band .metric,
.catalog-compare .item,
.catalog-compare .system,
.catalog-compare .package {
  border-color: rgba(245, 247, 248, 0.14) !important;
  background: rgba(245, 247, 248, 0.035) !important;
}

.deep .item.featured,
.deep-band .item.featured,
.catalog-compare .item.featured {
  background: rgba(245, 247, 248, 0.055) !important;
  border-color: rgba(143, 174, 53, 0.30) !important;
}

.badge,
.dot,
.step-number,
.system-tap,
.check-dot,
.bundle-sale {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
}

.badge *,
.dot *,
.step-number *,
.system-tap *,
.check-dot *,
.bundle-sale * {
  color: #0B0D0F !important;
}

.note,
.range-note,
.trust-note,
.warranty-card,
.legal-card {
  color: rgba(26, 29, 33, 0.76) !important;
}

/* Final catalog page override. Keep the hub quieter than the homepage hero. */
body:has(.catalog-hero) .catalog-hero h1,
body:has(.catalog-hero) .hero.catalog-hero h1,
body:has(.catalog-hero) .catalog-hero .container > h1 {
  max-width: 820px !important;
  font-size: clamp(50px, 6vw, 82px) !important;
  line-height: 0.98 !important;
}

body:has(.catalog-hero) .catalog-hero .hero-actions .btn,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn::after {
  animation: none !important;
}

body:has(.catalog-hero) .catalog-hero .hero-actions .btn::after {
  content: none !important;
}

@media (max-width: 760px) {
  body:has(.catalog-hero) .catalog-hero h1,
  body:has(.catalog-hero) .hero.catalog-hero h1,
  body:has(.catalog-hero) .catalog-hero .container > h1 {
    max-width: 340px !important;
    font-size: clamp(34px, 9.4vw, 42px) !important;
    line-height: 1.06 !important;
  }
}

/* Content density 10/10: shorter copy, calmer cards, faster scanning. */
.statement {
  max-width: 900px !important;
}

.why-slider {
  margin-top: 30px !important;
}

.why-card {
  min-height: 154px !important;
  padding-top: 22px !important;
  padding-bottom: 22px !important;
}

.why-card strong {
  font-size: clamp(20px, 1.65vw, 26px) !important;
}

.section-head p,
.trust-copy p,
.reviews-head p,
.process-copy p,
.lead-copy p {
  max-width: 620px !important;
}

.system {
  min-height: 470px !important;
}

.system p,
.metric span,
.package p,
.review-card blockquote,
.common-item,
.package-discount span {
  font-size: 15px !important;
  line-height: 1.48 !important;
}

.metrics {
  align-items: stretch !important;
}

.metric {
  min-height: 190px !important;
}

.trust-copy h2 {
  max-width: 620px !important;
}

.trust-item span {
  max-width: 560px !important;
}

.review-card {
  min-height: 214px !important;
}

.packages {
  gap: 18px !important;
}

.package.has-media > div:first-child {
  min-height: 100% !important;
}

.package-media {
  min-height: 180px !important;
}

.lead-copy {
  gap: 28px !important;
}

@media (max-width: 980px) {
  .why-track {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .why-card:nth-child(odd) {
    border-left: 0 !important;
  }
}

@media (max-width: 760px) {
  .statement {
    font-size: clamp(25px, 7.2vw, 31px) !important;
  }

  .why-slider {
    margin-top: 24px !important;
  }

  .why-track {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-auto-columns: initial !important;
    gap: 10px !important;
    overflow: visible !important;
    padding-right: 0 !important;
  }

  .why-card,
  .why-card:nth-child(odd),
  .why-card:nth-child(4n + 1) {
    min-height: auto !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 8px !important;
  }

  .why-card strong {
    font-size: 22px !important;
  }

  .system {
    min-height: 390px !important;
  }

  .system p,
  .metric span,
  .package p,
  .review-card blockquote {
    font-size: 14px !important;
  }

  .metric {
    min-height: auto !important;
    padding: 22px 0 !important;
  }

  .review-card {
    min-height: auto !important;
  }

  .package-media {
    min-height: 160px !important;
  }
}

/* CTA hierarchy 9/10: one primary path, quieter utility actions. */
body:not(.cart-has-items) .topbar .cart-nav,
body:not(.cart-has-items) .cart-nav {
  opacity: 0.44 !important;
  box-shadow: none !important;
  transform: none !important;
}

body:not(.cart-has-items) .topbar .cart-nav:hover,
body:not(.cart-has-items) .cart-nav:hover {
  opacity: 0.72 !important;
  border-color: rgba(43, 49, 55, 0.18) !important;
  background: rgba(245, 247, 248, 0.62) !important;
}

.topbar .cart-count[hidden],
.cart-count[hidden] {
  display: none !important;
}

.package-action.primary {
  min-height: 48px !important;
  padding-inline: 18px !important;
  box-shadow: 0 12px 30px rgba(11, 13, 15, 0.10) !important;
}

.package-action.primary:hover {
  box-shadow: 0 14px 34px rgba(11, 13, 15, 0.14) !important;
}

.lead-modal-form .btn,
.lead-form .btn {
  width: fit-content !important;
  min-width: min(100%, 260px) !important;
}

.call-widget {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translate3d(0, 8px, 0) !important;
  transition: opacity 220ms var(--motion-ease), visibility 220ms var(--motion-ease), transform 220ms var(--motion-ease) !important;
}

.call-widget.is-visible,
.call-widget.is-open {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: translate3d(0, 0, 0) !important;
}

.call-button {
  width: 56px !important;
  height: 56px !important;
  animation: none !important;
  opacity: 0.92 !important;
}

.call-button svg {
  width: 23px !important;
  height: 23px !important;
}

@media (max-width: 760px) {
  .hero-actions .hero-secondary-link {
    width: fit-content !important;
    min-height: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #1A1D21 !important;
    text-decoration: none !important;
  }

  .hero-actions .hero-secondary-link::after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 1px;
    margin-left: 9px;
    vertical-align: middle;
    background: #8FAE35;
    transform: rotate(-62deg);
  }

  .package-action.primary,
  .lead-form .btn,
  .lead-modal-form .btn {
    width: 100% !important;
  }

  .call-widget {
    right: 16px !important;
    bottom: 16px !important;
  }

  .call-button {
    width: 52px !important;
    height: 52px !important;
  }
}

/* Psychological UX 9/10: reduce anxiety, clarify scenarios, avoid retail pressure. */
.cta-reassurance {
  margin: 12px 0 0 !important;
  max-width: 440px !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
}

.package-discounts {
  gap: 12px !important;
  margin-bottom: 18px !important;
}

.package-discount {
  grid-template-columns: 1fr !important;
  align-items: start !important;
  gap: 7px !important;
  min-height: auto !important;
  padding: 18px 20px !important;
  border-color: rgba(43, 49, 55, 0.12) !important;
  background: rgba(245, 247, 248, 0.48) !important;
  box-shadow: none !important;
}

.package-discount strong {
  color: #1A1D21 !important;
  font-size: 17px !important;
  line-height: 1.25 !important;
  white-space: normal !important;
}

.package-discount span {
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
}

.financial-note {
  display: grid !important;
  gap: 7px !important;
  margin: 0 0 18px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-left: 3px solid #8FAE35 !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.66) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

.financial-note span {
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.financial-note strong {
  min-width: 0 !important;
  max-width: 100% !important;
  color: #1A1D21 !important;
  font-size: clamp(15px, 1.5vw, 18px) !important;
  font-weight: 900 !important;
  line-height: 1.35 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.financial-note em {
  min-width: 0 !important;
  max-width: 100% !important;
  color: rgba(26, 29, 33, 0.7) !important;
  font-style: normal !important;
  font-weight: 780 !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.shop-results > .financial-note {
  margin-bottom: 14px !important;
}

.shop-card .item-price::after {
  content: "Спецумови" !important;
  display: block !important;
  margin-top: 7px !important;
  color: rgba(26, 29, 33, 0.52) !important;
  font-size: 11px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
}

@media (max-width: 760px) {
  .financial-note {
    padding: 14px 16px !important;
  }

  .financial-note em {
    display: none !important;
  }
}

.package.has-media > div:first-child {
  grid-template-rows: auto auto auto minmax(170px, 1fr) auto !important;
  gap: 0 !important;
}

.package-scenario {
  display: inline-flex !important;
  width: fit-content !important;
  margin-bottom: 12px !important;
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.package-scenario::before {
  content: "/";
  margin-right: 8px;
  color: #8FAE35;
}

.package-note {
  display: block !important;
  max-width: 280px !important;
  margin-top: 2px !important;
  color: rgba(26, 29, 33, 0.56) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1.42 !important;
}

.trust-list {
  gap: 0 !important;
}

.trust-item strong {
  font-size: clamp(27px, 3vw, 42px) !important;
}

.trust-item strong:not(.trust-brand) {
  text-transform: none !important;
}

.lead-copy p {
  max-width: 680px !important;
}

.contact-facts span:first-child {
  border-color: rgba(143, 174, 53, 0.28) !important;
  color: #1A1D21 !important;
  background: rgba(143, 174, 53, 0.08) !important;
}

@media (max-width: 760px) {
  .cta-reassurance {
    max-width: 310px !important;
    margin-top: 10px !important;
    font-size: 12.5px !important;
  }

  .package-discounts,
  .package-common {
    gap: 10px !important;
  }

  .package.has-media > div:first-child {
    grid-template-rows: auto auto auto minmax(150px, auto) auto !important;
  }

  .package-scenario {
    margin-bottom: 10px !important;
  }

  .package-note {
    max-width: 100% !important;
  }
}

/* Catalog hub: calm engineering selector above the detailed category pages. */
.catalog-hero h1 {
  max-width: 820px !important;
  font-size: clamp(50px, 6vw, 82px) !important;
  line-height: 0.98 !important;
}

.catalog-hero .hero-actions .btn::after {
  content: none !important;
}

.catalog-hero .hero-actions .btn {
  animation: none !important;
}

@media (max-width: 760px) {
  .catalog-hero h1 {
    max-width: 340px !important;
    font-size: clamp(34px, 9.4vw, 42px) !important;
    line-height: 1.06 !important;
  }

  .catalog-hero p {
    max-width: 340px !important;
    font-size: 15px !important;
  }
}

html {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}

body {
  color: #0B0D0F;
  background: #F5F7F8;
  overflow-x: hidden;
}

.page,
body {
  background:
    linear-gradient(180deg, rgba(245, 247, 248, 0.98), rgba(245, 247, 248, 1) 44%, rgba(124, 135, 145, 0.10) 100%) !important;
}

.container {
  width: min(1180px, calc(100% - 52px));
}

.topbar {
  border-bottom: 0 !important;
  background: rgba(245, 247, 248, 0.96) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  transition: background var(--motion-card) var(--motion-ease), box-shadow var(--motion-card) var(--motion-ease), border-color var(--motion-card) var(--motion-ease) !important;
}

.topbar .brand img,
.brand img {
  box-shadow: none !important;
  filter: none !important;
  text-shadow: none !important;
  mix-blend-mode: normal !important;
  backdrop-filter: none !important;
}

.topbar .nav-links,
.nav-links {
  color: rgba(11, 13, 15, 0.62) !important;
  letter-spacing: 0 !important;
}

.topbar .nav-links a:hover,
.nav-links a:hover,
.nav-menu:hover .nav-trigger,
.nav-menu:focus-within .nav-trigger {
  color: #1A1D21 !important;
}

.topbar .nav-links a,
.nav-links a,
.nav-trigger {
  transition: color var(--motion-fast) var(--motion-ease), opacity var(--motion-fast) var(--motion-ease) !important;
}

.topbar .cart-nav,
.cart-nav,
.menu-toggle {
  border-color: rgba(43, 49, 55, 0.14) !important;
  background: rgba(245, 247, 248, 0.78) !important;
  color: #1A1D21 !important;
}

.topbar .cart-nav:hover,
.cart-nav:hover {
  border-color: rgba(143, 174, 53, 0.42) !important;
  background: rgba(143, 174, 53, 0.12) !important;
  transform: translateY(-1px) !important;
}

.cart-count {
  border-color: #F5F7F8 !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
}

.btn,
.topbar .btn,
.topbar .cta,
.cart-button,
[data-add-cart] {
  border-radius: 8px !important;
  transition: transform var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), opacity var(--motion-fast) var(--motion-ease) !important;
}

.btn-primary,
.topbar .btn,
.topbar .cta,
.lead-form .btn,
.callback-form .btn,
.cart-form .btn,
.cart-button,
[data-add-cart] {
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  box-shadow: 0 14px 32px rgba(11, 13, 15, 0.16) !important;
}

.btn-primary:hover,
.topbar .btn:hover,
.topbar .cta:hover,
.lead-form .btn:hover,
.callback-form .btn:hover,
.cart-form .btn:hover,
.cart-button:hover,
[data-add-cart]:hover {
  background: #0B0D0F !important;
  box-shadow: 0 18px 40px rgba(11, 13, 15, 0.18) !important;
  transform: translateY(-1px) !important;
}

.btn-soft,
.item-details,
.cart-continue,
.filter-chip,
.product-actions .btn:not(.btn-primary) {
  border-color: rgba(43, 49, 55, 0.14) !important;
  background: rgba(245, 247, 248, 0.76) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

.btn-soft:hover,
.item-details:hover,
.cart-continue:hover,
.filter-chip:hover {
  border-color: rgba(143, 174, 53, 0.42) !important;
  background: rgba(143, 174, 53, 0.10) !important;
}

.hero-actions .btn-primary,
.call-button,
.floating-call {
  animation: none !important;
}

.hero-actions .btn-primary::after {
  opacity: 0 !important;
  animation: none !important;
}

.mega-menu,
.cart-dialog,
.lead-modal-dialog,
.callback-modal-dialog,
.lead-panel,
.package,
.item,
.shop-card,
.guide-card,
.metric,
.review-card,
.system,
.benefit-card,
.doc-card,
.warranty-card {
  border-color: rgba(43, 49, 55, 0.12) !important;
  box-shadow: var(--shadow-soft) !important;
  transition: transform var(--motion-card) var(--motion-ease), box-shadow var(--motion-card) var(--motion-ease), border-color var(--motion-card) var(--motion-ease), background var(--motion-card) var(--motion-ease), opacity var(--motion-card) var(--motion-ease) !important;
}

.package:hover,
.item:hover,
.shop-card:hover,
.guide-card:hover,
.metric:hover,
.review-card:hover,
.system:hover,
.benefit-card:hover,
.doc-card:hover,
.warranty-card:hover {
  border-color: rgba(43, 49, 55, 0.20) !important;
  box-shadow: 0 22px 62px rgba(11, 13, 15, 0.105) !important;
  transform: translate3d(0, -2px, 0) !important;
}

.cart-dialog,
.lead-modal-dialog,
.callback-modal-dialog,
.lead-panel {
  background: rgba(245, 247, 248, 0.98) !important;
}

.lead-panel {
  position: relative !important;
  overflow: hidden !important;
  gap: clamp(28px, 5vw, 58px) !important;
  padding: clamp(28px, 4vw, 48px) !important;
  border-color: rgba(43, 49, 55, 0.10) !important;
  background:
    linear-gradient(145deg, rgba(245, 247, 248, 0.99), rgba(245, 247, 248, 0.91)) !important;
  box-shadow: 0 28px 82px rgba(11, 13, 15, 0.10) !important;
}

.lead-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.045;
  background: linear-gradient(116deg, transparent 0 55%, #1A1D21 55.2% 55.45%, transparent 55.7% 100%);
}

.lead-copy,
.lead-form {
  position: relative;
}

.lead-copy {
  justify-content: center !important;
}

.lead-copy h2 {
  max-width: 620px !important;
  margin-bottom: 18px !important;
  font-size: clamp(34px, 4.4vw, 58px) !important;
  line-height: 1.04 !important;
}

.lead-copy p {
  max-width: 560px !important;
  color: rgba(11, 13, 15, 0.66) !important;
  font-size: clamp(16px, 1.4vw, 18px) !important;
  line-height: 1.62 !important;
}

.contact-facts {
  gap: 10px !important;
  margin-top: 8px !important;
}

.contact-facts span {
  width: fit-content;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  padding: 0 13px;
  border: 1px solid rgba(43, 49, 55, 0.10);
  border-radius: 999px;
  background: rgba(245, 247, 248, 0.66);
  color: rgba(11, 13, 15, 0.70);
  font-size: 13px;
  font-weight: 900;
}

.lead-form {
  gap: 18px !important;
  padding: clamp(20px, 3vw, 30px) !important;
  border-color: rgba(43, 49, 55, 0.10) !important;
  border-radius: 18px !important;
  background: rgba(245, 247, 248, 0.72) !important;
  box-shadow: inset 0 1px 0 rgba(245, 247, 248, 0.75) !important;
}

.lead-form label,
.lead-modal-form label,
.callback-form label,
.cart-form label {
  gap: 9px !important;
  color: rgba(11, 13, 15, 0.62) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.lead-form input,
.lead-form select,
.lead-form textarea,
.lead-modal-form input,
.lead-modal-form select,
.lead-modal-form textarea,
.callback-form input,
.cart-form input,
.cart-form select,
.cart-form textarea {
  border-radius: 12px !important;
  border-color: rgba(43, 49, 55, 0.13) !important;
  background-color: rgba(245, 247, 248, 0.90) !important;
  font-weight: 720 !important;
}

.lead-form select,
.lead-modal-form select,
.cart-form select {
  appearance: none !important;
  padding-right: 44px !important;
  background-image: linear-gradient(45deg, transparent 50%, rgba(26, 29, 33, 0.70) 50%), linear-gradient(135deg, rgba(26, 29, 33, 0.70) 50%, transparent 50%) !important;
  background-position: calc(100% - 22px) 50%, calc(100% - 16px) 50% !important;
  background-size: 6px 6px, 6px 6px !important;
  background-repeat: no-repeat !important;
}

.lead-form textarea,
.lead-modal-form textarea,
.cart-form textarea {
  line-height: 1.45 !important;
}

.lead-form .btn,
.lead-modal-form .btn,
.callback-form .btn {
  min-height: 56px !important;
  border-radius: 12px !important;
  box-shadow: 0 16px 34px rgba(11, 13, 15, 0.14) !important;
}

.mega-menu {
  background: rgba(245, 247, 248, 0.98) !important;
}

.deep,
.deep-band {
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
}

.site-footer {
  background:
    radial-gradient(circle at 14% 0%, rgba(143, 174, 53, 0.055), transparent 34%),
    linear-gradient(145deg, #1A1D21 0%, #0B0D0F 54%, #0B0D0F 100%) !important;
  color: #F5F7F8 !important;
}

.section-kicker,
.kicker,
.eyebrow,
.price,
.new-price,
.product-price,
.lead-modal-note,
.cart-note,
.footer-links a:hover {
  color: #1A1D21 !important;
}

.deep .section-kicker,
.deep-band .section-kicker,
.deep .kicker,
.deep-band .kicker,
.site-footer .footer-links a:hover {
  color: #8FAE35 !important;
}

.badge,
.dot,
.step-number,
.system-tap,
.check-dot {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
  box-shadow: none !important;
}

input,
select,
textarea {
  border-color: rgba(43, 49, 55, 0.16) !important;
  background: rgba(245, 247, 248, 0.88) !important;
  color: #0B0D0F !important;
  transition: border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(143, 174, 53, 0.72) !important;
  box-shadow: 0 0 0 3px rgba(143, 174, 53, 0.13) !important;
}

.cart-backdrop,
.lead-modal-backdrop,
.callback-modal-backdrop {
  background: rgba(11, 13, 15, 0.58) !important;
  backdrop-filter: blur(7px);
}

.cookie-banner {
  border-color: rgba(43, 49, 55, 0.12) !important;
  background: rgba(245, 247, 248, 0.98) !important;
  box-shadow: 0 18px 48px rgba(11, 13, 15, 0.12) !important;
}

.cookie-banner .cookie-close {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  width: 34px !important;
  height: 34px !important;
  display: inline-grid !important;
  place-items: center !important;
  padding: 0 !important;
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-radius: 50% !important;
  background: rgba(245, 247, 248, 0.88) !important;
  color: #1A1D21 !important;
  font-size: 20px !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.cookie-actions button {
  min-width: 0 !important;
  border-radius: 8px !important;
  white-space: normal !important;
}

.hero {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate;
}

.hero::before {
  content: "";
  position: absolute;
  inset: -18% -12%;
  z-index: -1;
  pointer-events: none;
  opacity: 0.011;
  background:
    linear-gradient(116deg, transparent 0 44%, #1A1D21 44.25% 44.75%, transparent 45% 100%),
    linear-gradient(116deg, transparent 0 61%, #8FAE35 61.2% 61.55%, transparent 61.8% 100%);
  transform: translate3d(-10px, 0, 0);
  animation: elxAmbientDrift 18s var(--motion-ease-soft) infinite alternate;
}

.hero-copy,
.hero-media,
.hero-warranty,
.hero .container > *,
.hero-grid > *,
.hero-inner > * {
  will-change: transform, opacity;
}

.hero-copy .eyebrow,
.hero-copy .kicker,
.hero-copy h1,
.hero-copy .hero-text,
.hero-copy p,
.hero-copy .hero-actions,
.hero .container > .kicker,
.hero .container > h1,
.hero .container > p,
.hero .container > .hero-actions {
  animation: elxHeroSettle 880ms var(--motion-ease-soft) both;
}

.hero-copy h1,
.hero .container > h1 {
  animation-delay: 90ms;
}

.hero-copy .hero-text,
.hero-copy p,
.hero .container > p {
  animation-delay: 210ms;
}

.hero-copy .hero-actions,
.hero .container > .hero-actions {
  animation-name: elxHeroCtaSettle;
  animation-delay: 300ms;
}

.hero-media,
.hero-warranty {
  animation: elxHeroDepth 1050ms var(--motion-ease-soft) 260ms both;
}

.hero-actions .btn,
.hero-actions .btn-primary,
.hero-actions .btn-soft,
.package-action,
.item-details,
.cart-button,
[data-add-cart] {
  transform: translate3d(0, 0, 0);
}

.hero-actions .btn:hover,
.hero-actions .btn-primary:hover,
.hero-actions .btn-soft:hover,
.package-action:hover,
.item-details:hover,
.cart-button:hover,
[data-add-cart]:hover {
  transform: translate3d(0, -1px, 0) !important;
}

.section-tab,
.filter-chip,
.why-control,
.product-gallery-button,
.cart-continue,
.cookie-actions button,
.lead-modal-close,
.product-close,
.cart-close,
.call-close {
  transition: transform var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease), opacity var(--motion-fast) var(--motion-ease) !important;
}

.section-tab:hover,
.filter-chip:hover,
.why-control:hover,
.product-gallery-button:hover,
.cart-continue:hover,
.cookie-actions button:hover {
  transform: translate3d(0, -1px, 0) !important;
}

.section-tab.is-active,
.filter-chip.is-active {
  transition-duration: 240ms !important;
}

.tab-panel {
  animation: elxPanelSettle 460ms var(--motion-ease) both;
}

.reveal {
  opacity: 0 !important;
  transform: translate3d(var(--reveal-x, 0), var(--reveal-y, 14px), 0) !important;
  transition:
    opacity var(--motion-reveal) var(--motion-ease-soft) var(--reveal-delay, 0ms),
    transform var(--motion-reveal) var(--motion-ease-soft) var(--reveal-delay, 0ms) !important;
  will-change: opacity, transform;
}

.reveal.in-view {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
}

.reveal:nth-child(3n + 1) {
  --reveal-x: -6px;
}

.reveal:nth-child(3n + 2) {
  --reveal-x: 6px;
}

.section-head.reveal,
.trust-copy.reveal,
.process-copy.reveal {
  --reveal-y: 10px;
  --reveal-x: 0;
}

.shop-card.reveal,
.guide-card.reveal,
.system.reveal,
.package.reveal {
  --reveal-y: 16px;
}

.metric.reveal,
.range-note.reveal,
.lead-panel.reveal {
  --reveal-y: 8px;
}

.site-footer,
.deep,
.deep-band {
  transition: background 700ms var(--motion-ease), color 700ms var(--motion-ease) !important;
}

.call-button,
.floating-call {
  background: rgba(26, 29, 33, 0.92) !important;
  color: #F5F7F8 !important;
  box-shadow: 0 16px 38px rgba(11, 13, 15, 0.18) !important;
  border: 1px solid rgba(245, 247, 248, 0.16) !important;
}

.call-button:hover,
.floating-call:hover {
  background: #1A1D21 !important;
  box-shadow: 0 18px 42px rgba(11, 13, 15, 0.20) !important;
  transform: translate3d(0, -1px, 0) !important;
}

[data-add-cart].is-added,
[data-add-cart].is-just-added {
  animation-duration: 360ms !important;
}

@keyframes elxHeroSettle {
  from {
    opacity: 0;
    transform: translate3d(-8px, 16px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes elxHeroDepth {
  from {
    opacity: 0;
    transform: translate3d(10px, 18px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes elxHeroCtaSettle {
  from {
    opacity: 0.9;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes elxPanelSettle {
  from {
    opacity: 0;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes elxAmbientDrift {
  from {
    transform: translate3d(-10px, -4px, 0);
  }
  to {
    transform: translate3d(12px, 6px, 0);
  }
}

@media (max-width: 760px) {
  .container,
  .site-footer .footer-shell,
  .site-footer .footer-bottom {
    width: min(100% - 32px, 1180px) !important;
  }

  body,
  .page,
  main,
  section {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .topbar {
    border-radius: 0 0 22px 22px !important;
  }

  .topbar .nav {
    width: calc(100% - 24px) !important;
    grid-template-columns: minmax(0, 1fr) auto auto !important;
    gap: 8px !important;
  }

  .topbar .brand,
  .topbar .nav-actions,
  .topbar .menu-toggle {
    grid-column: auto !important;
  }

  .topbar .nav-actions {
    justify-self: end !important;
  }

  .topbar .brand img,
  .brand img {
    width: 108px !important;
    height: auto !important;
  }

  .topbar .cart-nav,
  .topbar .menu-toggle {
    width: 48px !important;
    height: 48px !important;
  }

  h1,
  .hero h1 {
    max-width: 100% !important;
    font-size: clamp(38px, 11.2vw, 44px) !important;
    line-height: 1.04 !important;
    overflow-wrap: break-word !important;
  }

  .hero-copy,
  .hero-inner,
  .hero .container,
  .hero-copy p,
  .section-head,
  .section-head p {
    width: 100% !important;
    max-width: 100% !important;
    overflow-wrap: break-word !important;
  }

  .hero .container {
    max-width: calc(100vw - 32px) !important;
  }

  .hero-text,
  .hero-copy p {
    font-size: 17px !important;
    line-height: 1.55 !important;
  }

  .hero-actions {
    width: 100% !important;
  }

  .hero-actions .btn,
  .hero-actions .btn-primary,
  .hero-actions .btn-soft {
    width: 100% !important;
    min-width: 0 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .topbar .menu-toggle {
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
  }

  .topbar .nav-links {
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    box-shadow: 0 24px 70px rgba(11, 13, 15, 0.22) !important;
  }

  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    color: #F5F7F8 !important;
  }

  body.menu-open .topbar .menu-toggle,
  body.menu-open .topbar .cart-nav,
  .topbar .mobile-menu-secondary {
    background: #F5F7F8 !important;
    color: #1A1D21 !important;
  }

  .topbar .nav-links > a.mobile-menu-secondary {
    color: #1A1D21 !important;
    font-size: 19px !important;
    line-height: 1.1 !important;
  }

  .topbar .mobile-menu-cta {
    border-color: rgba(245, 247, 248, 0.62) !important;
    color: #F5F7F8 !important;
  }

  .lead-panel {
    padding: 22px !important;
  }

  .lead-copy h2 {
    font-size: clamp(32px, 9.2vw, 42px) !important;
  }

  .contact-facts span {
    width: 100%;
  }

  .lead-form {
    padding: 18px !important;
  }

  .hero::before {
    opacity: 0.006;
    animation-duration: 24s;
  }

  .hero-copy .eyebrow,
  .hero-copy .kicker,
  .hero-copy h1,
  .hero-copy .hero-text,
  .hero-copy p,
  .hero-copy .hero-actions,
  .hero .container > .kicker,
  .hero .container > h1,
  .hero .container > p,
  .hero .container > .hero-actions {
    animation-duration: 720ms;
  }

  .hero-media,
  .hero-warranty {
    animation-duration: 820ms;
  }

  .reveal {
    --reveal-x: 0 !important;
    --reveal-y: 10px !important;
    transition-duration: 520ms !important;
  }

  .package:hover,
  .item:hover,
  .shop-card:hover,
  .guide-card:hover,
  .metric:hover,
  .review-card:hover,
  .system:hover,
  .benefit-card:hover,
  .doc-card:hover,
  .warranty-card:hover {
    transform: none !important;
  }
}

@media (max-width: 520px) {
  .hero-copy,
  .hero-inner,
  .hero .container,
  .hero h1,
  .hero-text,
  .cookie-banner {
    max-width: calc(100vw - 32px) !important;
  }

  .hero h1 {
    font-size: clamp(36px, 10.8vw, 42px) !important;
  }

  .cookie-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
    transition-delay: 0ms !important;
  }

  .reveal,
  .reveal.in-view {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* Homepage identity refinement: calm engineering, restrained ELX accents. */
.topbar {
  background: #F5F7F8 !important;
  backdrop-filter: none !important;
}

.topbar .nav-links a,
.topbar .nav-links .nav-trigger,
.nav-links a,
.nav-trigger {
  position: relative;
}

.topbar .nav-links a::after,
.topbar .nav-links .nav-trigger::after,
.nav-links a::after,
.nav-trigger::after {
  content: "";
  position: absolute;
  left: 0;
  right: auto;
  bottom: -9px;
  width: 0;
  height: 2px;
  background: #8FAE35;
  opacity: 0;
  transition: width 200ms var(--motion-ease), opacity 200ms var(--motion-ease);
}

.topbar .nav-links a:hover::after,
.topbar .nav-links .nav-trigger:hover::after,
.topbar .nav-links a[aria-current="page"]::after,
.nav-links a:hover::after,
.nav-links a[aria-current="page"]::after,
.nav-trigger:hover::after {
  width: 18px;
  opacity: 1;
}

.topbar .nav-links a[aria-current="page"],
.nav-links a[aria-current="page"] {
  color: #0B0D0F !important;
}

.hero {
  min-height: auto !important;
  padding: clamp(30px, 4.2vw, 56px) 0 18px !important;
  background: #F5F7F8 !important;
  overflow: visible !important;
}

.hero::before {
  display: none;
}

.hero-inner {
  position: relative;
  display: grid !important;
  grid-template-columns: minmax(500px, 1fr) minmax(500px, 1fr);
  align-items: stretch;
  gap: 0 !important;
  min-height: 0 !important;
  height: clamp(540px, 43vw, 620px);
  border: 1px solid rgba(43, 49, 55, 0.10);
  border-radius: 8px;
  background: #F5F7F8;
  box-shadow: 0 16px 46px rgba(11, 13, 15, 0.075);
  overflow: hidden;
}

.hero-copy {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  max-width: none !important;
  padding: clamp(42px, 4.7vw, 64px) clamp(36px, 5vw, 68px) clamp(28px, 3.4vw, 44px);
  background: #F5F7F8;
}

.hero-copy .eyebrow {
  margin-bottom: 18px !important;
  color: rgba(26, 29, 33, 0.72) !important;
  text-transform: none;
  font-size: 13px !important;
  letter-spacing: 0 !important;
}

.hero-copy .eyebrow::before {
  width: 7px;
  height: 7px;
  box-shadow: none !important;
}

.hero h1 {
  max-width: 620px !important;
  margin-bottom: 20px !important;
  font-size: clamp(50px, 4.65vw, 68px) !important;
  line-height: 1.03 !important;
  color: #0B0D0F !important;
}

.hero-text {
  max-width: 540px !important;
  margin-bottom: 24px !important;
  color: rgba(26, 29, 33, 0.70) !important;
  font-size: clamp(17px, 1.45vw, 20px) !important;
  line-height: 1.5 !important;
}

.hero-trust,
.hero-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 28px;
  max-width: 520px;
  margin: clamp(30px, 3.2vw, 42px) 0 0;
  padding-top: 0;
}

.hero-cats {
  position: static;
}

.hero-trust span,
.hero-cats a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding-left: 19px;
  color: rgba(26, 29, 33, 0.78);
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
}

.hero-cats a::before {
  content: "/";
  position: absolute;
  left: 0;
  color: #8FAE35;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}

.hero-cats a:hover {
  color: #0B0D0F;
}

.hero-copy .hero-actions {
  align-items: center;
  gap: 14px !important;
}

.hero-secondary-link {
  min-height: 46px !important;
  padding: 0 21px !important;
  border: 1px solid rgba(43, 49, 55, 0.16) !important;
  background: rgba(245, 247, 248, 0.68) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

.hero-secondary-link:hover {
  color: #0B0D0F !important;
  border-color: rgba(143, 174, 53, 0.48) !important;
  background: rgba(245, 247, 248, 0.94) !important;
  transform: translate3d(0, -1px, 0) !important;
}

.hero-media {
  z-index: 1;
  height: 100% !important;
  min-height: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  clip-path: polygon(9% 0, 100% 0, 100% 100%, 0 100%);
  background: #1A1D21 !important;
}

.hero-media picture,
.hero-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0 !important;
}

.hero-media img {
  object-fit: cover;
  object-position: 82% center;
}

.hero-media::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 8.8%;
  z-index: 2;
  width: 2px;
  background: #8FAE35;
  opacity: 0.58;
  transform: skewX(-13deg);
  transform-origin: top center;
  pointer-events: none;
}

.hero-media::after {
  background: linear-gradient(90deg, rgba(11, 13, 15, 0.08), rgba(11, 13, 15, 0.03) 42%, rgba(11, 13, 15, 0.10)) !important;
}

.media-caption {
  display: none !important;
}

.category-line {
  display: none;
  flex-wrap: wrap;
  gap: 12px 22px;
  align-items: center;
  padding: 10px 0 4px;
  color: rgba(26, 29, 33, 0.58);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0;
}

.category-line a {
  color: inherit;
  transition: color var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);
}

.category-line a:hover {
  color: #0B0D0F;
  transform: translate3d(2px, 0, 0);
}

.package,
.shop-card,
.system {
  position: relative;
  overflow: hidden;
}

.package::before,
.shop-card::before,
.system::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  height: 2px;
  background: #8FAE35;
  opacity: 0;
  transition: opacity var(--motion-card) var(--motion-ease);
}

.package:hover::before,
.shop-card:hover::before,
.system:hover::before {
  opacity: 0.72;
}

.shop-card[data-href],
.shop-card[data-open-lead-modal] {
  cursor: pointer;
}

.shop-card[data-href]:focus-visible,
.shop-card[data-open-lead-modal]:focus-visible {
  outline: 3px solid rgba(143, 174, 53, 0.96);
  outline-offset: 4px;
  box-shadow: 0 0 0 7px rgba(143, 174, 53, 0.16), 0 22px 48px rgba(11, 13, 15, 0.14);
}

.shop-card[data-href] .card-actions,
.shop-card[data-open-lead-modal] .card-actions {
  display: none !important;
}

.shop-card[data-href] h3::after,
.shop-card[data-open-lead-modal] h3::after {
  content: " /";
  color: #8FAE35;
  font-weight: 900;
}

.package-media img,
.shop-card img,
.system img {
  transition: transform 420ms var(--motion-ease);
}

.package:hover .package-media img,
.shop-card:hover img,
.system:hover img {
  transform: scale(1.018);
}

@media (max-width: 980px) {
  .hero-inner {
    grid-template-columns: 1fr;
    height: auto;
    min-height: auto;
  }

  .hero-media {
    clip-path: none;
  }

  .hero-media::before {
    inset: 0 0 auto 0;
    width: auto;
    height: 2px;
    transform: none;
  }

  .hero-cats {
    position: static;
    margin-top: 24px;
  }
}

@media (max-width: 760px) {
  .topbar .nav-links a::after,
  .topbar .nav-links .nav-trigger::after {
    display: none;
  }

  .hero {
    padding: 20px 0 18px !important;
  }

  .hero::before {
    display: none;
  }

  .hero-inner {
    max-width: calc(100vw - 28px) !important;
    border-radius: 8px;
    box-shadow: 0 16px 48px rgba(11, 13, 15, 0.075);
  }

  .hero-copy {
    padding: 26px 20px 18px;
  }

  .hero-copy .eyebrow {
    margin-bottom: 13px !important;
    font-size: 12px !important;
  }

  h1,
  .hero h1 {
    max-width: 100% !important;
    margin-bottom: 15px !important;
    font-size: clamp(34px, 9.2vw, 39px) !important;
    line-height: 1.05 !important;
  }

  .hero-text,
  .hero-copy p {
    max-width: 100% !important;
    margin-bottom: 14px !important;
    font-size: 15.8px !important;
    line-height: 1.48 !important;
  }

  .hero-trust {
    gap: 7px;
    margin-bottom: 20px;
  }

  .hero-trust span {
    min-height: 28px;
    padding: 0 9px;
    font-size: 11px;
  }

  .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr;
    justify-items: start;
    gap: 11px !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .hero-actions .btn-primary {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
    min-height: 48px !important;
    box-sizing: border-box !important;
  }

  .hero-actions .hero-secondary-link {
    width: auto !important;
    min-height: auto !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    font-size: 14px !important;
    text-align: left !important;
  }

  .hero-media,
  .hero-media img,
  .hero-media picture {
    min-height: 226px !important;
    height: 226px !important;
  }

  .hero-media img {
    object-position: 70% center;
  }

  .hero-cats {
    gap: 8px 14px;
    margin-top: 20px;
  }

  .hero-cats a {
    min-height: 22px;
    padding-left: 14px;
    font-size: 11px;
  }

  .category-line {
    display: none;
    padding-top: 14px;
    gap: 8px 14px;
    font-size: 12px;
  }

  .cookie-banner {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    width: auto !important;
    max-width: none !important;
    gap: 12px !important;
    padding: 14px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 14px !important;
    background: #F5F7F8 !important;
    box-shadow: 0 18px 48px rgba(11, 13, 15, 0.14) !important;
  }

  .cookie-banner h3 {
    max-width: calc(100% - 44px) !important;
    margin-bottom: 4px !important;
    font-size: 18px !important;
    line-height: 1.15 !important;
  }

  .cookie-banner p {
    margin-top: 0 !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
    color: rgba(26, 29, 33, 0.72) !important;
  }

  .cookie-banner .cookie-close {
    top: 10px !important;
    right: 10px !important;
    width: 34px !important;
    height: 34px !important;
    font-size: 20px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    background: rgba(245, 247, 248, 0.54) !important;
  }

  .cookie-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  .cookie-actions button {
    min-height: 42px !important;
    padding: 0 10px !important;
    font-size: 13px !important;
  }
}

/* Wide homepage pass: full-width hero and calmer engineering sections. */
@media (min-width: 981px) {
  .hero {
    padding: 22px 0 0 !important;
  }

  .hero-inner.container {
    width: min(100% - 48px, 1680px) !important;
  }

  .hero-inner {
    grid-template-columns: minmax(570px, 0.9fr) minmax(690px, 1.1fr) !important;
    height: clamp(620px, calc(100vh - 126px), 760px) !important;
    border-radius: 10px !important;
    box-shadow: 0 26px 74px rgba(11, 13, 15, 0.10) !important;
  }

  .hero-copy {
    padding: clamp(74px, 7vw, 112px) clamp(54px, 6.6vw, 94px) clamp(52px, 5vw, 76px) !important;
  }

  .hero h1 {
    max-width: 640px !important;
    font-size: clamp(50px, 4.25vw, 64px) !important;
    line-height: 1.02 !important;
  }

  .hero-text {
    max-width: 520px !important;
    font-size: clamp(18px, 1.35vw, 22px) !important;
  }

  .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: max-content max-content !important;
    align-items: center !important;
    margin-top: 6px;
    gap: 18px !important;
  }

  .hero-actions .btn {
    width: auto !important;
    min-height: 54px !important;
    padding-inline: 28px !important;
  }

  .hero-secondary-link {
    width: auto !important;
    min-height: 54px !important;
    padding-inline: 28px !important;
  }

  .hero-cats {
    gap: 24px 42px;
    margin-top: clamp(54px, 7vw, 92px);
  }

  .hero-cats a {
    font-size: 13px;
  }

  .hero-media {
    clip-path: polygon(12% 0, 100% 0, 100% 100%, 0 100%) !important;
  }

  .hero-media::before {
    inset: 0 auto 0 11.7%;
    width: 2px;
    opacity: 0.62;
  }

  .hero-media img {
    object-position: 58% center !important;
  }
}

.manifest {
  padding: 74px 0 68px !important;
  background: #F5F7F8 !important;
}

.manifest-grid {
  gap: 24px !important;
}

.manifest .section-kicker {
  color: #0B0D0F !important;
  font-size: 18px !important;
}

.statement {
  max-width: 1040px !important;
  font-size: clamp(30px, 3.5vw, 48px) !important;
  line-height: 1.08 !important;
}

.why-slider {
  margin-top: 38px !important;
}

.why-slider-head {
  margin-bottom: 4px;
}

.why-controls {
  opacity: 0.55;
}

.why-track {
  grid-auto-flow: initial !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-auto-columns: initial !important;
  gap: 0 !important;
  overflow: visible !important;
  padding: 6px 0 0 !important;
  scroll-snap-type: none !important;
}

.why-card {
  min-height: 178px !important;
  padding: 24px 28px !important;
  border-width: 0 0 0 1px !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.why-card:first-child {
  border-left: 0 !important;
}

.why-card strong {
  font-size: clamp(22px, 2vw, 30px) !important;
  color: #0B0D0F !important;
}

.why-card p {
  max-width: 260px;
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 14px !important;
  line-height: 1.48 !important;
}

.deep-band {
  padding: 76px 0 78px !important;
  background: #0B0D0F !important;
}

.deep-band .section-head {
  align-items: start !important;
  margin-bottom: 46px !important;
}

.deep-band .section-head h2 {
  max-width: 620px;
  font-size: clamp(34px, 3.8vw, 58px) !important;
}

.deep-band .section-head p {
  max-width: 640px;
  color: rgba(245, 247, 248, 0.68) !important;
  font-size: 17px !important;
}

.metrics {
  gap: 0 !important;
  border-top: 1px solid rgba(245, 247, 248, 0.12);
}

.metric {
  min-height: 230px !important;
  padding: 28px 34px 22px !important;
  border: 0 !important;
  border-right: 1px solid rgba(245, 247, 248, 0.16) !important;
  background: transparent !important;
}

.metric:last-child {
  border-right: 0 !important;
}

.metric small {
  margin-bottom: 28px !important;
  color: #8FAE35 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.metric strong {
  margin-bottom: 12px !important;
  color: #F5F7F8 !important;
  font-size: clamp(24px, 2.2vw, 34px) !important;
}

.metric span {
  max-width: 300px !important;
  color: rgba(245, 247, 248, 0.66) !important;
  font-size: 15px !important;
}

#process {
  padding: 76px 0 82px !important;
  background: #F5F7F8;
}

.process {
  display: block !important;
}

.process-copy {
  position: static !important;
  max-width: none;
  margin-bottom: 34px;
}

.process-copy h2 {
  max-width: 720px;
  font-size: clamp(32px, 3.8vw, 54px) !important;
}

.process-copy p {
  max-width: 620px !important;
  font-size: 17px !important;
}

.timeline {
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 22px !important;
  border-top: 1px solid rgba(43, 49, 55, 0.14) !important;
  padding-top: 22px;
}

.step {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 18px !important;
  padding: 0 !important;
  border-bottom: 0 !important;
}

.step span {
  display: flex;
  align-items: center;
  gap: 18px;
  color: #8FAE35 !important;
  font-size: 18px;
}

.step span::after {
  content: "";
  height: 1px;
  flex: 1;
  background: rgba(43, 49, 55, 0.18);
}

.step h3 {
  margin-bottom: 8px !important;
  font-size: clamp(20px, 1.7vw, 26px) !important;
}

.step p {
  margin: 0;
  max-width: 250px;
  color: rgba(26, 29, 33, 0.66);
  font-size: 15px;
  font-weight: 700;
}

@media (max-width: 980px) {
  html,
  body,
  .page {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .hero-inner.container {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }

  .timeline,
  .metrics {
    grid-template-columns: 1fr 1fr !important;
  }

  .metric:nth-child(2n) {
    border-right: 0 !important;
  }
}

@media (max-width: 760px) {
  html,
  body,
  .page {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  .hero-inner.container {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
  }

  .hero-copy {
    box-sizing: border-box !important;
    min-width: 0 !important;
    width: min(330px, 100%) !important;
    overflow: hidden !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .hero-media img {
    object-position: 58% center !important;
  }

  .manifest,
  .deep-band,
  #process {
    padding: 56px 0 !important;
  }

  .why-track {
    grid-auto-columns: minmax(238px, 78vw) !important;
    gap: 12px !important;
  }

  .why-card {
    min-height: 170px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 8px !important;
    padding: 20px !important;
  }

  h1,
  .hero h1 {
    max-width: 330px !important;
    font-size: clamp(31px, 8.5vw, 36px) !important;
    line-height: 1.08 !important;
  }

  .hero-text,
  .hero-copy p {
    max-width: 330px !important;
    font-size: 15px !important;
  }

  .hero-copy .hero-actions {
    width: 100% !important;
    max-width: 100% !important;
  }

  .hero-actions .btn-primary {
    width: 330px !important;
    max-width: 100% !important;
  }

  .hero-cats {
    gap: 8px 12px !important;
  }

  .hero-cats a {
    padding-left: 12px !important;
    font-size: 10.5px !important;
  }

  .metrics,
  .timeline {
    grid-template-columns: 1fr !important;
  }

  .metric {
    border-right: 0 !important;
    border-bottom: 1px solid rgba(245, 247, 248, 0.14) !important;
  }
}

/* Final contrast pass: this must stay at the end of the cascade. */
::selection {
  background: rgba(143, 174, 53, 0.34);
  color: inherit;
}

.deep,
.deep-band,
.catalog-compare,
section[class*="deep"] {
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
}

.deep h1,
.deep h2,
.deep h3,
.deep h4,
.deep strong,
.deep-band h1,
.deep-band h2,
.deep-band h3,
.deep-band h4,
.deep-band strong,
.catalog-compare h1,
.catalog-compare h2,
.catalog-compare h3,
.catalog-compare h4,
.catalog-compare strong,
section[class*="deep"] h1,
section[class*="deep"] h2,
section[class*="deep"] h3,
section[class*="deep"] h4,
section[class*="deep"] strong {
  color: #F5F7F8 !important;
}

.deep p,
.deep li,
.deep span,
.deep-band p,
.deep-band li,
.deep-band span,
.catalog-compare p,
.catalog-compare li,
.catalog-compare span,
section[class*="deep"] p,
section[class*="deep"] li,
section[class*="deep"] span {
  color: rgba(245, 247, 248, 0.74) !important;
}

.deep .section-kicker,
.deep .eyebrow,
.deep .kicker,
.deep small,
.deep-band .section-kicker,
.deep-band .eyebrow,
.deep-band .kicker,
.deep-band small,
.catalog-compare .section-kicker,
.catalog-compare .eyebrow,
.catalog-compare .kicker,
.catalog-compare small,
section[class*="deep"] .section-kicker,
section[class*="deep"] .eyebrow,
section[class*="deep"] .kicker,
section[class*="deep"] small {
  color: #8FAE35 !important;
}

.deep .item,
.deep .system,
.deep .package,
.deep .metric,
.deep-band .item,
.deep-band .system,
.deep-band .package,
.deep-band .metric,
.catalog-compare .item,
.catalog-compare .system,
.catalog-compare .package {
  border-color: rgba(245, 247, 248, 0.14) !important;
  background: rgba(245, 247, 248, 0.035) !important;
}

.deep .item.featured,
.deep-band .item.featured,
.catalog-compare .item.featured {
  background: rgba(245, 247, 248, 0.055) !important;
  border-color: rgba(143, 174, 53, 0.30) !important;
}

.badge,
.dot,
.step-number,
.system-tap,
.check-dot,
.bundle-sale {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
}

.badge *,
.dot *,
.step-number *,
.system-tap *,
.check-dot *,
.bundle-sale * {
  color: #0B0D0F !important;
}

.note,
.range-note,
.trust-note,
.warranty-card,
.legal-card {
  color: rgba(26, 29, 33, 0.76) !important;
}
.cart-button.is-added,
.cart-button.is-just-added,
[data-add-cart].is-added,
[data-add-cart].is-just-added {
  background: #8FAE35 !important;
  color: #0B0D0F !important;
  border-color: rgba(11, 13, 15, 0.10) !important;
}

.cart-button.is-added *,
.cart-button.is-just-added *,
[data-add-cart].is-added *,
[data-add-cart].is-just-added * {
  color: #0B0D0F !important;
}
/* Homepage hero should feel like a full editorial split, not a framed card. */
body:has(.hero-inner) .hero {
  padding: clamp(20px, 3.4vw, 44px) 0 clamp(34px, 5vw, 70px) !important;
  background: #F5F7F8 !important;
  overflow: hidden !important;
}

body:has(.hero-inner) .hero-inner.container {
  width: min(1540px, calc(100% - 32px)) !important;
  max-width: min(1540px, calc(100% - 32px)) !important;
}

body:has(.hero-inner) .hero-inner {
  height: clamp(620px, 48vw, 760px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

body:has(.hero-inner) .hero-copy {
  padding-left: clamp(38px, 6.4vw, 108px) !important;
  padding-right: clamp(42px, 5.4vw, 86px) !important;
  background: #F5F7F8 !important;
}

body:has(.hero-inner) .hero-media {
  clip-path: polygon(8% 0, 100% 0, 100% 100%, 0 100%) !important;
  border-radius: 0 !important;
  overflow: hidden !important;
}

body:has(.hero-inner) .hero-media img {
  object-position: 74% center !important;
}

@media (max-width: 980px) {
  body:has(.hero-inner) .hero-inner.container {
    width: min(100% - 28px, 760px) !important;
    max-width: min(100% - 28px, 760px) !important;
  }

  body:has(.hero-inner) .hero-inner {
    height: auto !important;
    overflow: hidden !important;
  }

  body:has(.hero-inner) .hero-copy {
    padding-left: clamp(20px, 6vw, 42px) !important;
    padding-right: clamp(20px, 6vw, 42px) !important;
  }

  body:has(.hero-inner) .hero-media {
    clip-path: none !important;
  }
}
/* Final category and warranty stability layer. */
body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
  padding: clamp(104px, 8.6vw, 144px) 0 clamp(52px, 5.5vw, 78px) !important;
  background: #F5F7F8 !important;
  overflow: visible !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
  width: min(1180px, calc(100% - 64px)) !important;
  max-width: min(1180px, calc(100% - 64px)) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 360px) !important;
  align-items: start !important;
  gap: clamp(48px, 6vw, 86px) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
  max-width: 860px !important;
  margin: 18px 0 24px !important;
  font-size: clamp(58px, 6.6vw, 96px) !important;
  line-height: 0.98 !important;
  letter-spacing: 0 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero p {
  max-width: 780px !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: clamp(19px, 1.65vw, 25px) !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-actions {
  margin-top: 34px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
  align-self: start !important;
  margin-top: 0 !important;
  padding: 24px !important;
  border-radius: 14px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty h2 {
  font-size: clamp(34px, 3.2vw, 48px) !important;
  line-height: 1 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty p {
  font-size: 15px !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty-logo {
  min-height: 128px !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero:not(:has(.hero-warranty)) {
  padding-bottom: clamp(34px, 4.2vw, 58px) !important;
}

.trust-list {
  border-top: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust-item {
  display: grid !important;
  grid-template-columns: minmax(360px, 0.42fr) minmax(0, 1fr) !important;
  align-items: center !important;
  gap: clamp(44px, 6vw, 86px) !important;
  min-height: 220px !important;
  padding: clamp(34px, 4.2vw, 56px) 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.16) !important;
}

.trust-item strong,
.trust-item .trust-brand {
  display: block !important;
  max-width: 100% !important;
  color: #1A1D21 !important;
  font-size: clamp(54px, 5.8vw, 88px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
}

.trust-item span {
  max-width: 620px !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: clamp(22px, 2.1vw, 34px) !important;
  font-weight: 820 !important;
  line-height: 1.48 !important;
}

@media (max-width: 980px) {
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
    padding: 56px 0 42px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
    width: min(100% - 28px, 760px) !important;
    max-width: min(100% - 28px, 760px) !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
    font-size: clamp(42px, 12vw, 64px) !important;
  }
}

@media (max-width: 760px) {
  .trust-item {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
    min-height: 0 !important;
    padding: 28px 0 !important;
  }

  .trust-item strong,
  .trust-item .trust-brand {
    font-size: clamp(42px, 16vw, 64px) !important;
  }

  .trust-item span {
    font-size: clamp(19px, 6vw, 25px) !important;
  }
}

/* True final trust and product text overrides. */
.trust .trust-list { border-top: 1px solid rgba(43, 49, 55, 0.16) !important; }
.trust .trust-item { display: grid !important; grid-template-columns: minmax(190px, 250px) minmax(0, 1fr) !important; align-items: center !important; gap: clamp(30px, 4vw, 48px) !important; min-height: 0 !important; padding: 30px 0 !important; border-bottom: 1px solid rgba(43, 49, 55, 0.16) !important; }
.trust .trust-item strong, .trust .trust-item .trust-brand { display: block !important; max-width: 100% !important; color: #8FAE35 !important; font-size: clamp(34px, 4vw, 56px) !important; line-height: 1 !important; letter-spacing: 0 !important; white-space: normal !important; }
.trust .trust-item .trust-brand { font-size: clamp(34px, 3.8vw, 52px) !important; }
.trust .trust-item span { max-width: 430px !important; color: rgba(11, 13, 15, 0.74) !important; font-size: 17px !important; font-weight: 750 !important; line-height: 1.5 !important; }
body:has(.product-layout) .section-card p { color: rgba(26, 29, 33, 0.66) !important; font-weight: 520 !important; line-height: 1.58 !important; }
@media (max-width: 760px) { .trust .trust-item { grid-template-columns: 1fr !important; gap: 18px !important; min-height: 0 !important; padding: 28px 0 !important; } .trust .trust-item strong, .trust .trust-item .trust-brand { font-size: clamp(42px, 16vw, 64px) !important; } .trust .trust-item span { font-size: clamp(19px, 6vw, 25px) !important; } }

/* Product image surfaces: neutral, calm, no green halo behind equipment. */
.product-card-image,
.product-visual,
.product-thumb {
  background:
    linear-gradient(145deg, rgba(245, 247, 248, 0.96) 0%, rgba(245, 247, 248, 0.86) 62%, rgba(245, 247, 248, 0.74) 100%) !important;
}

.product-card-image {
  border: 1px solid rgba(43, 49, 55, 0.08) !important;
  box-shadow: inset 0 1px 0 rgba(245, 247, 248, 0.72) !important;
}

.product-card-image img {
  filter: drop-shadow(0 24px 34px rgba(11, 13, 15, 0.14)) !important;
}

/* Homepage package images: new clean product renders, scaled without extra visual noise. */
.package-media.product-media {
  height: clamp(280px, 22vw, 340px) !important;
}

.package-media.basic-media img,
.package-media.solar-media img {
  width: min(96%, 350px) !important;
  max-height: 320px !important;
}

.package-media.hv-media img {
  width: min(100%, 430px) !important;
  max-height: 300px !important;
}

/* Inquiry cards: simple catalog positions share one calm style and do not show grid-inverter prices. */
.shop-card.inquiry-card {
  display: grid !important;
  align-content: space-between !important;
  gap: 18px !important;
  min-height: 220px !important;
  border-color: rgba(43, 49, 55, 0.10) !important;
  background:
    linear-gradient(145deg, rgba(245, 247, 248, 0.82), rgba(245, 247, 248, 0.66)) !important;
}

.shop-card.inquiry-card h3 {
  max-width: 100% !important;
}

.shop-card.inquiry-card p {
  max-width: 34ch !important;
  color: rgba(26, 29, 33, 0.62) !important;
  font-size: 14px !important;
  line-height: 1.48 !important;
}

.shop-card.grid-inquiry-card .item-price {
  display: none !important;
}

.shop-card.product-card.grid-inquiry-card .item-price {
  display: block !important;
}

.shop-card.product-card.inquiry-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  gap: 0 !important;
  min-height: 430px !important;
}

.shop-card.inquiry-card .chips {
  display: none !important;
}

.shop-card.inquiry-card .inquiry-actions {
  margin-top: auto !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
}

.shop-card.inquiry-card .inquiry-button {
  width: 100% !important;
  min-height: 44px !important;
  border: 1px solid rgba(26, 29, 33, 0.14) !important;
  border-radius: 9px !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  box-shadow: none !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.shop-card.inquiry-card .inquiry-button:hover {
  transform: translateY(-1px) !important;
  background: #0B0D0F !important;
  border-color: rgba(143, 174, 53, 0.35) !important;
}

/* Responsive precision layer: mobile-first calmness across homepage, catalog, category and product pages. */
html,
body {
  max-width: 100%;
  overflow-x: clip;
}

img,
picture,
video,
canvas,
svg {
  max-width: 100%;
}

@media (max-width: 1280px) {
  .container,
  .hero-inner.container,
  .site-footer .footer-shell,
  .site-footer .footer-grid,
  .site-footer .footer-bottom {
    width: min(100% - 48px, 1120px) !important;
    max-width: min(100% - 48px, 1120px) !important;
  }

  body:has(.hero-inner) .hero-inner {
    min-height: 0 !important;
  }
}

@media (max-width: 980px) {
  section,
  .lead,
  .manifest,
  .systems,
  .packages,
  .trust,
  .deep,
  .deep-band {
    padding-top: clamp(48px, 8vw, 72px) !important;
    padding-bottom: clamp(48px, 8vw, 72px) !important;
  }

  .section-head {
    gap: 12px !important;
    margin-bottom: 26px !important;
  }

  .section-head h2,
  section h2 {
    font-size: clamp(34px, 6.2vw, 50px) !important;
    line-height: 1.04 !important;
    max-width: 760px !important;
  }

  .section-head p {
    max-width: 640px !important;
    font-size: clamp(16px, 2.2vw, 19px) !important;
    line-height: 1.58 !important;
  }

  .catalog-grid,
  .systems-grid,
  .package-grid,
  .benefits-grid,
  .steps-grid,
  .lead-panel {
    grid-template-columns: 1fr !important;
  }

  .shop-layout {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
}

@media (max-width: 760px) {
  :root {
    scroll-padding-top: 86px;
  }

  body {
    text-rendering: optimizeLegibility;
  }

  .container,
  .hero-inner.container,
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container,
  .site-footer .footer-shell,
  .site-footer .footer-grid,
  .site-footer .footer-bottom {
    width: min(100% - 28px, 520px) !important;
    max-width: min(100% - 28px, 520px) !important;
  }

  .topbar {
    min-height: 86px !important;
    border-radius: 0 0 22px 22px !important;
  }

  .topbar .nav {
    min-height: 86px !important;
    padding: 0 14px !important;
  }

  .topbar .brand img,
  .brand img {
    width: 112px !important;
    height: auto !important;
    max-height: 52px !important;
  }

  .topbar .cart-nav,
  .topbar .menu-toggle {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
  }

  .topbar .nav-links {
    inset: 86px 12px auto !important;
    width: calc(100% - 24px) !important;
    max-height: calc(100svh - 104px) !important;
    overflow-y: auto !important;
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    min-height: 48px !important;
    padding: 12px 4px !important;
    font-size: 17px !important;
    line-height: 1.1 !important;
  }

  body:has(.hero-inner) .hero {
    padding: 18px 0 34px !important;
  }

  body:has(.hero-inner) .hero-inner.container {
    width: 100% !important;
    max-width: 100% !important;
  }

  body:has(.hero-inner) .hero-inner {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    height: auto !important;
    background: #F5F7F8 !important;
  }

  body:has(.hero-inner) .hero-copy {
    box-sizing: border-box !important;
    padding: 28px 28px 22px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    text-align: left !important;
    justify-items: start !important;
    align-items: start !important;
  }

  .hero-copy .eyebrow,
  .hero-copy .kicker,
  .hero .container > .kicker {
    margin-bottom: 16px !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .hero h1,
  .hero-copy h1,
  .hero .container > h1 {
    max-width: min(8.4em, 100%) !important;
    margin: 0 0 16px !important;
    font-size: clamp(34px, 9.6vw, 39px) !important;
    line-height: 1.07 !important;
    letter-spacing: 0 !important;
    overflow-wrap: anywhere !important;
  }

  .hero-text,
  .hero-copy p,
  .hero .container > p {
    max-width: 32ch !important;
    font-size: 16px !important;
    line-height: 1.48 !important;
  }

  .hero-copy .hero-actions,
  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: min(320px, 100%) !important;
    margin-top: 20px !important;
  }

  .hero-actions .btn,
  .hero-actions .btn-primary,
  .hero-actions .btn-soft,
  .btn,
  .cart-button,
  button[type="submit"] {
    min-height: 50px !important;
    padding: 0 18px !important;
    font-size: 15px !important;
    border-radius: 9px !important;
    touch-action: manipulation;
  }

  .hero-actions .hero-secondary-link,
  .hero-actions .anchor,
  .hero-actions .btn-soft {
    width: fit-content !important;
    min-height: 34px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: #1A1D21 !important;
  }

  .hero-trust {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    margin-top: 14px !important;
    font-size: 13px !important;
  }

  .cta-reassurance {
    max-width: 30ch !important;
    font-size: 14px !important;
    line-height: 1.42 !important;
    overflow-wrap: break-word !important;
  }

  .hero-cats,
  .category-line {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px 14px !important;
    overflow: visible !important;
    padding: 10px 0 2px !important;
    max-width: 100% !important;
    scrollbar-width: auto;
  }

  .hero-cats::-webkit-scrollbar,
  .category-line::-webkit-scrollbar {
    display: none;
  }

  .hero-cats a,
  .category-line a {
    flex: 0 0 auto !important;
    font-size: 12px !important;
    white-space: nowrap !important;
  }

  body:has(.hero-inner) .hero-media {
    width: 100% !important;
    min-height: 0 !important;
    aspect-ratio: 1.32 / 1 !important;
    margin: 0 !important;
    border-top: 1px solid rgba(143, 174, 53, 0.72) !important;
    clip-path: none !important;
  }

  body:has(.hero-inner) .hero-media picture,
  body:has(.hero-inner) .hero-media img {
    height: 100% !important;
  }

  body:has(.hero-inner) .hero-media img {
    object-position: 68% center !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero,
  .catalog-hero {
    padding: 88px 0 32px !important;
    overflow: hidden !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
    gap: 22px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
  .catalog-hero h1 {
    max-width: 100% !important;
    margin: 10px 0 16px !important;
    font-size: clamp(40px, 11.4vw, 48px) !important;
    line-height: 1.02 !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero p,
  .catalog-hero p {
    max-width: 34ch !important;
    font-size: 16px !important;
    line-height: 1.55 !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-actions {
    margin-top: 22px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-items: start !important;
    padding: 18px !important;
    border-radius: 14px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty > div:last-child {
    min-width: 0 !important;
    overflow: hidden !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty-logo {
    width: 112px !important;
    min-height: 78px !important;
    border-radius: 12px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty-logo img {
    max-width: 74px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty h2 {
    font-size: clamp(32px, 9vw, 40px) !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty p {
    max-width: 31ch !important;
    font-size: 12.5px !important;
    line-height: 1.45 !important;
    overflow-wrap: anywhere !important;
  }

  .catalog-grid,
  .products-grid,
  .systems-grid,
  .package-grid,
  .benefits-grid,
  .steps-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .shop-card,
  .catalog-card,
  .system-card,
  .package-card,
  .benefit-card,
  .step-card,
  .guide-card,
  .item {
    min-width: 0 !important;
    padding: 18px !important;
    border-radius: 14px !important;
  }

  .shop-card.product-card {
    gap: 14px !important;
  }

  .shop-card.product-card > div:first-child,
  .shop-card-top {
    gap: 12px !important;
  }

  .product-card-image {
    min-height: 178px !important;
    aspect-ratio: 1.16 / 1 !important;
    border-radius: 12px !important;
  }

  .shop-card h3,
  .shop-card.product-card h3,
  .catalog-card h3,
  .system-card h3,
  .package-card h3 {
    font-size: clamp(22px, 6.4vw, 28px) !important;
    line-height: 1.08 !important;
    overflow-wrap: anywhere !important;
  }

  .shop-card p,
  .catalog-card p,
  .system-card p,
  .package-card p,
  .shop-card li {
    font-size: 14px !important;
    line-height: 1.48 !important;
  }

  .filters,
  .filter-panel,
  .catalog-filters,
  .catalog-quick-filters {
    display: flex !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding-bottom: 8px !important;
    scrollbar-width: none;
  }

  .filters::-webkit-scrollbar,
  .filter-panel::-webkit-scrollbar,
  .catalog-filters::-webkit-scrollbar,
  .catalog-quick-filters::-webkit-scrollbar {
    display: none;
  }

  .filter-option,
  .catalog-quick-filters button {
    flex: 0 0 auto !important;
    min-height: 40px !important;
    white-space: nowrap !important;
  }

  main:has(.product-layout) {
    padding-top: 28px !important;
    overflow-x: hidden !important;
  }

  .product-layout {
    box-sizing: border-box !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    width: 100% !important;
    max-width: calc(100vw - 28px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .gallery {
    position: static !important;
    gap: 12px !important;
    min-width: 0 !important;
  }

  .gallery-main {
    min-height: 0 !important;
    aspect-ratio: 1 / 0.82 !important;
    border-radius: 14px !important;
  }

  .gallery-main img {
    width: min(74%, 270px) !important;
    max-height: 270px !important;
  }

  .thumbs {
    display: flex !important;
    gap: 10px !important;
    overflow-x: auto !important;
    padding-bottom: 2px !important;
    scrollbar-width: none;
  }

  .thumbs::-webkit-scrollbar {
    display: none;
  }

  .thumb {
    flex: 0 0 110px !important;
    height: 72px !important;
    border-radius: 10px !important;
  }

  .product-info {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: calc(100vw - 28px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .product-info h1 {
    display: block !important;
    width: min(100%, 340px) !important;
    max-width: min(100%, 340px) !important;
    font-size: clamp(29px, 8vw, 32px) !important;
    line-height: 1.06 !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    hyphens: none !important;
  }

  .badges {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  .badge {
    min-height: 34px !important;
    padding: 8px 12px !important;
    font-size: 12px !important;
  }

  .price {
    font-size: clamp(34px, 10vw, 42px) !important;
    line-height: 1 !important;
  }

  .actions,
  .product-info .actions {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    max-width: none !important;
  }

  .section-tabs {
    display: flex !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding-bottom: 2px !important;
    scrollbar-width: none;
  }

  .section-tabs::-webkit-scrollbar {
    display: none;
  }

  .section-tab {
    flex: 0 0 auto !important;
    min-height: 42px !important;
    padding: 10px 14px !important;
    font-size: 13px !important;
  }

  .section-card {
    padding: 18px !important;
    border-radius: 14px !important;
  }

  .spec-row {
    grid-template-columns: 1fr !important;
    gap: 5px !important;
    padding: 12px 0 !important;
  }

  .lead-panel,
  .lead-copy,
  .lead-form {
    min-width: 0 !important;
  }

  .lead-copy h2 {
    font-size: clamp(32px, 9vw, 42px) !important;
    line-height: 1.05 !important;
  }

  .lead-form input,
  .lead-form select,
  .lead-form textarea,
  .lead-modal-form input,
  .lead-modal-form select,
  .lead-modal-form textarea {
    min-height: 48px !important;
    font-size: 16px !important;
  }

  .call-widget {
    right: 16px !important;
    bottom: 18px !important;
  }

  .call-button {
    width: 54px !important;
    height: 54px !important;
  }

  .cookie-banner {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    width: auto !important;
    max-width: none !important;
    padding: 16px !important;
    border-radius: 14px !important;
  }

  .cookie-banner h3 {
    font-size: 18px !important;
    margin-bottom: 6px !important;
  }

  .cookie-banner p {
    max-height: 88px !important;
    overflow: auto !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
  }

  .cookie-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .cookie-actions button {
    min-width: 0 !important;
    width: 100% !important;
    min-height: 44px !important;
    padding: 0 10px !important;
    font-size: 13px !important;
    white-space: normal !important;
  }

  .site-footer {
    padding: 48px 0 24px !important;
  }

  .site-footer .footer-brand img,
  .site-footer .footer-logo img,
  .footer-logo img {
    width: 122px !important;
  }
}

@media (max-width: 360px) {
  .container,
  .hero-inner.container,
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container {
    width: min(100% - 24px, 520px) !important;
    max-width: min(100% - 24px, 520px) !important;
  }

  body:has(.hero-inner) .hero-copy {
    padding: 26px 24px 20px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
  }

  .hero h1,
  .hero-copy h1,
  .hero .container > h1 {
    font-size: clamp(33px, 10.2vw, 37px) !important;
  }

  .cta-reassurance {
    max-width: 27ch !important;
    font-size: 13px !important;
  }

  .hero-cats,
  .category-line {
    gap: 8px 10px !important;
  }

  .hero-cats a,
  .category-line a {
    padding-left: 15px !important;
    font-size: 11px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
  .catalog-hero h1 {
    font-size: clamp(35px, 10.8vw, 40px) !important;
  }

  .product-info h1 {
    width: min(100%, 292px) !important;
    max-width: min(100%, 292px) !important;
    font-size: clamp(26px, 7.8vw, 30px) !important;
  }

  .topbar .brand img,
  .brand img {
    width: 104px !important;
  }

  .cookie-actions {
    grid-template-columns: 1fr !important;
  }
}

@media (min-width: 761px) and (max-width: 834px) {
  .topbar .nav {
    padding-inline: 28px !important;
  }

  body:has(.hero-inner) .hero-copy {
    padding: 54px 56px 34px !important;
  }

  body:has(.hero-inner) .hero-media {
    aspect-ratio: 1.55 / 1 !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
  .catalog-hero h1 {
    font-size: clamp(54px, 8vw, 66px) !important;
  }
}

@media (min-width: 835px) and (max-width: 1280px) {
  body:has(.hero-inner) .hero-inner {
    height: clamp(560px, 58vw, 690px) !important;
  }

  body:has(.hero-inner) .hero-copy {
    padding-left: clamp(34px, 4.8vw, 68px) !important;
    padding-right: clamp(34px, 4vw, 58px) !important;
  }

  .hero h1 {
    font-size: clamp(48px, 5.8vw, 70px) !important;
  }
}

/* Homepage alignment polish: process markers and package CTAs sit on one clean axis. */
#process .timeline {
  align-items: start !important;
}

#process .step {
  grid-template-rows: 30px auto !important;
}

#process .step > span {
  display: grid !important;
  grid-template-columns: auto 1fr !important;
  align-items: center !important;
  gap: 16px !important;
  min-height: 30px !important;
  margin: 0 !important;
  line-height: 1 !important;
}

#process .step > span::after {
  align-self: center !important;
  height: 1px !important;
  min-width: 0 !important;
  transform: translateY(0) !important;
}

#packages .packages {
  align-items: stretch !important;
}

#packages .package {
  height: 100% !important;
}

#packages .package.has-media > div:first-child {
  display: grid !important;
  grid-template-rows: auto auto minmax(96px, auto) minmax(250px, 1fr) auto !important;
  height: 100% !important;
}

#packages .package-actions {
  align-self: end !important;
  min-height: 96px !important;
  margin-top: 22px !important;
}

#packages .package-action.primary {
  width: 100% !important;
  min-height: 56px !important;
}

@media (max-width: 980px) {
  #process .step {
    grid-template-rows: auto auto !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto auto !important;
  }

  #packages .package-actions {
    min-height: auto !important;
  }
}

/* SEO entity block: visible, calm and crawlable summary of the all-in-one service offer. */
.seo-summary {
  padding: 34px 0 44px !important;
  border-top: 1px solid rgba(43, 49, 55, 0.08);
  border-bottom: 1px solid rgba(43, 49, 55, 0.08);
  background: rgba(245, 247, 248, 0.74);
}

.seo-summary-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.86fr) minmax(0, 1.14fr);
  gap: clamp(28px, 5vw, 76px);
  align-items: start;
}

.seo-summary h2 {
  max-width: 560px;
  margin: 10px 0 0;
  color: #0B0D0F;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.04;
}

.seo-summary p {
  max-width: 760px;
  margin: 0;
  color: rgba(26, 29, 33, 0.66);
  font-size: 16px;
  font-weight: 750;
  line-height: 1.62;
}

.seo-summary p + p {
  margin-top: 12px;
}

.seo-summary-points {
  display: grid;
  gap: 10px;
  max-width: 780px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.seo-summary-points li {
  position: relative;
  padding-left: 18px;
  color: rgba(26, 29, 33, 0.66);
  font-size: 15px;
  font-weight: 720;
  line-height: 1.54;
}

.seo-summary-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #8FAE35;
}

@media (max-width: 760px) {
  .seo-summary {
    padding: 28px 0 32px !important;
  }

  .seo-summary-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .seo-summary h2 {
    font-size: clamp(25px, 7vw, 31px);
  }

  .seo-summary p {
    font-size: 14px;
  }

  .seo-summary-points {
    margin-top: 14px;
    gap: 8px;
  }

  .seo-summary-points li {
    font-size: 13.5px;
    line-height: 1.48;
  }
}

/* Mobile catalog and menu correction: keep product cards readable and menu states visible. */
@media (max-width: 760px) {
  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    color: #F5F7F8 !important;
    font-size: clamp(24px, 7vw, 30px) !important;
    line-height: 1.08 !important;
  }

  .topbar .nav-links > a:hover,
  .topbar .nav-links > a:focus-visible,
  .topbar .nav-links > a:active,
  .topbar .nav-links > a[aria-current="page"],
  .topbar .nav-links .nav-trigger:hover,
  .topbar .nav-links .nav-trigger:focus-visible,
  .topbar .nav-links .nav-trigger:active {
    color: #8FAE35 !important;
  }

  .topbar .nav-links > a::after,
  .topbar .nav-links .nav-trigger::after {
    bottom: 5px !important;
    background: #8FAE35 !important;
  }

  .shop-layout .shop-grid {
    width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .shop-layout {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: 1fr !important;
    overflow: visible !important;
  }

  .shop-layout .shop-filter,
  .shop-layout .shop-results,
  .shop-layout .shop-count {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .shop-layout .shop-card {
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
  }

  .shop-layout .shop-card.product-card {
    padding: 18px !important;
  }

  .shop-layout .product-card-image {
    width: 100% !important;
    height: auto !important;
    min-height: 230px !important;
    aspect-ratio: 1.28 / 1 !important;
    margin: 14px 0 16px !important;
    overflow: hidden !important;
  }

  .shop-layout .product-card-image img,
  .shop-layout .product-card-image.is-portrait img,
  .shop-layout .product-card-image.is-battery img {
    width: auto !important;
    max-width: 86% !important;
    height: auto !important;
    max-height: 218px !important;
    object-fit: contain !important;
    object-position: center !important;
    transform: none !important;
  }

  .shop-layout .shop-card.product-card h3,
  .shop-layout .shop-card h3 {
    max-width: 100% !important;
    font-size: clamp(28px, 8.2vw, 36px) !important;
    line-height: 1.05 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-all !important;
  }

  .shop-layout .item-price {
    font-size: clamp(34px, 11vw, 46px) !important;
    line-height: 1 !important;
  }
}

@media (max-width: 360px) {
  .shop-layout .product-card-image {
    min-height: 205px !important;
  }

  .shop-layout .product-card-image img,
  .shop-layout .product-card-image.is-portrait img,
  .shop-layout .product-card-image.is-battery img {
    max-height: 196px !important;
  }

  .shop-layout .shop-card.product-card h3,
  .shop-layout .shop-card h3 {
    font-size: clamp(25px, 8vw, 31px) !important;
  }
}

/* Final mobile readability pass for homepage trust and warranty blocks. */
@media (max-width: 760px) {
  .trust .trust-item {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 22px 0 !important;
  }

  .trust .trust-item strong,
  .trust .trust-item .trust-brand {
    font-size: clamp(34px, 11.2vw, 46px) !important;
    line-height: 1.02 !important;
  }

  .trust .trust-item span {
    max-width: 100% !important;
    font-size: clamp(15px, 4.45vw, 18px) !important;
    font-weight: 760 !important;
    line-height: 1.48 !important;
  }

  .why-slider {
    margin-top: 22px !important;
  }

  .why-slider-head {
    gap: 12px !important;
    margin-bottom: 12px !important;
  }

  .why-track {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-auto-flow: row !important;
    grid-auto-columns: initial !important;
    gap: 10px !important;
    overflow: visible !important;
    padding: 0 !important;
    scroll-snap-type: none !important;
  }

  .why-card,
  .why-card:nth-child(odd),
  .why-card:nth-child(4n + 1) {
    width: 100% !important;
    min-width: 0 !important;
    min-height: auto !important;
    padding: 18px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 8px !important;
    background: rgba(245, 247, 248, 0.48) !important;
  }

  .why-card strong {
    display: block !important;
    max-width: 100% !important;
    font-size: clamp(22px, 6.4vw, 28px) !important;
    line-height: 1.08 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .why-card p {
    max-width: 100% !important;
    margin-top: 12px !important;
    font-size: 15px !important;
    line-height: 1.45 !important;
    overflow-wrap: anywhere !important;
  }
}

/* Mobile homepage correction: calm readable trust rows and advantage cards. */
@media (max-width: 760px) {
  .home-page .manifest .container,
  .home-page .manifest-grid,
  .home-page .manifest-grid > *,
  .home-page .why-slider,
  .home-page .why-track,
  .home-page .why-card {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .home-page .manifest {
    padding: 44px 0 48px !important;
  }

  .home-page .manifest-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .home-page .manifest .section-kicker {
    font-size: 15px !important;
    line-height: 1.25 !important;
  }

  .home-page .statement {
    max-width: 100% !important;
    font-size: clamp(30px, 8.2vw, 38px) !important;
    line-height: 1.1 !important;
    letter-spacing: 0 !important;
    overflow-wrap: normal !important;
  }

  .home-page .why-slider {
    margin-top: 26px !important;
  }

  .home-page .why-slider-head {
    display: block !important;
    margin-bottom: 14px !important;
  }

  .home-page .why-slider-head strong {
    display: block !important;
    font-size: 20px !important;
    line-height: 1.15 !important;
  }

  .home-page .why-controls {
    display: none !important;
  }

  .home-page .why-track {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-auto-flow: row !important;
    grid-auto-columns: initial !important;
    gap: 10px !important;
    overflow: visible !important;
    padding: 0 !important;
    scroll-snap-type: none !important;
  }

  .home-page .why-card,
  .home-page .why-card:nth-child(odd),
  .home-page .why-card:nth-child(4n + 1) {
    display: grid !important;
    gap: 8px !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 17px 18px 18px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 8px !important;
    background: rgba(245, 247, 248, 0.64) !important;
    box-shadow: none !important;
  }

  .home-page .why-card strong {
    max-width: 100% !important;
    font-size: clamp(22px, 6vw, 27px) !important;
    line-height: 1.08 !important;
    color: #0B0D0F !important;
    white-space: normal !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }

  .home-page .why-card p {
    max-width: 100% !important;
    margin: 0 !important;
    color: rgba(26, 29, 33, 0.68) !important;
    font-size: 14px !important;
    font-weight: 760 !important;
    line-height: 1.42 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }

  .home-page .trust .trust-item {
    grid-template-columns: 1fr !important;
    gap: 9px !important;
    padding: 20px 0 !important;
  }

  .home-page .trust .trust-item strong,
  .home-page .trust .trust-item .trust-brand {
    font-size: clamp(31px, 10vw, 42px) !important;
    line-height: 1.02 !important;
    color: #8FAE35 !important;
  }

  .home-page .trust .trust-item span {
    max-width: 100% !important;
    font-size: clamp(14px, 4.05vw, 17px) !important;
    line-height: 1.48 !important;
    font-weight: 760 !important;
  }
}

/* Final product page commerce polish: turnkey discount and slash specs. */
body:has(.product-layout) .badges {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0 !important;
  margin: 0 0 24px !important;
}

body:has(.product-layout) .badge {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 0 !important;
  padding: 0 14px 0 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(26, 29, 33, 0.66) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.3 !important;
  box-shadow: none !important;
}

body:has(.product-layout) .badge::before {
  content: "/" !important;
  margin-right: 9px !important;
  color: #8FAE35 !important;
  font-weight: 950 !important;
}

body:has(.product-layout) .bundle-highlight {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 14px !important;
  margin: 0 0 30px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-left: 3px solid #8FAE35 !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.78) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

body:has(.product-layout) .bundle-highlight strong {
  color: #8FAE35 !important;
  font-size: 22px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

body:has(.product-layout) .bundle-highlight span {
  min-width: 0 !important;
  max-width: 100% !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: 14px !important;
  font-weight: 820 !important;
  line-height: 1.4 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

@media (max-width: 760px) {
  body:has(.product-layout) .badges {
    margin-bottom: 18px !important;
  }

  body:has(.product-layout) .badge {
    padding-right: 12px !important;
    font-size: 12px !important;
  }

  body:has(.product-layout) .bundle-highlight {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 15px 16px !important;
  }

  body:has(.product-layout) .bundle-highlight strong {
    font-size: 22px !important;
  }
}

/* Accessibility and catalog density pass: compact clickable cards, clear focus, safer touch targets. */
.filter-chip,
.section-tab,
.hero-cats a,
.category-line a,
.site-footer .footer-links a {
  min-height: 44px;
}

.filter-chip,
.section-tab {
  display: inline-flex;
  align-items: center;
}

@media (max-width: 760px) {
  .shop-layout .shop-grid,
  .catalog-featured-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .shop-layout .shop-card,
  .catalog-featured-grid .shop-card {
    min-height: 0 !important;
    padding: 13px !important;
    border-radius: 8px !important;
  }

  .shop-layout .shop-card.product-card > div:first-child,
  .catalog-featured-grid .shop-card > div:first-child {
    gap: 8px !important;
  }

  .shop-layout .product-card-image,
  .catalog-featured-grid .product-card-image {
    min-height: 96px !important;
    height: 112px !important;
    aspect-ratio: 1 / 0.82 !important;
    margin: 8px 0 9px !important;
  }

  .shop-layout .product-card-image img,
  .shop-layout .product-card-image.is-portrait img,
  .shop-layout .product-card-image.is-battery img,
  .catalog-featured-grid .product-card-image img,
  .catalog-featured-grid .product-card-image.is-portrait img,
  .catalog-featured-grid .product-card-image.is-battery img {
    max-width: 90% !important;
    max-height: 106px !important;
  }

  .shop-layout .shop-card h3,
  .catalog-featured-grid .shop-card h3 {
    font-size: clamp(14px, 3.8vw, 16px) !important;
    line-height: 1.12 !important;
    word-break: normal !important;
  }

  .shop-layout .shop-card p,
  .catalog-featured-grid .shop-card p {
    display: -webkit-box !important;
    overflow: hidden !important;
    font-size: 12px !important;
    line-height: 1.28 !important;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }

  .shop-layout .product-specs,
  .shop-layout .catalog-specs,
  .catalog-featured-grid .catalog-specs {
    gap: 4px !important;
  }

  .shop-layout .spec-badge,
  .catalog-featured-grid .catalog-specs span {
    padding: 4px 6px !important;
    font-size: 10px !important;
    line-height: 1.1 !important;
  }

  .shop-layout .item-price,
  .catalog-featured-grid .item-price {
    margin-top: 8px !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
  }
}

/* Product catalog cleanup: no framed image trays, no hero-sized names in compact cards. */
.shop-layout .shop-card.product-card,
.catalog-featured-grid .shop-card {
  gap: 12px !important;
}

.shop-layout .product-card-image,
.catalog-featured-grid .product-card-image {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.shop-layout .shop-card.product-card h3,
.catalog-featured-grid .shop-card h3 {
  max-width: 100% !important;
  color: #0B0D0F !important;
  font-size: clamp(20px, 2vw, 26px) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

.shop-layout .product-type-label,
.catalog-featured-grid .product-type-label {
  color: rgba(26, 29, 33, 0.66) !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
}

.shop-layout .item-price,
.catalog-featured-grid .item-price {
  color: #0B0D0F !important;
  font-size: 20px !important;
  line-height: 1.12 !important;
}

@media (max-width: 760px) {
  .shop-layout,
  .shop-layout .shop-filter,
  .shop-layout .shop-results,
  .shop-layout .shop-grid,
  .shop-layout .shop-card,
  .catalog-featured-grid,
  .catalog-featured-grid .shop-card {
    box-sizing: border-box !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .shop-layout .shop-results,
  .shop-layout .shop-grid,
  .catalog-featured-grid {
    width: calc(100vw - 28px) !important;
  }

  .shop-layout .shop-grid,
  .catalog-featured-grid {
    grid-template-columns: repeat(2, minmax(0, calc((100vw - 48px) / 2))) !important;
    justify-content: start !important;
  }

  .shop-layout .product-card-image,
  .catalog-featured-grid .product-card-image {
    height: 98px !important;
    min-height: 88px !important;
    margin: 7px 0 8px !important;
  }

  .shop-layout .product-card-image img,
  .shop-layout .product-card-image.is-portrait img,
  .shop-layout .product-card-image.is-battery img,
  .catalog-featured-grid .product-card-image img,
  .catalog-featured-grid .product-card-image.is-portrait img,
  .catalog-featured-grid .product-card-image.is-battery img {
    max-width: 86% !important;
    max-height: 96px !important;
  }

  .shop-layout .shop-card.product-card h3,
  .shop-layout .shop-card h3,
  .catalog-featured-grid .shop-card h3 {
    font-size: clamp(15px, 4vw, 18px) !important;
    line-height: 1.12 !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
  }

  .shop-layout .product-type-label,
  .catalog-featured-grid .product-type-label {
    font-size: 10px !important;
  }

  .shop-layout .item-price,
  .catalog-featured-grid .item-price {
    font-size: 15px !important;
  }

  .shop-layout .shop-card,
  .catalog-featured-grid .shop-card {
    width: auto !important;
  }
}

@media (max-width: 760px) {
  .topbar .nav {
    width: calc(100% - 24px) !important;
    max-width: 1360px !important;
    padding-inline: 0 !important;
  }

  .topbar .brand,
  .topbar .nav-actions,
  .topbar .menu-toggle {
    min-width: 0 !important;
  }
}

body:has(.legal) .container.legal {
  width: calc(100% - 48px) !important;
  max-width: 1080px !important;
  display: block !important;
}

body:has(.legal) .legal > div {
  max-width: 860px !important;
}

body:has(.legal) .doc {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

body:has(.legal) .doc,
body:has(.legal) .doc * {
  min-width: 0 !important;
  overflow-wrap: break-word !important;
  word-break: normal !important;
}

@media (max-width: 760px) {
  body:has(.legal) .container.legal {
    width: calc(100% - 28px) !important;
    max-width: 760px !important;
  }

  body:has(.legal) h1 {
    font-size: clamp(34px, 10vw, 46px) !important;
  }

  body:has(.legal) .doc h2 {
    font-size: clamp(24px, 7vw, 30px) !important;
    line-height: 1.12 !important;
  }

  body:has(.legal) .lead,
  body:has(.legal) .doc h2,
  body:has(.legal) .doc p,
  body:has(.legal) .doc li {
    max-width: calc(100vw - 68px) !important;
    overflow-wrap: anywhere !important;
  }

  body.loyalty-page .topbar .nav {
    grid-template-columns: minmax(0, 1fr) 48px !important;
  }

  body.loyalty-page .topbar .nav-actions {
    display: none !important;
  }

  body.loyalty-page .topbar .menu-toggle {
    display: grid !important;
    grid-column: 2 !important;
    justify-self: end !important;
    width: 48px !important;
    height: 48px !important;
    border: 0 !important;
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    position: relative !important;
    right: auto !important;
  }
}

/* Final mobile menu and lead modal refinement. */
@media (max-width: 980px) {
  body.menu-open {
    overflow: hidden !important;
    touch-action: none !important;
  }

  body.menu-open .topbar {
    min-height: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .topbar .nav-links {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0 !important;
    padding: calc(116px + env(safe-area-inset-top)) 32px calc(38px + env(safe-area-inset-bottom)) !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    box-shadow: none !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    z-index: 260 !important;
  }

  body.menu-open .topbar .nav-links {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.menu-open .topbar .nav-actions {
    position: fixed !important;
    top: calc(22px + env(safe-area-inset-top)) !important;
    right: 104px !important;
    z-index: 320 !important;
  }

  body.menu-open .topbar .menu-toggle {
    position: fixed !important;
    top: calc(22px + env(safe-area-inset-top)) !important;
    right: 24px !important;
    z-index: 320 !important;
  }

  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    padding: clamp(8px, 1.8vh, 14px) 0 !important;
    color: #F5F7F8 !important;
    font-size: clamp(42px, 12.4vw, 66px) !important;
    line-height: 1.04 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
  }

  .topbar .nav-links > a[aria-current="page"],
  .topbar .nav-links > a:hover,
  .topbar .nav-links > a:focus-visible {
    color: #8FAE35 !important;
  }

  .topbar .mobile-menu-cta {
    width: 100% !important;
    min-height: 64px !important;
    flex: 0 0 auto !important;
    margin-top: auto !important;
    margin-bottom: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(245, 247, 248, 0.56) !important;
    border-radius: 8px !important;
    background: transparent !important;
    color: #F5F7F8 !important;
    font-size: clamp(20px, 6vw, 28px) !important;
    line-height: 1.12 !important;
    font-weight: 950 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .topbar .mobile-menu-secondary {
    width: 100% !important;
    min-height: 58px !important;
    margin-top: 12px !important;
    margin-bottom: 0 !important;
    border-radius: 8px !important;
    background: #F5F7F8 !important;
    color: #1A1D21 !important;
    font-size: 18px !important;
  }
}

.lead-modal {
  z-index: 420 !important;
}

.lead-modal-backdrop {
  background: rgba(11, 13, 15, 0.70) !important;
  backdrop-filter: blur(10px) !important;
}

.lead-modal-dialog {
  width: min(760px, calc(100vw - 36px)) !important;
  max-height: min(88dvh, 820px) !important;
  padding: clamp(34px, 4vw, 52px) !important;
  border: 1px solid rgba(245, 247, 248, 0.10) !important;
  border-radius: 10px !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(143, 174, 53, 0.10), transparent 30%),
    linear-gradient(145deg, #1A1D21 0%, #0B0D0F 72%) !important;
  color: #F5F7F8 !important;
  box-shadow: 0 34px 100px rgba(11, 13, 15, 0.48) !important;
  text-align: left !important;
}

.lead-modal-dialog::before {
  content: "";
  display: block;
  width: 132px;
  height: 56px;
  margin: 0 0 24px;
  background-image: url("elx-logo-transparent.png");
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
  filter: brightness(0) invert(1);
  opacity: 0.96;
}

.lead-modal-close {
  top: 22px !important;
  right: 22px !important;
  width: 50px !important;
  height: 50px !important;
  border: 1px solid rgba(245, 247, 248, 0.16) !important;
  background: rgba(245, 247, 248, 0.06) !important;
  color: #F5F7F8 !important;
}

.lead-modal-dialog h2 {
  max-width: 620px !important;
  margin: 0 0 12px !important;
  color: #F5F7F8 !important;
  font-size: clamp(38px, 4.4vw, 58px) !important;
  line-height: 1.02 !important;
  text-align: left !important;
}

.lead-modal-dialog > p {
  max-width: 620px !important;
  margin: 0 0 22px !important;
  color: rgba(245, 247, 248, 0.70) !important;
  font-size: clamp(16px, 1.45vw, 19px) !important;
  line-height: 1.56 !important;
  text-align: left !important;
}

.lead-modal-facts {
  justify-content: flex-start !important;
  margin: 0 0 26px !important;
}

.lead-modal-facts span {
  border-color: rgba(245, 247, 248, 0.16) !important;
  background: rgba(245, 247, 248, 0.06) !important;
  color: rgba(245, 247, 248, 0.78) !important;
}

.lead-modal-form {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.lead-modal-form label {
  color: rgba(245, 247, 248, 0.70) !important;
}

.lead-modal-form label:has(textarea),
.lead-modal-form label:has(select),
.lead-modal-form button,
.lead-modal-note {
  grid-column: 1 / -1 !important;
}

.lead-modal-form input,
.lead-modal-form select,
.lead-modal-form textarea {
  border-color: rgba(245, 247, 248, 0.16) !important;
  background-color: rgba(245, 247, 248, 0.08) !important;
  color: #F5F7F8 !important;
}

.lead-modal-form input::placeholder,
.lead-modal-form textarea::placeholder {
  color: rgba(245, 247, 248, 0.42) !important;
}

.lead-modal-form select {
  background-image: linear-gradient(45deg, transparent 50%, rgba(245, 247, 248, 0.72) 50%), linear-gradient(135deg, rgba(245, 247, 248, 0.72) 50%, transparent 50%) !important;
}

.lead-modal-form input:focus,
.lead-modal-form select:focus,
.lead-modal-form textarea:focus {
  border-color: rgba(143, 174, 53, 0.74) !important;
  background-color: rgba(245, 247, 248, 0.11) !important;
  box-shadow: 0 0 0 3px rgba(143, 174, 53, 0.14) !important;
}

.lead-modal-form button[type="submit"],
.lead-modal-form .btn {
  min-height: 58px !important;
  background: #F5F7F8 !important;
  color: #0B0D0F !important;
  box-shadow: none !important;
}

.lead-modal-note {
  color: rgba(245, 247, 248, 0.78) !important;
}

@media (max-width: 760px) {
  .lead-modal {
    align-items: stretch !important;
    padding: 12px !important;
  }

  .lead-modal-dialog {
    width: 100% !important;
    max-height: calc(100dvh - 24px) !important;
    padding: 26px 20px calc(24px + env(safe-area-inset-bottom)) !important;
    border-radius: 10px !important;
  }

  .lead-modal-dialog::before {
    width: 118px;
    height: 48px;
    margin: 0 auto 18px;
    background-position: center;
  }

  .lead-modal-close {
    top: 18px !important;
    right: 18px !important;
    width: 48px !important;
    height: 48px !important;
  }

  .lead-modal-dialog h2 {
    max-width: 100% !important;
    margin-right: auto !important;
    margin-left: auto !important;
    font-size: clamp(32px, 10.5vw, 48px) !important;
    line-height: 1.02 !important;
    text-align: center !important;
  }

  .lead-modal-dialog > p {
    margin-right: auto !important;
    margin-left: auto !important;
    font-size: 16px !important;
    line-height: 1.46 !important;
    text-align: center !important;
  }

  .lead-modal-facts {
    justify-content: center !important;
  }

  .lead-modal-facts span {
    text-align: center !important;
  }

  .lead-modal-form {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .lead-modal-form input,
  .lead-modal-form select,
  .lead-modal-form textarea {
    min-height: 54px !important;
    padding: 13px 15px !important;
  }

  .lead-modal-form textarea {
    min-height: 88px !important;
  }
}

/* Global callback widget: visible button, manual popup only, centered premium dialog. */
.call-widget {
  position: fixed !important;
  right: 22px !important;
  bottom: calc(22px + env(safe-area-inset-bottom)) !important;
  z-index: 410 !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
}

body.menu-open .call-widget,
.lead-modal.is-open ~ .call-widget {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.call-widget.is-open:not(.elx-user-open) .call-popover {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(10px) scale(0.98) !important;
}

.call-widget.is-open:not(.elx-user-open) .call-button {
  display: inline-grid !important;
  opacity: 0.92 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.call-widget .call-button {
  width: 58px !important;
  height: 58px !important;
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid rgba(245, 247, 248, 0.18) !important;
  border-radius: 50% !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  box-shadow: 0 18px 46px rgba(11, 13, 15, 0.22) !important;
  animation: none !important;
}

.call-widget.elx-user-open.is-open .call-button {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.call-widget .call-popover {
  position: absolute !important;
  right: 0 !important;
  bottom: 76px !important;
  width: min(520px, calc(100vw - 44px)) !important;
  padding: 34px 34px 36px !important;
  border: 1px solid rgba(245, 247, 248, 0.10) !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(143, 174, 53, 0.10), transparent 31%),
    linear-gradient(145deg, #1A1D21 0%, #0B0D0F 76%) !important;
  color: #F5F7F8 !important;
  box-shadow: 0 34px 100px rgba(11, 13, 15, 0.40) !important;
  text-align: center !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(10px) scale(0.98) !important;
}

.call-widget.elx-user-open.is-open .call-popover {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) scale(1) !important;
  pointer-events: auto !important;
}

.call-widget .call-popover::before {
  content: "";
  display: block;
  width: 126px;
  height: 52px;
  margin: 0 auto 18px;
  background-image: url("elx-logo-transparent.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  filter: brightness(0) invert(1);
  opacity: 0.96;
}

.call-popover-head {
  display: block !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.call-popover h3 {
  margin: 0 auto 10px !important;
  max-width: 420px !important;
  color: #F5F7F8 !important;
  font-size: clamp(34px, 4vw, 48px) !important;
  line-height: 1.04 !important;
  text-align: center !important;
}

.call-popover p {
  max-width: 400px !important;
  margin: 0 auto !important;
  color: rgba(245, 247, 248, 0.76) !important;
  font-size: clamp(16px, 1.5vw, 19px) !important;
  line-height: 1.46 !important;
  text-align: center !important;
}

.call-close {
  position: absolute !important;
  top: 20px !important;
  right: 20px !important;
  width: 46px !important;
  height: 46px !important;
  display: inline-grid !important;
  place-items: center !important;
  border: 1px solid rgba(245, 247, 248, 0.16) !important;
  border-radius: 50% !important;
  background: rgba(245, 247, 248, 0.07) !important;
  color: #F5F7F8 !important;
  font-size: 28px !important;
  line-height: 1 !important;
}

.call-direct {
  display: grid !important;
  justify-items: center !important;
  gap: 6px !important;
  width: 100% !important;
  margin: 22px 0 18px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(245, 247, 248, 0.13) !important;
  border-radius: 18px !important;
  background: rgba(245, 247, 248, 0.08) !important;
  color: #F5F7F8 !important;
  text-align: center !important;
  text-decoration: none !important;
}

.call-direct small {
  color: rgba(245, 247, 248, 0.66) !important;
  font-size: 13px !important;
  text-decoration: none !important;
}

.call-direct span {
  color: #F5F7F8 !important;
  font-size: clamp(24px, 3vw, 32px) !important;
  line-height: 1.1 !important;
  text-decoration: none !important;
  overflow-wrap: anywhere !important;
}

.callback-form {
  display: grid !important;
  gap: 14px !important;
  text-align: left !important;
}

.callback-form label {
  display: grid !important;
  gap: 9px !important;
  color: rgba(245, 247, 248, 0.74) !important;
}

.callback-form input {
  width: 100% !important;
  min-height: 58px !important;
  border-color: rgba(245, 247, 248, 0.18) !important;
  background: rgba(245, 247, 248, 0.08) !important;
  color: #F5F7F8 !important;
}

.callback-form input::placeholder {
  color: rgba(245, 247, 248, 0.42) !important;
}

.callback-form input:focus {
  border-color: rgba(143, 174, 53, 0.72) !important;
  background: rgba(245, 247, 248, 0.11) !important;
  box-shadow: 0 0 0 3px rgba(143, 174, 53, 0.14) !important;
}

.callback-form .btn {
  width: 100% !important;
  min-height: 60px !important;
  border-radius: 999px !important;
  background: #F5F7F8 !important;
  color: #0B0D0F !important;
  box-shadow: none !important;
}

.callback-note {
  color: rgba(245, 247, 248, 0.80) !important;
  text-align: center !important;
}

@media (max-width: 760px) {
  .call-widget {
    right: 16px !important;
    bottom: calc(16px + env(safe-area-inset-bottom)) !important;
  }

  .call-widget.elx-user-open.is-open {
    inset: 0 !important;
    pointer-events: none !important;
  }

  .call-widget.elx-user-open.is-open::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(11, 13, 15, 0.58);
    backdrop-filter: blur(3px);
    pointer-events: auto;
  }

  .call-widget .call-popover {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    bottom: calc(12px + env(safe-area-inset-bottom)) !important;
    width: auto !important;
    max-height: calc(100dvh - 24px) !important;
    padding: 26px 20px calc(24px + env(safe-area-inset-bottom)) !important;
    border-radius: 28px !important;
    overflow: auto !important;
  }

  .call-popover h3 {
    max-width: calc(100% - 58px) !important;
    font-size: clamp(32px, 10.5vw, 48px) !important;
  }

  .call-popover p {
    font-size: 16px !important;
  }

  .call-direct {
    margin: 18px 0 14px !important;
    padding: 14px 14px !important;
    gap: 7px !important;
  }

  .call-direct small {
    font-size: 12px !important;
    line-height: 1.3 !important;
  }

  .call-direct span {
    font-size: clamp(24px, 7.2vw, 30px) !important;
    white-space: normal !important;
  }
}

/* Art-directed homepage viewport pass: wider hero, controlled sections, calmer rhythm. */
.home-page .container:not(.hero-inner) {
  width: min(1180px, calc(100% - clamp(40px, 5vw, 88px))) !important;
  max-width: 1180px !important;
}

.home-page section:not(.hero):not(.seo-summary) {
  padding-top: clamp(76px, 6.4vw, 112px) !important;
  padding-bottom: clamp(76px, 6.4vw, 112px) !important;
}

.home-page .section-head {
  align-items: end !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(300px, 0.64fr) !important;
  gap: clamp(34px, 4.8vw, 70px) !important;
}

.home-page .section-head h2,
.home-page .process-copy h2,
.home-page .trust-copy h2,
.home-page .lead-copy h2 {
  max-width: 720px !important;
  text-wrap: balance;
}

.home-page .section-head p,
.home-page .process-copy p,
.home-page .trust-copy p,
.home-page .lead-copy p {
  max-width: 58ch !important;
}

.home-page .hero {
  padding: clamp(18px, 2.4vw, 42px) 0 clamp(34px, 4.4vw, 68px) !important;
}

.home-page .hero-inner.container,
body.home-page:has(.hero-inner) .hero-inner.container {
  width: min(calc(100% - clamp(36px, 4.4vw, 88px)), 1760px) !important;
  max-width: 1760px !important;
}

.home-page .hero-inner,
body.home-page:has(.hero-inner) .hero-inner {
  grid-template-columns: minmax(460px, 0.76fr) minmax(720px, 1.24fr) !important;
  height: clamp(620px, calc(100svh - 128px), 790px) !important;
  max-height: 790px !important;
}

.home-page .hero-copy,
body.home-page:has(.hero-inner) .hero-copy {
  align-self: stretch !important;
  display: grid !important;
  align-content: center !important;
  padding: clamp(58px, 6vw, 104px) clamp(42px, 5.4vw, 88px) clamp(44px, 4.4vw, 72px) !important;
}

.home-page .hero h1 {
  max-width: 11.2em !important;
  margin-bottom: clamp(18px, 1.8vw, 26px) !important;
  font-size: clamp(50px, 4.05vw, 68px) !important;
  line-height: 1.01 !important;
  text-wrap: balance;
}

.home-page .hero-text {
  max-width: 36ch !important;
  margin-bottom: clamp(24px, 2.6vw, 34px) !important;
  font-size: clamp(18px, 1.16vw, 21px) !important;
  line-height: 1.5 !important;
}

.home-page .hero-copy .hero-actions {
  gap: 14px !important;
}

.home-page .cta-reassurance {
  max-width: 42ch !important;
  margin-top: 14px !important;
  line-height: 1.45 !important;
}

.home-page .hero-cats {
  margin-top: clamp(42px, 5.6vw, 78px) !important;
}

.home-page .hero-media,
body.home-page:has(.hero-inner) .hero-media {
  min-width: 0 !important;
  height: 100% !important;
}

.home-page .hero-media img,
body.home-page:has(.hero-inner) .hero-media img {
  height: 100% !important;
  object-fit: cover !important;
  object-position: 57% center !important;
}

@media (min-width: 1600px) {
  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(calc(100% - 96px), 1840px) !important;
    max-width: 1840px !important;
  }

  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: minmax(500px, 0.68fr) minmax(900px, 1.32fr) !important;
    height: min(800px, calc(100svh - 128px)) !important;
  }

  .home-page .hero h1 {
    max-width: 10.6em !important;
    font-size: clamp(60px, 3.7vw, 74px) !important;
  }

  .home-page .hero-text {
    max-width: 37ch !important;
  }

  .home-page .hero-media img,
  body.home-page:has(.hero-inner) .hero-media img {
    object-position: 55% center !important;
  }
}

@media (min-width: 1900px) {
  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(calc(100% - 128px), 1900px) !important;
    max-width: 1900px !important;
  }

  .home-page .container:not(.hero-inner) {
    max-width: 1220px !important;
  }
}

@media (min-width: 981px) and (max-width: 1320px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: minmax(420px, 0.86fr) minmax(560px, 1.14fr) !important;
    height: clamp(570px, 55vw, 720px) !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding-inline: clamp(36px, 4.2vw, 58px) !important;
  }

  .home-page .hero h1 {
    font-size: clamp(48px, 4.8vw, 64px) !important;
  }
}

@media (min-width: 761px) and (max-width: 980px) {
  .home-page .container:not(.hero-inner) {
    width: min(calc(100% - 48px), 820px) !important;
    max-width: 820px !important;
  }

  .home-page .hero {
    padding: 24px 0 48px !important;
  }

  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(calc(100% - 40px), 900px) !important;
    max-width: 900px !important;
  }

  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: 1fr !important;
    height: auto !important;
    max-height: none !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding: clamp(48px, 7vw, 72px) clamp(42px, 7vw, 72px) 34px !important;
  }

  .home-page .hero h1 {
    max-width: 9.6em !important;
    font-size: clamp(52px, 7.1vw, 68px) !important;
  }

  .home-page .hero-text {
    max-width: 42ch !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    aspect-ratio: 1.72 / 1 !important;
    height: auto !important;
  }

  .home-page .hero-media img,
  body.home-page:has(.hero-inner) .hero-media img {
    object-position: 58% center !important;
  }

  .home-page .section-head {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
}

@media (max-width: 760px) {
  .home-page .container:not(.hero-inner),
  .home-page .seo-summary .container {
    width: min(calc(100% - 28px), 520px) !important;
    max-width: 520px !important;
  }

  .home-page section:not(.hero):not(.seo-summary) {
    padding-top: clamp(48px, 13vw, 68px) !important;
    padding-bottom: clamp(48px, 13vw, 68px) !important;
  }

  .home-page .section-head {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-bottom: 26px !important;
  }

  .home-page .section-head h2,
  .home-page .process-copy h2,
  .home-page .trust-copy h2,
  .home-page .lead-copy h2 {
    max-width: 10.5em !important;
    font-size: clamp(31px, 8.7vw, 40px) !important;
    line-height: 1.06 !important;
    text-wrap: balance;
  }

  .home-page .section-head p,
  .home-page .process-copy p,
  .home-page .trust-copy p,
  .home-page .lead-copy p {
    max-width: 34ch !important;
    font-size: 15px !important;
    line-height: 1.52 !important;
  }

  .home-page .hero {
    padding: 12px 0 36px !important;
  }

  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(calc(100% - 20px), 520px) !important;
    max-width: 520px !important;
  }

  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: 1fr !important;
    height: auto !important;
    max-height: none !important;
    border-radius: 10px !important;
    overflow: hidden !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    align-content: start !important;
    row-gap: 0 !important;
    padding: 26px 24px 16px !important;
  }

  .home-page .hero-copy .eyebrow {
    margin-bottom: 12px !important;
  }

  .home-page .hero h1 {
    max-width: 8.2em !important;
    margin-bottom: 12px !important;
    font-size: clamp(33px, 9.1vw, 39px) !important;
    line-height: 1.04 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    text-wrap: balance;
  }

  .home-page .hero-text {
    max-width: 31ch !important;
    margin-bottom: 18px !important;
    font-size: clamp(16px, 4.3vw, 18px) !important;
    line-height: 1.46 !important;
  }

  .home-page .hero-copy .hero-actions {
    width: min(100%, calc(100vw - 68px)) !important;
    max-width: 330px !important;
    gap: 8px !important;
    margin-top: 0 !important;
  }

  .home-page .hero-actions .btn-primary {
    box-sizing: border-box !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .home-page .hero-actions .hero-secondary-link {
    width: fit-content !important;
    margin-top: 2px !important;
  }

  .home-page .cta-reassurance {
    max-width: 28ch !important;
    margin-top: 10px !important;
    font-size: 13px !important;
    line-height: 1.38 !important;
  }

  .home-page .hero-cats {
    margin-top: 16px !important;
    padding-top: 4px !important;
    gap: 8px 12px !important;
  }

  .home-page .hero-cats a {
    min-height: 28px !important;
    font-size: 11px !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    aspect-ratio: 1.26 / 1 !important;
    height: auto !important;
    min-height: 276px !important;
    border-top: 1px solid rgba(43, 49, 55, 0.10) !important;
  }

  .home-page .hero-media img,
  body.home-page:has(.hero-inner) .hero-media img {
    object-position: 63% center !important;
  }

  .home-page .seo-summary {
    padding: 30px 0 36px !important;
  }

  .home-page .seo-summary-grid {
    gap: 14px !important;
  }
}

@media (max-width: 390px) {
  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding: 24px 20px 15px !important;
  }

  .home-page .hero h1 {
    max-width: 8em !important;
    font-size: clamp(31px, 9.1vw, 36px) !important;
  }

  .home-page .hero-text {
    max-width: 28ch !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    min-height: 252px !important;
  }
}

/* SEO/AEO content blocks */
.seo-faq {
  padding: clamp(68px, 8vw, 112px) 0;
  background: #F5F7F8;
}

.seo-faq .section-head {
  margin-bottom: clamp(28px, 4vw, 46px);
}

.seo-faq .section-head p {
  max-width: 68ch;
}

.answer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  border: 1px solid rgba(43, 49, 55, 0.12);
  background: rgba(43, 49, 55, 0.12);
}

.answer-card {
  min-height: 100%;
  padding: clamp(22px, 2.3vw, 34px);
  background: #F5F7F8;
}

.answer-card h3 {
  margin: 0 0 14px;
  color: #0B0D0F;
  font-size: clamp(17px, 1.25vw, 20px);
  line-height: 1.22;
  letter-spacing: 0;
}

.answer-card p {
  margin: 0;
  max-width: 42ch;
  color: rgba(11, 13, 15, 0.68);
  font-size: 14px;
  line-height: 1.7;
}

.related-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.related-links a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid rgba(26, 29, 33, 0.14);
  border-radius: 999px;
  color: rgba(11, 13, 15, 0.78);
  background: rgba(245, 247, 248, 0.42);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.2;
  transition: border-color 180ms ease, color 180ms ease, background 180ms ease;
}

.related-links a:hover,
.related-links a:focus-visible {
  border-color: rgba(143, 174, 53, 0.58);
  color: #0B0D0F;
  background: rgba(143, 174, 53, 0.1);
}

@media (max-width: 1080px) {
  .answer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .seo-faq {
    padding: 54px 0;
  }

  .answer-grid {
    grid-template-columns: 1fr;
  }

  .answer-card {
    padding: 22px 20px;
  }

  .related-links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .related-links a {
    justify-content: center;
    border-radius: 8px;
    text-align: center;
  }
}

/* Unified proportional system */
:root {
  --elx-container: 1180px;
  --elx-container-wide: 1420px;
  --elx-container-text: 1080px;
  --elx-page-gutter: 48px;
  --elx-page-gutter-mobile: 28px;
  --elx-section-y: clamp(76px, 7vw, 112px);
  --elx-section-y-compact: clamp(56px, 5.4vw, 82px);
  --elx-card-pad: clamp(22px, 2.4vw, 34px);
  --elx-panel-pad: clamp(28px, 4vw, 48px);
  --elx-grid-gap: clamp(18px, 2vw, 28px);
  --elx-copy: 66ch;
  --elx-copy-narrow: 54ch;
  --elx-radius: 8px;
}

.container,
body:has(.shop-layout) .container,
body:has(.product-layout) .container,
body:has(.legal) .container,
body:has(.doc) .container,
body:has(.page-head) .container,
body.programs-page .container {
  width: min(var(--elx-container), calc(100% - var(--elx-page-gutter))) !important;
  margin-inline: auto !important;
}

.home-page .hero-inner.container,
body.home-page:has(.hero-inner) .hero-inner.container {
  width: min(var(--elx-container-wide), calc(100% - 64px)) !important;
}

body:has(.legal) .container,
body:has(.doc) .container,
body:has(.page-head) .container {
  width: min(var(--elx-container-text), calc(100% - var(--elx-page-gutter))) !important;
}

section:not(.hero):not(.seo-summary),
.seo-faq,
body.programs-page section {
  padding-top: var(--elx-section-y) !important;
  padding-bottom: var(--elx-section-y) !important;
}

body:has(.product-layout) main,
body:has(.legal) main,
body:has(.doc) main,
body:has(.page-head) main,
body.programs-page main,
body:has(.cart-layout) main {
  padding-top: clamp(70px, 7vw, 104px) !important;
  padding-bottom: clamp(76px, 7vw, 108px) !important;
}

.section-head,
body.programs-page .section-head,
.page-head,
.process-copy,
.trust-copy {
  margin-bottom: clamp(28px, 3.8vw, 46px) !important;
}

.section-head,
body.programs-page .section-head {
  gap: clamp(16px, 2vw, 26px) !important;
}

.section-head h2,
.process-copy h2,
.trust-copy h2,
.lead-copy h2,
body.programs-page .section-head h2,
.program-cta h2 {
  max-width: 11.5em !important;
  font-size: clamp(34px, 4.2vw, 62px) !important;
  line-height: 1.04 !important;
  letter-spacing: 0 !important;
  text-wrap: balance;
}

.section-head p,
.process-copy p,
.trust-copy p,
.lead-copy p,
body.programs-page .section-head p,
.program-cta p,
.page-head .lead,
.legal .lead,
.doc p,
.doc li,
.document-card p,
.document-card li,
.answer-card p,
.section-card p {
  max-width: var(--elx-copy) !important;
  line-height: 1.62 !important;
}

h1,
.hero h1,
body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
.catalog-hero h1,
body.programs-page .program-hero h1 {
  max-width: 10.5em !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
  text-wrap: balance;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
.catalog-hero h1,
body.programs-page .program-hero h1 {
  font-size: clamp(44px, 5.7vw, 82px) !important;
}

body:has(.legal) h1,
body:has(.doc) h1,
body:has(.page-head) h1,
body:has(.cart-layout) h1 {
  max-width: 10.8em !important;
  font-size: clamp(40px, 5.5vw, 72px) !important;
  line-height: 1.03 !important;
  text-wrap: balance;
}

body:has(.product-layout) h1 {
  max-width: 13.5em !important;
  font-size: clamp(31px, 2.35vw, 42px) !important;
  line-height: 1.12 !important;
}

.systems,
.metrics,
.reviews-grid,
.timeline,
.packages,
.shop-grid,
.compare-grid,
.answer-grid,
.contact-grid,
.doc-grid,
.program-grid,
.check-grid,
.support-grid,
.steps-grid {
  gap: var(--elx-grid-gap) !important;
}

.system,
.metric,
.review-card,
.step,
.package,
.shop-card,
.answer-card,
.doc,
.document-card,
.contact-card,
.service-card,
.support-card,
.program-card,
.cart-panel,
.summary-panel,
.interest,
body:has(.product-layout) .section-card,
body:has(.product-layout) .delivery-payment-block,
body:has(.product-layout) .bundle-card {
  border-radius: var(--elx-radius) !important;
}

.system,
.metric,
.review-card,
.step,
.shop-card,
.answer-card,
.service-card,
.support-card,
.program-card,
.interest {
  padding: var(--elx-card-pad) !important;
}

.doc,
.document-card,
.contact-card,
.lead-panel,
.cart-panel,
.summary-panel,
body:has(.product-layout) .section-card,
body:has(.product-layout) .delivery-payment-block,
body:has(.product-layout) .bundle-card {
  padding: var(--elx-panel-pad) !important;
}

.hero-actions,
.actions,
.package-actions,
.related-links,
.contact-facts {
  gap: clamp(10px, 1.2vw, 14px) !important;
}

.btn,
.hero-actions .btn,
.actions .btn,
.lead-form .btn,
.lead-modal-form .btn,
.package-action,
.cart-continue,
.mobile-menu-cta {
  min-height: 48px !important;
  border-radius: var(--elx-radius) !important;
  padding: 13px 20px !important;
}

.lead-form,
.lead-modal-form,
.cart-form {
  gap: clamp(14px, 1.6vw, 18px) !important;
}

.lead-form input,
.lead-form select,
.lead-form textarea,
.lead-modal-form input,
.lead-modal-form select,
.lead-modal-form textarea,
.cart-form input,
.cart-form select,
.cart-form textarea {
  min-height: 48px !important;
  border-radius: var(--elx-radius) !important;
}

.lead-panel {
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr) !important;
  gap: clamp(28px, 4vw, 56px) !important;
  align-items: start !important;
}

.lead-copy {
  gap: clamp(20px, 3vw, 34px) !important;
}

.seo-faq {
  padding-top: var(--elx-section-y-compact) !important;
  padding-bottom: var(--elx-section-y-compact) !important;
}

.product-faq {
  margin-top: clamp(24px, 3vw, 42px) !important;
}

.answer-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 1px !important;
}

.related-links {
  margin-top: clamp(20px, 2.2vw, 30px) !important;
}

body:has(.product-layout) .product-layout {
  gap: clamp(30px, 4vw, 58px) !important;
  align-items: start !important;
}

body:has(.product-layout) .gallery {
  gap: clamp(12px, 1.5vw, 18px) !important;
}

body:has(.product-layout) .gallery-main {
  min-height: clamp(420px, 42vw, 560px) !important;
  border-radius: var(--elx-radius) !important;
}

body:has(.product-layout) .product-info {
  padding-top: clamp(8px, 1vw, 16px) !important;
}

body:has(.product-layout) .product-back-link {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  min-height: 42px !important;
  margin: 0 0 18px !important;
  padding: 0 15px !important;
  border: 1px solid rgba(43, 49, 55, 0.14) !important;
  border-radius: 999px !important;
  background: rgba(245, 247, 248, 0.72) !important;
  color: rgba(11, 13, 15, 0.76) !important;
  text-decoration: none !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
  transition: border-color 180ms ease, color 180ms ease, background 180ms ease !important;
}

body:has(.product-layout) .product-back-link:hover,
body:has(.product-layout) .product-back-link:focus-visible {
  border-color: rgba(143, 174, 53, 0.42) !important;
  background: rgba(245, 247, 248, 0.94) !important;
  color: var(--elx-black) !important;
}

body:has(.product-layout) .badges,
body:has(.product-layout) .section-tabs {
  gap: 8px !important;
}

.doc h2,
.document-card h2,
.service-card h2,
.contact-card h2,
.cart-panel h2,
.summary-panel h2,
.interest h2 {
  margin-top: clamp(30px, 3.8vw, 42px) !important;
  margin-bottom: 12px !important;
  font-size: clamp(24px, 2.4vw, 32px) !important;
  line-height: 1.12 !important;
  text-wrap: balance;
}

.doc h2:first-child,
.document-card h2:first-child,
.contact-card h2:first-child {
  margin-top: 0 !important;
}

.page-head {
  max-width: 860px !important;
}

.page-head .lead,
.legal .lead {
  max-width: 760px !important;
}

.contact-grid {
  align-items: stretch !important;
}

.contact-card .lead-form {
  max-width: none !important;
}

body.programs-page .hero-panel,
body.programs-page .document-card,
body.programs-page .disclaimer,
body.programs-page .program-cta,
.loyalty-card,
.loyalty-cta {
  border-radius: var(--elx-radius) !important;
}

@media (min-width: 1440px) {
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero .container,
  body:has(.catalog-hero) .catalog-hero .container,
  body.programs-page .container {
    width: min(1240px, calc(100% - 72px)) !important;
  }

  body:has(.legal) .container,
  body:has(.doc) .container,
  body:has(.page-head) .container {
    width: min(1100px, calc(100% - 72px)) !important;
  }
}

@media (max-width: 1080px) {
  .answer-grid,
  .shop-grid,
  .reviews-grid,
  .packages,
  .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .lead-panel,
  body:has(.product-layout) .product-layout,
  .contact-grid {
    grid-template-columns: 1fr !important;
  }

  body:has(.product-layout) .gallery-main {
    min-height: clamp(360px, 58vw, 520px) !important;
  }
}

@media (max-width: 760px) {
  :root {
    --elx-page-gutter: var(--elx-page-gutter-mobile);
    --elx-section-y: clamp(50px, 13vw, 66px);
    --elx-section-y-compact: clamp(46px, 12vw, 60px);
    --elx-card-pad: 22px;
    --elx-panel-pad: 24px;
    --elx-grid-gap: 14px;
  }

  .container,
  body:has(.shop-layout) .container,
  body:has(.product-layout) .container,
  body:has(.legal) .container,
  body:has(.doc) .container,
  body:has(.page-head) .container,
  body.programs-page .container,
  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(100% - var(--elx-page-gutter-mobile), 560px) !important;
  }

  section:not(.hero):not(.seo-summary),
  .seo-faq,
  body.programs-page section {
    padding-top: var(--elx-section-y) !important;
    padding-bottom: var(--elx-section-y) !important;
  }

  .section-head,
  body.programs-page .section-head,
  .page-head,
  .process-copy,
  .trust-copy {
    margin-bottom: 24px !important;
  }

  .section-head h2,
  .process-copy h2,
  .trust-copy h2,
  .lead-copy h2,
  body.programs-page .section-head h2,
  .program-cta h2 {
    max-width: 11em !important;
    font-size: clamp(30px, 8.6vw, 40px) !important;
    line-height: 1.06 !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1,
  .catalog-hero h1,
  body.programs-page .program-hero h1,
  body:has(.legal) h1,
  body:has(.doc) h1,
  body:has(.page-head) h1,
  body:has(.cart-layout) h1 {
    max-width: 10em !important;
    font-size: clamp(34px, 9.6vw, 44px) !important;
    line-height: 1.04 !important;
  }

  body:has(.product-layout) h1 {
    font-size: clamp(28px, 8vw, 34px) !important;
    line-height: 1.1 !important;
  }

  .answer-grid,
  .shop-grid,
  .reviews-grid,
  .packages,
  .metrics,
  .systems,
  .timeline,
  .compare-grid,
  .doc-grid {
    grid-template-columns: 1fr !important;
  }

  .system,
  .metric,
  .review-card,
  .step,
  .shop-card,
  .answer-card,
  .service-card,
  .support-card,
  .program-card,
  .interest,
  .doc,
  .document-card,
  .contact-card,
  .lead-panel,
  .cart-panel,
  .summary-panel,
  body:has(.product-layout) .section-card,
  body:has(.product-layout) .delivery-payment-block,
  body:has(.product-layout) .bundle-card {
    padding: var(--elx-card-pad) !important;
  }

  .lead-panel {
    gap: 24px !important;
  }

  .related-links {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .related-links a {
    min-height: 44px !important;
  }

  body:has(.product-layout) main,
  body:has(.legal) main,
  body:has(.doc) main,
  body:has(.page-head) main,
  body.programs-page main,
  body:has(.cart-layout) main {
    padding-top: 56px !important;
    padding-bottom: 68px !important;
  }

  body:has(.product-layout) .gallery-main {
    min-height: clamp(300px, 78vw, 380px) !important;
  }
}

@media (max-width: 420px) {
  :root {
    --elx-page-gutter-mobile: 24px;
  }

  .btn,
  .hero-actions .btn,
  .actions .btn,
  .lead-form .btn,
  .lead-modal-form .btn,
  .package-action,
  .cart-continue,
  .mobile-menu-cta {
    width: 100%;
    min-width: 0 !important;
  }
}

/* Targeted fixes: mobile menu scale and homepage FAQ header rhythm */
.home-page .seo-faq .section-head {
  grid-template-columns: 1fr !important;
  display: block !important;
  gap: 0 !important;
  max-width: 880px !important;
  margin-bottom: clamp(24px, 3vw, 36px) !important;
  margin-inline: 0 auto !important;
}

.home-page .seo-faq .section-head .section-kicker {
  display: block !important;
  margin-bottom: 16px !important;
}

.home-page .seo-faq .section-head h2 {
  max-width: 10.5em !important;
  margin: 0 0 18px !important;
  color: #0B0D0F !important;
  font-size: clamp(42px, 4.4vw, 64px) !important;
  line-height: 1.04 !important;
}

.home-page .seo-faq .section-head p {
  max-width: 62ch !important;
  font-size: clamp(16px, 1.25vw, 19px) !important;
  line-height: 1.58 !important;
}

@media (min-width: 981px) and (max-width: 1440px) {
  .home-page .seo-faq {
    padding-top: clamp(58px, 5vw, 76px) !important;
    padding-bottom: clamp(58px, 5vw, 76px) !important;
  }

  .home-page .seo-faq .section-head {
    max-width: 780px !important;
  }

  .home-page .seo-faq .section-head h2 {
    font-size: clamp(38px, 4.1vw, 56px) !important;
  }
}

@media (max-width: 980px) {
  body.menu-open .topbar .nav-links {
    padding: calc(110px + env(safe-area-inset-top)) 28px calc(24px + env(safe-area-inset-bottom)) !important;
    gap: 10px !important;
  }

  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    width: 100% !important;
    min-height: 40px !important;
    padding: 4px 0 !important;
    font-size: clamp(26px, 7.2vw, 36px) !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
  }

  .topbar .mobile-menu-cta,
  .topbar .mobile-menu-secondary,
  .topbar .nav-links > a.mobile-menu-secondary {
    min-height: 54px !important;
    padding: 12px 18px !important;
    font-size: clamp(16px, 4.4vw, 19px) !important;
    line-height: 1.2 !important;
  }

  .topbar .mobile-menu-cta {
    margin-top: auto !important;
  }

  .topbar .mobile-menu-secondary {
    display: none !important;
  }
}

@media (max-width: 420px) {
  body.menu-open .topbar .nav-links {
    padding-inline: 24px !important;
  }

  .topbar .nav-links > a,
  .topbar .nav-links .nav-trigger {
    font-size: clamp(24px, 7vw, 32px) !important;
  }
}

/* Cookie banner buttons: align with modal CTA style */
.cookie-actions .cookie-accept,
.cookie-actions button[data-cookie-accept] {
  border-color: #1A1D21 !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  box-shadow: 0 12px 28px rgba(11, 13, 15, 0.14) !important;
}

.cookie-actions .cookie-accept:hover,
.cookie-actions button[data-cookie-accept]:hover,
.cookie-actions .cookie-accept:focus-visible,
.cookie-actions button[data-cookie-accept]:focus-visible {
  border-color: #0B0D0F !important;
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
}

.cookie-actions .cookie-decline,
.cookie-actions button[data-cookie-decline] {
  border-color: rgba(26, 29, 33, 0.18) !important;
  background: rgba(245, 247, 248, 0.7) !important;
  color: #1A1D21 !important;
  box-shadow: none !important;
}

.cookie-actions .cookie-decline:hover,
.cookie-actions button[data-cookie-decline]:hover,
.cookie-actions .cookie-decline:focus-visible,
.cookie-actions button[data-cookie-decline]:focus-visible {
  border-color: rgba(26, 29, 33, 0.32) !important;
  background: #F5F7F8 !important;
  color: #0B0D0F !important;
}

@media (max-width: 560px) {
  .cookie-banner {
    left: 12px !important;
    right: 12px !important;
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    box-sizing: border-box !important;
  }

  .cookie-banner p,
  .cookie-actions button {
    overflow-wrap: anywhere !important;
  }
}

/* Premium framing restraint: make borders intentional accents, not the default surface language. */
:root {
  --elx-frame-line: rgba(43, 49, 55, 0.09);
  --elx-frame-line-soft: rgba(43, 49, 55, 0.06);
  --elx-frame-line-dark: rgba(245, 247, 248, 0.09);
  --elx-surface-open: rgba(245, 247, 248, 0.34);
  --elx-surface-panel: rgba(245, 247, 248, 0.58);
}

.answer-grid,
.contact-grid {
  gap: clamp(18px, 2vw, 28px) !important;
  border: 0 !important;
  background: transparent !important;
}

.answer-card,
.contact-card {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.home-page .seo-faq .answer-grid {
  gap: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
}

.home-page .seo-faq .answer-card {
  padding: clamp(22px, 2.3vw, 34px) clamp(22px, 2.4vw, 32px) !important;
}

.home-page .seo-faq .answer-card + .answer-card {
  border-left: 1px solid var(--elx-frame-line) !important;
}

.contact-grid .contact-card:nth-child(2),
.contact-card:has(.lead-form),
.lead-panel,
.cart-panel,
.summary-panel {
  border: 1px solid var(--elx-frame-line) !important;
  background: var(--elx-surface-panel) !important;
}

.contact-card:has(.lead-form) {
  box-shadow: none !important;
}

.map-frame {
  overflow: hidden !important;
  border-radius: var(--elx-radius, 8px) !important;
}

.trust {
  border-bottom: 0 !important;
  background: rgba(245, 247, 248, 0.46) !important;
}

.trust-list,
.timeline {
  border-top-color: var(--elx-frame-line) !important;
}

.trust-item,
.step {
  border-bottom-color: var(--elx-frame-line) !important;
}

.range-note,
.note,
.package-note {
  border: 0 !important;
  border-left: 2px solid rgba(143, 174, 53, 0.48) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 8px 0 8px 16px !important;
}

.reviews-head {
  border-top-color: var(--elx-frame-line) !important;
}

.review-card {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding-inline: 0 !important;
}

.review-card + .review-card {
  border-left: 1px solid var(--elx-frame-line) !important;
  padding-left: clamp(22px, 2.4vw, 34px) !important;
}

.metric {
  border-color: var(--elx-frame-line-dark) !important;
  background: rgba(245, 247, 248, 0.018) !important;
  box-shadow: none !important;
}

.package-discounts,
.package-common {
  gap: clamp(18px, 2vw, 26px) !important;
}

.package-discount,
.common-item {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.package-discount {
  border-top: 1px solid var(--elx-frame-line) !important;
  padding-top: 16px !important;
}

.common-item {
  border-left: 2px solid rgba(143, 174, 53, 0.36) !important;
  padding-left: 16px !important;
}

.package,
.shop-card,
.catalog-featured-grid .shop-card,
body:has(.product-layout) .section-card,
body:has(.product-layout) .delivery-payment-block,
body:has(.product-layout) .bundle-card,
.document-card,
.service-card,
.support-card,
.program-card,
.interest {
  border-color: var(--elx-frame-line) !important;
  background: var(--elx-surface-open) !important;
  box-shadow: none !important;
}

.package.featured,
.shop-card.featured,
.catalog-featured-grid .shop-card.featured {
  border-color: rgba(26, 29, 33, 0.18) !important;
  background: rgba(245, 247, 248, 0.72) !important;
  box-shadow: 0 18px 54px rgba(11, 13, 15, 0.07) !important;
}

.package:hover,
.shop-card:hover,
.catalog-featured-grid .shop-card:hover {
  border-color: rgba(143, 174, 53, 0.26) !important;
  box-shadow: 0 14px 42px rgba(11, 13, 15, 0.07) !important;
  transform: translateY(-2px) !important;
}

.product-card-image,
.catalog-featured-grid .product-card-image,
.package-media.product-media {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.package-spec,
.catalog-specs span,
.delivery-payment-block li,
body:has(.product-layout) .section-tabs button,
body:has(.product-layout) .badges span {
  border-color: var(--elx-frame-line-soft) !important;
}

.related-links a {
  border-color: transparent !important;
  background: transparent !important;
  padding-inline: 0 !important;
}

.related-links a:hover,
.related-links a:focus-visible {
  border-color: transparent !important;
  background: transparent !important;
  color: #8FAE35 !important;
}

@media (min-width: 761px) {
  .answer-card {
    padding: 0 !important;
  }

  .home-page .seo-faq .answer-card {
    padding: clamp(22px, 2.3vw, 34px) clamp(22px, 2.4vw, 32px) !important;
  }

  .contact-grid {
    align-items: start !important;
  }
}

@media (max-width: 760px) {
  .answer-grid,
  .contact-grid,
  .reviews-grid,
  .package-discounts,
  .package-common {
    gap: 0 !important;
  }

  .answer-card,
  .review-card,
  .contact-grid .contact-card:not(:has(.lead-form)),
  .package-discount,
  .common-item {
    padding: 20px 0 !important;
    border-bottom: 1px solid var(--elx-frame-line) !important;
    border-left: 0 !important;
  }

  .home-page .seo-faq .answer-grid {
    border-top: 0 !important;
    border-bottom: 0 !important;
  }

  .home-page .seo-faq .answer-card {
    padding: 20px 0 !important;
  }

  .home-page .seo-faq .answer-card + .answer-card {
    border-left: 0 !important;
  }

  .answer-card:first-child,
  .review-card:first-child,
  .contact-grid .contact-card:first-child,
  .package-discount:first-child,
  .common-item:first-child {
    padding-top: 0 !important;
  }

  .review-card + .review-card {
    border-left: 0 !important;
    padding-left: 0 !important;
  }

  .contact-card:has(.lead-form),
  .lead-panel,
  .cart-panel,
  .summary-panel {
    margin-top: 18px !important;
  }

  .package,
  .shop-card,
  .catalog-featured-grid .shop-card {
    background: rgba(245, 247, 248, 0.48) !important;
  }

  .range-note,
  .note,
  .package-note {
    margin-top: 14px !important;
    padding: 8px 0 8px 14px !important;
    border-bottom: 0 !important;
    border-left: 2px solid rgba(143, 174, 53, 0.48) !important;
  }
}

/* SEO FAQ framing: calm editorial header and vertical question dividers across catalog pages. */
.seo-faq .section-head {
  display: block !important;
  max-width: 900px !important;
  margin-inline: 0 auto !important;
  margin-bottom: clamp(28px, 3.6vw, 42px) !important;
}

.seo-faq .section-head .section-kicker {
  display: block !important;
  margin-bottom: 16px !important;
}

.seo-faq .section-head h2 {
  max-width: 11em !important;
  margin: 0 0 18px !important;
  font-size: clamp(38px, 4.2vw, 62px) !important;
  line-height: 1.04 !important;
}

.seo-faq .section-head p {
  max-width: 70ch !important;
  font-size: clamp(16px, 1.2vw, 18px) !important;
  line-height: 1.62 !important;
}

.seo-faq .answer-grid {
  gap: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.seo-faq .answer-card {
  padding: clamp(22px, 2.3vw, 34px) clamp(22px, 2.4vw, 32px) !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.seo-faq .answer-card + .answer-card {
  border-left: 1px solid var(--elx-frame-line) !important;
}

@media (max-width: 1080px) and (min-width: 761px) {
  .seo-faq .answer-card:nth-child(odd) {
    border-left: 0 !important;
  }

  .seo-faq .answer-card:nth-child(n + 3) {
    margin-top: 26px !important;
  }
}

@media (max-width: 760px) {
  .seo-faq .section-head {
    margin-bottom: 22px !important;
  }

  .seo-faq .section-head h2 {
    max-width: 10.5em !important;
    font-size: clamp(30px, 8.4vw, 40px) !important;
  }

  .seo-faq .answer-grid {
    gap: 18px !important;
  }

  .seo-faq .answer-card,
  .seo-faq .answer-card:first-child {
    padding: 0 0 0 16px !important;
    border-bottom: 0 !important;
    border-left: 1px solid var(--elx-frame-line) !important;
  }

  .seo-faq .answer-card + .answer-card {
    border-left: 1px solid var(--elx-frame-line) !important;
  }
}

/* Program CTA and warranty pages: remove off-system heavy banners and boxed legal framing. */
body.programs-page .program-cta {
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: clamp(18px, 3vw, 42px) !important;
  align-items: center !important;
  margin-top: clamp(42px, 5vw, 72px) !important;
  padding: clamp(28px, 4vw, 46px) 0 !important;
  border: 0 !important;
  border-top: 1px solid var(--elx-frame-line) !important;
  border-bottom: 1px solid var(--elx-frame-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #0B0D0F !important;
  box-shadow: none !important;
}

body.programs-page .program-cta h2 {
  max-width: 11em !important;
  margin: 0 0 12px !important;
  color: #0B0D0F !important;
  font-size: clamp(30px, 3.8vw, 54px) !important;
  line-height: 1.04 !important;
}

body.programs-page .program-cta p {
  max-width: 62ch !important;
  color: rgba(11, 13, 15, 0.66) !important;
  font-size: clamp(15px, 1.15vw, 17px) !important;
  font-weight: 720 !important;
  line-height: 1.58 !important;
}

body.programs-page .program-cta .btn {
  min-width: 230px !important;
  border-color: #1A1D21 !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  box-shadow: none !important;
}

body:has(.summary-grid) .doc {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.summary-grid) .summary-grid {
  gap: 0 !important;
  margin-bottom: clamp(34px, 4vw, 52px) !important;
  border-top: 1px solid var(--elx-frame-line) !important;
  border-bottom: 1px solid var(--elx-frame-line) !important;
}

body:has(.summary-grid) .summary-card {
  min-height: 128px !important;
  padding: clamp(20px, 2.4vw, 30px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.summary-grid) .summary-card + .summary-card {
  border-left: 1px solid var(--elx-frame-line) !important;
}

body:has(.summary-grid) .service-card {
  grid-template-columns: 170px minmax(0, 1fr) !important;
  margin: clamp(30px, 4vw, 48px) 0 !important;
  padding: clamp(24px, 3vw, 34px) 0 !important;
  border: 0 !important;
  border-top: 1px solid var(--elx-frame-line) !important;
  border-bottom: 1px solid var(--elx-frame-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.summary-grid) .service-logo {
  border-radius: 8px !important;
  box-shadow: none !important;
}

body:has(.summary-grid) .doc h2 {
  font-size: clamp(24px, 2.4vw, 32px) !important;
}

body:has(.summary-grid) .note {
  border: 0 !important;
  border-left: 2px solid rgba(143, 174, 53, 0.48) !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 8px 0 8px 16px !important;
  color: rgba(11, 13, 15, 0.72) !important;
}

@media (max-width: 760px) {
  body.programs-page .program-cta {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  body.programs-page .program-cta .btn {
    width: 100% !important;
    min-width: 0 !important;
  }

  body:has(.summary-grid) .summary-grid,
  body:has(.summary-grid) .service-card {
    grid-template-columns: 1fr !important;
  }

  body:has(.summary-grid) .summary-card + .summary-card {
    border-left: 0 !important;
    border-top: 1px solid var(--elx-frame-line) !important;
  }

  body:has(.summary-grid) .service-card {
    gap: 22px !important;
  }
}

/* Official ELX Energy color discipline: six-color matte interface system. */
:root {
  --elx-black: #0B0D0F;
  --elx-graphite: #1A1D21;
  --elx-green: #8FAE35;
  --elx-white: #F5F7F8;
  --elx-muted: #7C8791;
  --elx-divider: #2B3137;
  --elx-divider-a08: rgba(43, 49, 55, 0.08);
  --elx-divider-a12: rgba(43, 49, 55, 0.12);
  --elx-divider-a16: rgba(43, 49, 55, 0.16);
}

body {
  background: var(--elx-white) !important;
  color: var(--elx-black) !important;
}

.page {
  background: var(--elx-white) !important;
  background-image: none !important;
}

.topbar,
.site-header,
.seo-faq,
.trust,
.programs-page main,
body:has(.legal) main,
body:has(.doc) main,
body:has(.page-head) main,
.shop-layout,
.page,
.legal,
.doc {
  background-color: var(--elx-white) !important;
}

.site-footer,
.deep-band,
.mobile-menu,
.lead-modal-dialog,
.callback-popover,
.call-popover,
.product-dialog {
  background: var(--elx-black) !important;
  background-image: none !important;
}

.site-footer,
.deep-band,
.mobile-menu,
.lead-modal-dialog,
.callback-popover,
.call-popover,
.product-dialog {
  color: var(--elx-white) !important;
}

.btn-primary,
.btn.dark,
.mobile-menu-cta,
.package-action.primary,
.lead-form .btn,
.lead-modal-form .btn,
.cart-continue,
.cookie-actions .cookie-accept,
.cookie-actions button[data-cookie-accept],
body.programs-page .program-cta .btn {
  border-color: var(--elx-graphite) !important;
  background: var(--elx-graphite) !important;
  color: var(--elx-white) !important;
  box-shadow: none !important;
}

.btn-secondary,
.btn-soft,
.hero-secondary-link,
.cookie-actions .cookie-decline,
.cookie-actions button[data-cookie-decline] {
  border-color: var(--elx-divider-a16) !important;
  background: var(--elx-white) !important;
  color: var(--elx-graphite) !important;
  box-shadow: none !important;
}

.section-kicker,
.kicker,
.eyebrow,
.product-kicker,
.product-type-label,
.brand-name,
.metric small,
.step span,
.review-mark,
.summary-card strong,
.trust-item strong,
.trust-item .trust-brand,
a:hover,
a:focus-visible {
  color: var(--elx-green) !important;
}

.hero-accent,
.range-note,
.note,
.package-note,
.common-item,
.seo-faq .answer-card,
body:has(.summary-grid) .note {
  border-left-color: var(--elx-green) !important;
}

.answer-grid,
.contact-grid,
.summary-grid,
.trust-list,
.timeline,
.program-cta,
.service-card,
.review-card + .review-card,
.seo-faq .answer-card + .answer-card,
.shop-card,
.package,
.document-card,
.service-card,
.support-card,
.program-card,
.cart-panel,
.summary-panel,
body:has(.product-layout) .section-card,
body:has(.product-layout) .bundle-card,
body:has(.product-layout) .delivery-payment-block {
  border-color: var(--elx-divider-a12) !important;
}

.shop-card,
.package,
.answer-card,
.contact-card,
.document-card,
.service-card,
.support-card,
.program-card,
.summary-card,
.financial-note,
.hero-accent,
.lead-panel,
.cart-panel,
.summary-panel,
body:has(.product-layout) .section-card,
body:has(.product-layout) .bundle-card,
body:has(.product-layout) .delivery-payment-block {
  background: var(--elx-white) !important;
  box-shadow: none !important;
}

.hero-panel,
.hero-media::after,
.mega-card::after,
.product-card-image,
.gallery-main,
.product-visual,
.package-media,
.financial-note,
.summary-card,
.program-cta,
.site-footer,
.lead-modal-dialog,
.callback-popover,
.call-popover {
  background-image: none !important;
}

.hero-panel {
  background-color: var(--elx-graphite) !important;
}

.deep-band .metric,
.deep-band .system,
.deep-band .package {
  border-color: rgba(245, 247, 248, 0.12) !important;
  background: var(--elx-graphite) !important;
}

.product-card-image,
.gallery-main,
.product-visual,
.package-media.product-media {
  background-color: var(--elx-white) !important;
}

.brand-solis small,
.brand-solis .brand-name,
.brand-name.solis {
  color: var(--elx-muted) !important;
}

.muted,
.lead,
.hero-text,
.section-head p,
.doc p,
.doc li,
.answer-card p,
.shop-card p,
.package p,
.review-card blockquote,
.trust-item span,
.product-description,
.form-note,
.cookie-banner p {
  color: var(--elx-muted) !important;
}

*:focus-visible {
  outline-color: var(--elx-green) !important;
  box-shadow: none !important;
}

.call-widget .call-popover {
  background: var(--elx-black) !important;
  background-image: none !important;
}

body select,
.lead-form select,
.lead-modal-form select,
.cart-form select {
  background-image: none !important;
}

@media (max-width: 980px) {
  body.menu-open .topbar .nav-links {
    background: var(--elx-black) !important;
  }
}

/* Dark popup proportion and focus discipline: monochrome, single-ring controls. */
.call-widget .call-popover {
  bottom: 0 !important;
  width: min(380px, calc(100vw - 44px)) !important;
  padding: 24px 24px 26px !important;
  border-color: rgba(245, 247, 248, 0.12) !important;
  border-radius: 10px !important;
  transform-origin: right bottom !important;
}

.call-widget .call-popover::before {
  width: 92px !important;
  height: 38px !important;
  margin-bottom: 12px !important;
}

.call-popover h3 {
  max-width: 300px !important;
  margin-bottom: 8px !important;
  font-size: clamp(28px, 2.7vw, 34px) !important;
  line-height: 1.06 !important;
}

.call-popover p {
  max-width: 300px !important;
  font-size: 14px !important;
  line-height: 1.42 !important;
}

.call-close {
  top: 16px !important;
  right: 16px !important;
  width: 36px !important;
  height: 36px !important;
  border-color: rgba(245, 247, 248, 0.22) !important;
  background: rgba(245, 247, 248, 0.06) !important;
  box-shadow: none !important;
  font-size: 23px !important;
}

.call-direct {
  margin: 14px 0 12px !important;
  padding: 12px 14px !important;
  gap: 4px !important;
  border-color: rgba(245, 247, 248, 0.16) !important;
  background: rgba(245, 247, 248, 0.07) !important;
}

.call-direct small {
  font-size: 11px !important;
}

.call-direct span {
  font-size: clamp(21px, 2vw, 25px) !important;
}

.callback-form input,
.lead-modal-form input,
.lead-modal-form select,
.lead-modal-form textarea {
  border: 1px solid rgba(245, 247, 248, 0.18) !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.callback-form input:focus,
.callback-form input:focus-visible,
.lead-modal-form input:focus,
.lead-modal-form input:focus-visible,
.lead-modal-form select:focus,
.lead-modal-form select:focus-visible,
.lead-modal-form textarea:focus,
.lead-modal-form textarea:focus-visible {
  border-color: rgba(245, 247, 248, 0.74) !important;
  outline: 0 !important;
  background: rgba(245, 247, 248, 0.10) !important;
  box-shadow: none !important;
}

.callback-form {
  gap: 11px !important;
}

.callback-form label {
  gap: 7px !important;
  font-size: 12px !important;
}

.callback-form input {
  min-height: 48px !important;
  padding: 12px 14px !important;
  border-radius: 10px !important;
}

.callback-form .btn {
  min-height: 50px !important;
  padding: 12px 18px !important;
  border-radius: 8px !important;
  font-size: 14px !important;
}

@media (max-width: 640px) {
  .call-widget .call-popover {
    width: auto !important;
    padding: 24px 18px calc(22px + env(safe-area-inset-bottom)) !important;
  }

  .call-popover h3 {
    font-size: clamp(27px, 8vw, 34px) !important;
  }
}

body:has(.product-layout) .bos-gallery .gallery-main img {
  width: min(86%, 560px) !important;
  max-height: min(500px, calc(clamp(420px, 43vw, 540px) - 56px)) !important;
}

body:has(.product-layout) .bos-gallery .thumbs {
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr)) !important;
}

@media (max-width: 560px) {
  body:has(.product-layout) .bos-gallery .gallery-main img {
    width: min(86%, 330px) !important;
    max-height: min(300px, calc(clamp(300px, 62vw, 380px) - 40px)) !important;
  }
}

body.ess-open-detail:has(.product-layout) .section-card {
  padding: 8px 0 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.ess-open-detail:has(.product-layout) .section-card p {
  max-width: 68ch !important;
}

.shop-filter .filter-reset {
  min-height: 46px !important;
  width: 100% !important;
  margin-top: 4px !important;
  border: 1px solid rgba(11, 13, 15, 0.92) !important;
  border-radius: 999px !important;
  background: #0B0D0F !important;
  color: #F5F7F8 !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
  box-shadow: 0 14px 34px rgba(11, 13, 15, 0.16) !important;
  transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease !important;
}

.shop-filter .filter-reset:hover,
.shop-filter .filter-reset:focus-visible {
  background: #1A1D21 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 18px 42px rgba(11, 13, 15, 0.20) !important;
}


/* ELX catalog and product engineering system. */
:root {
  --elx-black: #0B0D0F;
  --elx-graphite: #1A1D21;
  --elx-green: #8FAE35;
  --elx-white: #F5F7F8;
  --elx-muted: #7C8791;
  --elx-divider: #2B3137;
}

body:has(.shop-layout),
body:has(.product-layout) {
  background: var(--elx-white) !important;
  color: var(--elx-black) !important;
}

body:has(.shop-layout) .financial-note {
  display: none !important;
}

body:has(.shop-layout) .shop-filter,
body:has(.shop-layout) .shop-card,
body:has(.shop-layout) .product-card-image,
body:has(.shop-layout) .filter-reset,
body:has(.shop-layout) .cart-button,
body:has(.product-layout) .gallery-main,
body:has(.product-layout) .thumb,
body:has(.product-layout) .section-card,
body:has(.product-layout) .spec-panel,
body:has(.product-layout) .delivery-payment-block,
body:has(.product-layout) .bundle-highlight,
body:has(.product-layout) .bundle-card,
body:has(.product-layout) .btn,
body:has(.product-layout) [data-add-cart] {
  box-shadow: none !important;
  background-image: none !important;
}

body:has(.shop-layout) .shop-grid {
  align-items: stretch !important;
}

body:has(.shop-layout) .shop-card {
  display: grid !important;
  grid-template-rows: 1fr auto !important;
  min-height: 570px !important;
  height: 100% !important;
  padding: 22px !important;
  border: 1px solid rgba(43, 49, 55, 0.14) !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.82) !important;
  color: var(--elx-black) !important;
  transition: border-color 180ms ease, background 180ms ease, transform 180ms ease !important;
}

body:has(.shop-layout) .shop-card:hover,
body:has(.shop-layout) .shop-card:focus-visible {
  border-color: rgba(43, 49, 55, 0.32) !important;
  background: var(--elx-white) !important;
  transform: translateY(-2px) !important;
}

body:has(.shop-layout) .shop-card > div:first-child {
  display: grid !important;
  grid-template-rows: auto 270px auto minmax(0, 1fr) !important;
  align-content: start !important;
  gap: 0 !important;
}

body:has(.shop-layout) .shop-card-top {
  min-height: 28px !important;
  align-items: flex-start !important;
  gap: 16px !important;
}

body:has(.shop-layout) .shop-card-top small,
body:has(.shop-layout) .brand-name {
  color: var(--elx-black) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}

body:has(.shop-layout) .product-card-image {
  height: 270px !important;
  margin: 18px 0 22px !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
  border: 1px solid rgba(43, 49, 55, 0.10) !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.72) !important;
}

body:has(.shop-layout) .product-card-image img,
body:has(.shop-layout) .product-card-image.is-portrait img,
body:has(.shop-layout) .product-card-image.is-battery img,
body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  padding: 20px !important;
  object-fit: contain !important;
  object-position: center !important;
  filter: none !important;
}

body:has(.shop-layout) .product-specs {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-end !important;
  gap: 0 !important;
  max-width: 190px !important;
  color: var(--elx-muted) !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
  text-align: right !important;
}

body:has(.shop-layout) .spec-badge {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--elx-muted) !important;
  box-shadow: none !important;
}

body:has(.shop-layout) .spec-badge + .spec-badge::before {
  content: "／";
  margin: 0 7px;
  color: rgba(43, 49, 55, 0.55);
}

body:has(.shop-layout) .product-type-label {
  display: none !important;
}

body:has(.shop-layout) .shop-card h3 {
  margin: 0 0 12px !important;
  color: var(--elx-black) !important;
  font-size: clamp(22px, 2.1vw, 31px) !important;
  line-height: 1.04 !important;
  letter-spacing: 0 !important;
}

body:has(.shop-layout) .shop-card p {
  max-width: 32ch !important;
  margin: 0 !important;
  color: var(--elx-muted) !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

body:has(.shop-layout) .item-price {
  align-self: end !important;
  margin-top: 22px !important;
  padding-top: 18px !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  color: var(--elx-black) !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

body:has(.shop-layout) .shop-filter {
  border: 1px solid rgba(43, 49, 55, 0.14) !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.84) !important;
  padding: 18px !important;
}

body:has(.shop-layout) .filter-group {
  padding: 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.shop-layout) .filter-toggle {
  width: 100% !important;
  min-height: 48px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--elx-black) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  font: inherit !important;
  font-weight: 900 !important;
  text-align: left !important;
  cursor: pointer !important;
}

body:has(.shop-layout) .filter-toggle::after {
  content: "+";
  color: var(--elx-muted);
  font-size: 22px;
  line-height: 1;
}

body:has(.shop-layout) .filter-group.is-open .filter-toggle::after {
  content: "−";
}

body:has(.shop-layout) .filter-options {
  padding: 0 0 16px !important;
}

body:has(.shop-layout) .filter-option {
  border-radius: 0 !important;
  color: var(--elx-muted) !important;
}

body:has(.shop-layout) .filter-option input {
  accent-color: var(--elx-green) !important;
}

body:has(.shop-layout) .filter-reset {
  min-height: 46px !important;
  border: 1px solid var(--elx-black) !important;
  border-radius: 8px !important;
  background: var(--elx-black) !important;
  color: var(--elx-white) !important;
  font-weight: 900 !important;
}

body:has(.product-layout) .section-card,
body:has(.product-layout) .spec-panel {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 8px 0 0 !important;
}

body:has(.product-layout) .section-tabs {
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
  gap: 0 !important;
}

body:has(.product-layout) .section-tab {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--elx-muted) !important;
  box-shadow: none !important;
}

body:has(.product-layout) .section-tab.is-active {
  color: var(--elx-black) !important;
  border-bottom: 2px solid var(--elx-green) !important;
}

body:has(.product-layout) .spec-row {
  display: grid !important;
  grid-template-columns: minmax(150px, 0.36fr) 1fr !important;
  gap: 24px !important;
  padding: 15px 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.product-layout) .spec-row strong {
  color: var(--elx-muted) !important;
  font-weight: 750 !important;
}

body:has(.product-layout) .spec-row span {
  color: var(--elx-black) !important;
  font-weight: 820 !important;
}

body:has(.product-layout) .product-accordions {
  margin-top: clamp(28px, 4vw, 48px) !important;
  border-top: 1px solid rgba(43, 49, 55, 0.14) !important;
}

body:has(.product-layout) .product-accordion {
  border-bottom: 1px solid rgba(43, 49, 55, 0.14) !important;
}

body:has(.product-layout) .product-accordion-trigger {
  width: 100% !important;
  min-height: 68px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--elx-black) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  font: inherit !important;
  font-size: clamp(18px, 1.6vw, 23px) !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}

body:has(.product-layout) .accordion-mark {
  color: var(--elx-muted) !important;
  font-size: 30px !important;
  line-height: 1 !important;
}

body:has(.product-layout) .product-accordion-panel {
  padding: 0 0 26px !important;
  color: var(--elx-muted) !important;
}

body:has(.product-layout) .product-accordion-panel .delivery-payment-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

body:has(.product-layout) .product-accordion-panel .delivery-payment-block {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 0 !important;
}

body:has(.product-layout) .badge,
body:has(.product-layout) .bundle-chip {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

@media (max-width: 760px) {
  body:has(.shop-layout) .shop-card {
    min-height: 510px !important;
    padding: 18px !important;
  }

  body:has(.shop-layout) .shop-card > div:first-child {
    grid-template-rows: auto 230px auto minmax(0, 1fr) !important;
  }

  body:has(.shop-layout) .product-card-image {
    height: 230px !important;
  }

  body:has(.shop-layout) .shop-card h3 {
    font-size: clamp(21px, 7vw, 28px) !important;
  }

  body:has(.product-layout) .spec-row {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
  }

  body:has(.product-layout) .product-accordion-panel .delivery-payment-grid {
    grid-template-columns: 1fr !important;
  }
}


/* ELX catalog proportion correction. */
body:has(.shop-layout) .shop-card,
body:has(.shop-layout) .shop-card.product-card {
  min-height: 0 !important;
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 0 !important;
  padding: clamp(22px, 2.2vw, 30px) !important;
}

body:has(.shop-layout) .shop-card > div:first-child,
body:has(.shop-layout) .shop-card.product-card > div:first-child {
  display: flex !important;
  flex-direction: column !important;
  flex: 0 0 auto !important;
  min-height: 0 !important;
  height: auto !important;
  gap: 0 !important;
}

body:has(.shop-layout) .product-card-image,
body:has(.shop-layout) .catalog-featured-grid .product-card-image {
  height: 250px !important;
  margin: 18px 0 16px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

body:has(.shop-layout) .product-card-image img,
body:has(.shop-layout) .product-card-image.is-portrait img,
body:has(.shop-layout) .product-card-image.is-battery img,
body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill,
body:has(.shop-layout) .catalog-featured-grid .product-card-image img {
  width: auto !important;
  height: auto !important;
  max-width: min(84%, 320px) !important;
  max-height: 225px !important;
  padding: 0 !important;
  object-fit: contain !important;
  object-position: center !important;
  filter: none !important;
}

body:has(.shop-layout) .product-card-image.is-battery img,
body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill {
  max-width: min(86%, 330px) !important;
  max-height: 225px !important;
}

body:has(.shop-layout) .shop-card h3,
body:has(.shop-layout) .shop-card.product-card h3 {
  margin: 0 0 14px !important;
  color: var(--elx-black) !important;
  font-size: clamp(18px, 1.45vw, 24px) !important;
  line-height: 1.08 !important;
  letter-spacing: 0 !important;
  overflow-wrap: anywhere !important;
  hyphens: auto !important;
}

body:has(.shop-layout) .shop-card h3::after,
body:has(.shop-layout) .shop-card[data-href] h3::after,
body:has(.shop-layout) .shop-card[data-open-lead-modal] h3::after {
  content: none !important;
  display: none !important;
}

body:has(.shop-layout) .item-price,
body:has(.shop-layout) .shop-card .item-price {
  align-self: stretch !important;
  margin-top: 14px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  font-size: clamp(18px, 1.4vw, 22px) !important;
  line-height: 1.1 !important;
}

body:has(.shop-layout) .item-price::after,
body:has(.shop-layout) .shop-card .item-price::after {
  content: none !important;
  display: none !important;
}

body:has(.shop-layout) .financial-note,
body:has(.shop-layout) .shop-card small:has(+ .item-price),
body:has(.shop-layout) .shop-card .price-note {
  display: none !important;
}

@media (max-width: 760px) {
  body:has(.shop-layout) .shop-card,
  body:has(.shop-layout) .shop-card.product-card {
    min-height: 0 !important;
    padding: 18px !important;
  }

  body:has(.shop-layout) .shop-card > div:first-child,
  body:has(.shop-layout) .shop-card.product-card > div:first-child {
    display: flex !important;
  }

  body:has(.shop-layout) .product-card-image,
  body:has(.shop-layout) .catalog-featured-grid .product-card-image {
    height: 220px !important;
    margin: 14px 0 14px !important;
  }

  body:has(.shop-layout) .product-card-image img,
  body:has(.shop-layout) .product-card-image.is-portrait img,
  body:has(.shop-layout) .product-card-image.is-battery img,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill {
    max-width: min(86%, 280px) !important;
    max-height: 195px !important;
  }

  body:has(.shop-layout) .shop-card h3,
  body:has(.shop-layout) .shop-card.product-card h3 {
    font-size: clamp(19px, 6vw, 24px) !important;
    line-height: 1.1 !important;
  }
}


/* ELX battery card image normalization. */
body:has(.shop-layout) .product-card-image.is-battery {
  height: 246px !important;
}

body:has(.shop-layout) .product-card-image.is-battery img {
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: center !important;
}

body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv,
body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill.battery-size-lv {
  max-width: 250px !important;
  max-height: 216px !important;
}

body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv-wide {
  max-width: 300px !important;
  max-height: 200px !important;
}

body:has(.shop-layout) .product-card-image.is-battery img.battery-size-module {
  max-width: 300px !important;
  max-height: 205px !important;
}

body:has(.shop-layout) .product-card-image.is-battery img.battery-size-rack,
body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system,
body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system-wide,
body:has(.shop-layout) .product-card-image.is-battery img.battery-size-ess {
  max-width: 300px !important;
  max-height: 216px !important;
}

body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system-wide {
  max-width: 320px !important;
  max-height: 198px !important;
}

@media (max-width: 760px) {
  body:has(.shop-layout) .product-card-image.is-battery {
    height: 216px !important;
  }

  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-module,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-rack,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-ess {
    max-width: 250px !important;
    max-height: 188px !important;
  }

  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv-wide,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system-wide {
    max-width: 270px !important;
    max-height: 176px !important;
  }
}


/* ELX product description editorial rhythm. */
body:has(.product-layout) #description h3 {
  max-width: 760px;
  margin: clamp(26px, 3vw, 36px) 0 12px;
  color: var(--elx-black);
  font-size: clamp(22px, 2.1vw, 30px);
  line-height: 1.08;
  letter-spacing: 0;
}

body:has(.product-layout) #description p {
  max-width: 820px;
}

body:has(.product-layout) #description .product-description-list {
  display: grid;
  gap: 10px;
  max-width: 820px;
  margin: 16px 0 4px;
  padding: 0;
  list-style: none;
}

body:has(.product-layout) #description .product-description-list li {
  position: relative;
  padding-left: 22px;
  color: var(--elx-muted);
  font-size: clamp(15px, 1vw, 17px);
  font-weight: 720;
  line-height: 1.55;
}

body:has(.product-layout) #description .product-description-list li::before {
  content: "";
  position: absolute;
  top: 0.72em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--elx-green);
}

body:has(.product-layout) #description .product-description-list.compact {
  margin-top: 12px;
}

body:has(.product-layout) #description .product-description-specs {
  display: grid;
  max-width: 860px;
  margin: 16px 0 4px;
  padding: 0;
  list-style: none;
  border-top: 1px solid rgba(43, 49, 55, 0.12);
}

body:has(.product-layout) #description .product-description-specs li {
  display: grid;
  grid-template-columns: minmax(160px, 0.45fr) minmax(0, 1fr);
  gap: 18px;
  padding: 13px 0;
  border-bottom: 1px solid rgba(43, 49, 55, 0.1);
  color: var(--elx-black);
  font-size: clamp(14px, 0.95vw, 16px);
  line-height: 1.45;
}

body:has(.product-layout) #description .product-description-specs strong {
  color: var(--elx-muted);
  font-weight: 760;
}

/* Keep product info tabs light and legible in every state. */
body:has(.product-layout) .section-tabs {
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
  background: transparent !important;
}

body:has(.product-layout) .section-tab,
body:has(.product-layout) .section-tab:hover,
body:has(.product-layout) .section-tab:focus-visible {
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--elx-muted) !important;
  box-shadow: none !important;
}

body:has(.product-layout) .section-tab:hover,
body:has(.product-layout) .section-tab:focus-visible {
  color: var(--elx-black) !important;
}

body:has(.product-layout) .section-tab.is-active,
body:has(.product-layout) .section-tab.is-active:hover,
body:has(.product-layout) .section-tab.is-active:focus-visible {
  border-bottom-color: var(--elx-green) !important;
  background: transparent !important;
  color: var(--elx-black) !important;
}

/* Keep the home hero angled, but without the decorative green stripe. */
body.home-page:has(.hero-inner) .hero-media,
body:has(.hero-inner) .hero-media,
.hero-media {
  clip-path: polygon(10% 0, 100% 0, 100% 100%, 0 100%) !important;
  transform: none !important;
  background: transparent !important;
}

body.home-page:has(.hero-inner) .hero-media::before,
body:has(.hero-inner) .hero-media::before,
.hero-media::before,
body.home-page:has(.hero-inner) .hero-media::after,
body:has(.hero-inner) .hero-media::after,
.hero-media::after {
  content: none !important;
  display: none !important;
}

body.home-page:has(.hero-inner) .hero-media,
body.home-page .hero-media {
  margin-top: clamp(-54px, -3.2vw, -30px) !important;
  margin-right: calc(50% - 50vw) !important;
  min-height: clamp(560px, calc(100svh - 118px), 840px) !important;
  border-radius: 0 !important;
}

body.home-page:has(.hero-inner) .hero-media img,
body.home-page .hero-media img {
  min-height: clamp(560px, calc(100svh - 118px), 840px) !important;
  object-position: 100% 42% !important;
}

/* Keep the header and logo optically clean: no shadow or glow above the mark. */
.topbar,
.site-header,
body.menu-open .topbar {
  border-bottom: 0 !important;
  border-radius: 0 !important;
  background: #F5F7F8 !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;
  text-shadow: none !important;
  backdrop-filter: none !important;
}

.topbar .brand,
.topbar .logo,
.site-header .brand,
.site-header .logo {
  box-shadow: none !important;
  filter: none !important;
  text-shadow: none !important;
  mix-blend-mode: normal !important;
  backdrop-filter: none !important;
}

.topbar .brand img,
.topbar .logo img,
.site-header .brand img,
.site-header .logo img {
  width: 132px !important;
  height: 48px !important;
  object-fit: contain !important;
  box-shadow: none !important;
  filter: none !important;
  text-shadow: none !important;
  mix-blend-mode: normal !important;
  backdrop-filter: none !important;
}

.topbar .cart-nav,
.topbar .menu-toggle,
.site-header .cart-icon,
.site-header .menu-toggle,
.site-header .nav-actions .btn {
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
}

.topbar .cart-nav:hover,
.topbar .menu-toggle:hover,
.site-header .cart-icon:hover,
.site-header .menu-toggle:hover,
.site-header .nav-actions .btn:hover {
  box-shadow: none !important;
}

.topbar::before,
.topbar::after,
.site-header::before,
.site-header::after,
.topbar .brand::before,
.topbar .brand::after {
  content: none !important;
  display: none !important;
  background: none !important;
  box-shadow: none !important;
  filter: none !important;
}

/* Filter state must win over late product-card display corrections. */
body:has(.shop-layout) .shop-card[hidden],
body:has(.shop-layout) .shop-card.is-hidden {
  display: none !important;
}

/* Compact mobile catalog typography for inverters, batteries, panels and catalog cards. */
@media (max-width: 760px) {
  body:has(.shop-layout) .shop-card,
  body:has(.shop-layout) .shop-card.product-card,
  body:has(.shop-layout) .catalog-featured-grid .shop-card,
  .catalog-featured-grid .shop-card {
    padding: 14px !important;
  }

  body:has(.shop-layout) .shop-card-top {
    min-height: 22px !important;
    gap: 8px !important;
  }

  body:has(.shop-layout) .shop-card-top small,
  body:has(.shop-layout) .brand-name,
  .catalog-featured-grid .shop-card small {
    font-size: 10px !important;
    line-height: 1.15 !important;
    letter-spacing: 0.035em !important;
  }

  body:has(.shop-layout) .product-specs,
  body:has(.shop-layout) .catalog-specs,
  .catalog-featured-grid .catalog-specs {
    max-width: 100% !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    font-size: 10.5px !important;
    line-height: 1.2 !important;
    text-align: left !important;
  }

  body:has(.shop-layout) .spec-badge + .spec-badge::before {
    margin: 0 5px !important;
  }

  body:has(.shop-layout) .product-card-image,
  body:has(.shop-layout) .catalog-featured-grid .product-card-image,
  .catalog-featured-grid .product-card-image {
    height: 128px !important;
    min-height: 118px !important;
    margin: 10px 0 11px !important;
  }

  body:has(.shop-layout) .product-card-image img,
  body:has(.shop-layout) .product-card-image.is-portrait img,
  body:has(.shop-layout) .product-card-image.is-battery img,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill,
  body:has(.shop-layout) .catalog-featured-grid .product-card-image img,
  .catalog-featured-grid .product-card-image img {
    max-width: 88% !important;
    max-height: 118px !important;
  }

  body:has(.shop-layout) .shop-card h3,
  body:has(.shop-layout) .shop-card.product-card h3,
  body:has(.shop-layout) .catalog-featured-grid .shop-card h3,
  .catalog-featured-grid .shop-card h3 {
    margin-bottom: 10px !important;
    font-size: clamp(15px, 4.15vw, 17px) !important;
    line-height: 1.13 !important;
    letter-spacing: 0 !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    hyphens: auto !important;
  }

  body:has(.shop-layout) .item-price,
  body:has(.shop-layout) .shop-card .item-price,
  .catalog-featured-grid .item-price {
    margin-top: 10px !important;
    padding-top: 10px !important;
    font-size: clamp(16px, 4.4vw, 18px) !important;
    line-height: 1.12 !important;
  }
}

@media (max-width: 380px) {
  body:has(.shop-layout) .shop-card h3,
  body:has(.shop-layout) .shop-card.product-card h3,
  body:has(.shop-layout) .catalog-featured-grid .shop-card h3,
  .catalog-featured-grid .shop-card h3 {
    font-size: 14.5px !important;
  }

  body:has(.shop-layout) .item-price,
  body:has(.shop-layout) .shop-card .item-price,
  .catalog-featured-grid .item-price {
    font-size: 15.5px !important;
  }
}

@media (max-width: 760px) {
  body:has(.product-layout) #description h3 {
    margin-top: 24px;
    font-size: clamp(21px, 6vw, 26px);
  }

  body:has(.product-layout) #description .product-description-list {
    gap: 9px;
  }

  body:has(.product-layout) #description .product-description-specs li {
    grid-template-columns: 1fr;
    gap: 4px;
    padding: 12px 0;
  }
}

/* Responsive stability layer: keeps technical content inside mobile/tablet viewports. */
html,
body {
  max-width: 100%;
  overflow-x: clip;
}

main,
section,
header,
footer,
.container,
.topbar .nav,
.hero,
.hero-inner,
.hero-grid,
.shop-layout,
.shop-results,
.shop-grid,
.shop-card,
.product-layout,
.product-info,
.product-summary,
.product-gallery,
.gallery,
.site-footer .footer-shell,
.site-footer .footer-grid,
.site-footer .footer-bottom,
.doc,
.service-card,
.answer-card,
.summary-card,
.contact-card,
.lead-panel,
.cart-dialog,
.lead-modal-dialog,
form,
fieldset {
  min-width: 0;
  max-width: 100%;
}

img,
svg,
video,
canvas {
  max-width: 100%;
}

h1,
h2,
h3,
h4,
p,
li,
a,
button,
label,
strong,
span,
.shop-card,
.product-info,
.spec-row,
.delivery-list,
.footer-local,
.footer-links,
.cart-line {
  overflow-wrap: anywhere;
}

button,
.btn,
.cta,
.cart-button,
[data-add-cart],
.item-details,
.filter-reset,
.cart-continue,
.cart-empty-action {
  max-width: 100%;
  min-width: 0;
  white-space: normal;
}

input,
select,
textarea {
  max-width: 100%;
  min-width: 0;
}

table {
  width: 100%;
  max-width: 100%;
}

@media (max-width: 1100px) {
  .topbar {
    min-height: 86px !important;
    border-bottom: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background-image: none !important;
  }

  .topbar .nav {
    width: min(100% - 28px, 1360px) !important;
    height: 86px !important;
    grid-template-columns: auto 1fr auto auto !important;
    gap: 10px !important;
  }

  .topbar .brand img {
    width: 116px !important;
    height: 48px !important;
  }

  .topbar .nav-actions {
    grid-column: 3 !important;
    justify-self: end !important;
    gap: 8px !important;
  }

  .topbar .nav-actions .btn,
  .topbar .nav-actions .cta {
    display: none !important;
  }

  .topbar .menu-toggle {
    display: grid !important;
    grid-column: 4 !important;
    width: 52px !important;
    height: 52px !important;
    border: 0 !important;
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    z-index: 320 !important;
  }

  .topbar .nav-links {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    max-width: none !important;
    min-height: 100dvh !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0 !important;
    padding: calc(122px + env(safe-area-inset-top)) 24px calc(24px + env(safe-area-inset-bottom)) !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(-10px) !important;
    overflow: auto !important;
    overscroll-behavior: contain !important;
    z-index: 145 !important;
  }

  body.menu-open .topbar .nav-links {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) !important;
  }

  .topbar .nav-links a,
  .topbar .nav-links .nav-trigger {
    min-height: 0 !important;
    padding: 7px 0 !important;
    color: #F5F7F8 !important;
    font-size: clamp(28px, 5.2vw, 42px) !important;
    line-height: 1.04 !important;
  }
}

@media (min-width: 761px) and (max-width: 900px) {
  .site-footer .footer-shell,
  .site-footer .footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 34px !important;
  }

  .site-footer .footer-brand,
  .site-footer .footer-logo {
    grid-column: 1 / -1;
  }

  .site-footer .footer-local {
    max-width: 620px !important;
  }
}

@media (max-width: 760px) {
  html,
  body {
    overflow-x: hidden;
  }

  .container,
  .topbar .nav,
  .site-footer .footer-shell,
  .site-footer .footer-grid,
  .site-footer .footer-bottom {
    width: min(100% - 28px, 1180px) !important;
  }

  h1 {
    font-size: clamp(30px, 9.2vw, 42px) !important;
    line-height: 1.02 !important;
  }

  h2 {
    font-size: clamp(25px, 7.4vw, 34px) !important;
    line-height: 1.08 !important;
  }

  h3 {
    line-height: 1.14 !important;
  }

  p,
  li {
    font-size: clamp(14px, 4vw, 17px);
  }

  .hero-actions,
  .product-actions,
  .card-actions,
  .cookie-actions {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .btn,
  .cta,
  .hero-actions .btn,
  .product-actions .btn,
  .product-actions .cart-button,
  .product-actions [data-add-cart],
  .card-actions .item-details,
  .card-actions .cart-button,
  .card-actions [data-add-cart] {
    width: 100% !important;
    min-height: 46px !important;
    padding-inline: 14px !important;
    text-align: center !important;
  }

  body:has(.product-layout) .product-layout,
  .product-layout {
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: minmax(0, 1fr) !important;
    overflow: visible !important;
  }

  body:has(.product-layout) .gallery,
  .gallery {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  body:has(.product-layout) .thumbs,
  .thumbs {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(58px, 1fr)) !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    padding-bottom: 0 !important;
  }

  body:has(.product-layout) .thumb,
  .thumb {
    width: 100% !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    height: clamp(58px, 18vw, 74px) !important;
    border-radius: 10px !important;
  }

  .spec-row,
  .delivery-payment-grid,
  .answer-grid,
  .doc-grid,
  .bundle-card,
  .service-card {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .section-card,
  .spec-panel,
  .delivery-payment-block,
  .bundle-highlight,
  .doc,
  .service-card,
  .answer-card,
  .summary-card,
  .contact-card {
    padding-inline: clamp(16px, 5vw, 22px) !important;
  }
}

@media (max-width: 360px) {
  .topbar .brand img {
    width: 100px !important;
  }

  .topbar .cart-nav,
  .topbar .menu-toggle {
    width: 48px !important;
    height: 48px !important;
  }

  .topbar .nav {
    width: min(100% - 24px, 1360px) !important;
    gap: 8px !important;
  }

  .cookie-banner h3,
  .lead-modal-dialog h2,
  .cart-dialog h2,
  .call-popover h3 {
    font-size: clamp(28px, 9vw, 36px) !important;
  }
}

/* Quiet footer arrival: smooth, native-scroll reveal without motion gimmicks. */
html.premium-motion .site-footer.footer-motion-ready {
  transform: translateZ(0);
  will-change: auto;
}

/* Cart popup intentionally uses a solid commerce surface, unlike lead modals. */
.cart-modal .cart-dialog {
  isolation: isolate !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(143, 174, 53, 0.10), transparent 31%),
    linear-gradient(145deg, #1A1D21 0%, #0B0D0F 76%) !important;
}

.cart-modal .cart-dialog::before,
.cart-modal .cart-dialog::after {
  display: none !important;
  content: none !important;
}

.cart-modal .cart-dialog h2 {
  font-size: clamp(38px, 5vw, 52px) !important;
}

@media (max-width: 640px) {
  .cart-modal .cart-dialog h2 {
    font-size: clamp(32px, 10vw, 42px) !important;
  }
}

html.premium-motion .site-footer.footer-motion-ready .footer-shell,
html.premium-motion .site-footer.footer-motion-ready .footer-grid,
html.premium-motion .site-footer.footer-motion-ready .footer-bottom {
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  transition:
    opacity 920ms cubic-bezier(0.19, 1, 0.22, 1),
    transform 920ms cubic-bezier(0.19, 1, 0.22, 1);
  will-change: opacity, transform;
}

html.premium-motion .site-footer.footer-motion-ready .footer-bottom {
  transition-delay: 120ms;
}

html.premium-motion .site-footer.footer-motion-ready.footer-in-view .footer-shell,
html.premium-motion .site-footer.footer-motion-ready.footer-in-view .footer-grid,
html.premium-motion .site-footer.footer-motion-ready.footer-in-view .footer-bottom {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: auto;
}

@media (max-width: 760px) {
  html.premium-motion .site-footer.footer-motion-ready .footer-shell,
  html.premium-motion .site-footer.footer-motion-ready .footer-grid,
  html.premium-motion .site-footer.footer-motion-ready .footer-bottom {
    transform: translate3d(0, 10px, 0);
    transition-duration: 620ms;
  }

  html.premium-motion .site-footer.footer-motion-ready .footer-bottom {
    transition-delay: 70ms;
  }
}

@media (prefers-reduced-motion: reduce) {
  html.premium-motion .site-footer.footer-motion-ready .footer-shell,
  html.premium-motion .site-footer.footer-motion-ready .footer-grid,
  html.premium-motion .site-footer.footer-motion-ready .footer-bottom,
  html.motion-reduced .site-footer .footer-shell,
  html.motion-reduced .site-footer .footer-grid,
  html.motion-reduced .site-footer .footer-bottom {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    will-change: auto !important;
  }
}

/* Mobile package scenarios: turn the raw discount list into a calmer premium module. */
@media (max-width: 760px) {
  #packages .section-head {
    gap: 14px !important;
    margin-bottom: 22px !important;
  }

  #packages .section-head h2 {
    max-width: 100% !important;
    font-size: clamp(30px, 8.1vw, 34px) !important;
    line-height: 1.04 !important;
  }

  #packages .section-head p {
    max-width: 31ch !important;
    font-size: 15.5px !important;
    line-height: 1.52 !important;
  }

  #packages .package-discounts,
  #packages .package-common {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin: 0 0 10px !important;
  }

  #packages .package-common {
    margin-bottom: 24px !important;
  }

  #packages .package-discount,
  #packages .common-item {
    position: relative !important;
    min-height: 0 !important;
    padding: 15px 16px 15px 54px !important;
    border: 1px solid rgba(43, 49, 55, 0.11) !important;
    border-radius: 8px !important;
    background: rgba(245, 247, 248, 0.74) !important;
    box-shadow: none !important;
    color: rgba(26, 29, 33, 0.66) !important;
    font-size: 14.5px !important;
    font-weight: 760 !important;
    line-height: 1.42 !important;
  }

  #packages .package-discount::before,
  #packages .common-item::before {
    position: absolute;
    top: 16px;
    left: 16px;
    width: 24px;
    height: 24px;
    display: inline-grid;
    place-items: center;
    border-radius: 50%;
    background: rgba(143, 174, 53, 0.13);
    color: #1A1D21;
    font-size: 11px;
    font-weight: 950;
    line-height: 1;
  }

  #packages .package-discount:nth-child(1)::before {
    content: "01";
  }

  #packages .package-discount:nth-child(2)::before {
    content: "02";
  }

  #packages .common-item:nth-child(1)::before {
    content: "03";
  }

  #packages .common-item:nth-child(2)::before {
    content: "04";
  }

  #packages .package-discount strong,
  #packages .common-item strong {
    display: block !important;
    margin: 0 0 3px !important;
    color: #0B0D0F !important;
    font-size: 16px !important;
    font-weight: 950 !important;
    line-height: 1.18 !important;
  }

  #packages .package-discount span {
    display: block !important;
    color: rgba(26, 29, 33, 0.64) !important;
    font-size: 14.5px !important;
    font-weight: 760 !important;
    line-height: 1.42 !important;
  }
}

/* FAQ accordions: keep answers available, but remove mobile text overload. */
.seo-faq .answer-grid.faq-accordion {
  display: block !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-left: 0 !important;
  background: transparent !important;
}

.seo-faq .faq-accordion .answer-card,
.seo-faq .faq-accordion .answer-card:first-child,
.seo-faq .faq-accordion .answer-card + .answer-card {
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-left: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.seo-faq .faq-accordion .answer-card h3 {
  margin: 0 !important;
}

.seo-faq .answer-toggle {
  width: 100%;
  min-height: 72px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 28px;
  align-items: center;
  gap: 18px;
  padding: 22px 0;
  border: 0;
  background: transparent;
  color: #0B0D0F;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.seo-faq .answer-toggle span:first-child {
  font-size: clamp(18px, 1.9vw, 26px);
  font-weight: 950;
  line-height: 1.12;
  overflow-wrap: anywhere;
}

.seo-faq .answer-toggle-icon {
  position: relative;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(43, 49, 55, 0.16);
  border-radius: 50%;
  background: rgba(245, 247, 248, 0.72);
}

.seo-faq .answer-toggle-icon::before,
.seo-faq .answer-toggle-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  border-radius: 99px;
  background: #1A1D21;
  transform: translate(-50%, -50%);
  transition: transform 180ms cubic-bezier(0.22, 0.61, 0.36, 1), opacity 180ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.seo-faq .answer-toggle-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.seo-faq .answer-card.is-open .answer-toggle-icon::after {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(0deg);
}

.seo-faq .answer-panel {
  max-height: 0;
  margin: 0 !important;
  max-width: 68ch !important;
  overflow: hidden;
  opacity: 0;
  color: var(--elx-muted) !important;
  transition:
    max-height 320ms cubic-bezier(0.22, 0.61, 0.36, 1),
    opacity 240ms cubic-bezier(0.22, 0.61, 0.36, 1),
    padding 320ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.seo-faq .answer-card.is-open .answer-panel {
  max-height: 260px;
  padding: 0 56px 24px 0;
  opacity: 1;
}

@media (max-width: 760px) {
  .seo-faq .answer-grid.faq-accordion {
    gap: 0 !important;
  }

  .seo-faq .answer-toggle {
    min-height: 66px;
    gap: 14px;
    padding: 18px 0;
  }

  .seo-faq .answer-toggle span:first-child {
    font-size: clamp(18px, 5.4vw, 22px);
    line-height: 1.12;
  }

  .seo-faq .answer-toggle-icon {
    width: 26px;
    height: 26px;
  }

  .seo-faq .answer-card.is-open .answer-panel {
    max-height: 360px;
    padding: 0 40px 20px 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .seo-faq .answer-panel,
  .seo-faq .answer-toggle-icon::before,
  .seo-faq .answer-toggle-icon::after {
    transition: none !important;
  }
}

/* Catalog price alignment: prices sit on a stable baseline per grid row without inflating every card. */
body:has(.shop-layout) .shop-grid,
.catalog-featured-grid {
  align-items: stretch !important;
}

body:has(.shop-layout) .shop-card:not([hidden]):not(.is-hidden),
body:has(.shop-layout) .shop-card.product-card:not([hidden]):not(.is-hidden),
.catalog-featured-grid .shop-card {
  height: 100% !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  align-content: stretch !important;
}

body:has(.shop-layout) .shop-card:not([hidden]):not(.is-hidden) > div:first-child,
body:has(.shop-layout) .shop-card.product-card:not([hidden]):not(.is-hidden) > div:first-child,
.catalog-featured-grid .shop-card > div:first-child {
  min-height: 0 !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

body:has(.shop-layout) .shop-card .item-price,
body:has(.shop-layout) .item-price,
.catalog-featured-grid .item-price {
  align-self: end !important;
  margin-top: clamp(10px, 1.5vw, 14px) !important;
}

@media (max-width: 760px) {
  body:has(.shop-layout) .shop-card:not([hidden]):not(.is-hidden),
  body:has(.shop-layout) .shop-card.product-card:not([hidden]):not(.is-hidden),
  .catalog-featured-grid .shop-card {
    grid-template-rows: minmax(0, 1fr) auto !important;
  }

  body:has(.shop-layout) .shop-card h3,
  body:has(.shop-layout) .shop-card.product-card h3,
  body:has(.shop-layout) .catalog-featured-grid .shop-card h3,
  .catalog-featured-grid .shop-card h3 {
    margin-bottom: 0 !important;
  }
}

/* Cart page: quiet continuous layout, no nested card framing. */
body:has(.cart-layout) main {
  background: var(--elx-white) !important;
}

body:has(.cart-layout) .cart-hero {
  min-height: 0 !important;
  margin-bottom: clamp(34px, 6vw, 76px) !important;
  padding-bottom: clamp(28px, 4vw, 48px) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .cart-hero p {
  max-width: 58ch !important;
  color: rgba(11, 13, 15, 0.58) !important;
  font-size: clamp(16px, 1.45vw, 20px) !important;
  font-weight: 760 !important;
  line-height: 1.56 !important;
}

body:has(.cart-layout) .cart-panel,
body:has(.cart-layout) .summary-panel {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.cart-layout) .cart-empty {
  max-width: 760px !important;
  margin: 0 auto !important;
  padding: clamp(30px, 6vw, 56px) 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
  text-align: center !important;
}

body:has(.cart-layout) .cart-empty h2 {
  margin-bottom: 12px !important;
  font-size: clamp(30px, 4.5vw, 48px) !important;
  line-height: 1.04 !important;
}

body:has(.cart-layout) .cart-empty p {
  max-width: 46ch !important;
  margin-bottom: 24px !important;
  color: var(--elx-muted) !important;
  font-size: clamp(15px, 1.3vw, 17px) !important;
  line-height: 1.58 !important;
}

body:has(.cart-layout) .cart-table {
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .cart-head,
body:has(.cart-layout) .cart-row {
  padding-inline: 0 !important;
}

body:has(.cart-layout) .cart-actions {
  padding: 20px 0 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .cart-lower {
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr) !important;
  gap: clamp(34px, 5vw, 70px) !important;
  margin-top: clamp(48px, 7vw, 86px) !important;
}

body.cart-is-empty:has(.cart-layout) .cart-lower {
  grid-template-columns: 1fr !important;
}

body:has(.cart-layout) .interest,
body:has(.cart-layout) .cart-hits {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.cart-layout) .cart-hits-head {
  display: block !important;
  margin-bottom: 20px !important;
}

body:has(.cart-layout) .cart-hits-head .eyebrow {
  margin-bottom: 12px !important;
}

body:has(.cart-layout) .cart-hits h2 {
  margin: 0 !important;
  font-size: clamp(34px, 4.2vw, 58px) !important;
  line-height: 1.02 !important;
  letter-spacing: 0 !important;
}

body:has(.cart-layout) .cart-hit-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .cart-hit-card {
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 132px minmax(0, 1fr) !important;
  gap: clamp(18px, 2.4vw, 28px) !important;
  align-items: center !important;
  padding: clamp(18px, 2.1vw, 26px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body:has(.cart-layout) .cart-hit-card + .cart-hit-card {
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .cart-hit-media {
  min-height: 0 !important;
  display: grid !important;
  place-items: center !important;
}

body:has(.cart-layout) .cart-hit-media img {
  width: auto !important;
  max-width: 86% !important;
  max-height: 132px !important;
  object-fit: contain !important;
}

body:has(.cart-layout) .cart-hit-copy {
  min-width: 0 !important;
  display: grid !important;
  grid-template-rows: auto auto minmax(0, 1fr) auto !important;
  gap: 9px !important;
}

body:has(.cart-layout) .cart-hit-copy strong {
  color: var(--elx-green) !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.035em !important;
}

body:has(.cart-layout) .cart-hit-copy h3 {
  margin: 0 !important;
  color: var(--elx-black) !important;
  font-size: clamp(19px, 1.8vw, 25px) !important;
  line-height: 1.08 !important;
  overflow-wrap: anywhere !important;
}

body:has(.cart-layout) .cart-hit-copy p {
  margin: 0 !important;
  color: var(--elx-muted) !important;
  font-size: 14px !important;
  font-weight: 720 !important;
  line-height: 1.46 !important;
}

body:has(.cart-layout) .cart-hit-bottom {
  display: flex !important;
  justify-content: space-between !important;
  gap: 12px !important;
  align-items: center !important;
  margin-top: 8px !important;
}

body:has(.cart-layout) .cart-hit-bottom .btn {
  width: auto !important;
  min-width: 128px !important;
  min-height: 44px !important;
  padding: 11px 14px !important;
  box-shadow: none !important;
}

body:has(.cart-layout) .summary-panel {
  position: sticky !important;
  top: 104px !important;
  padding-top: 0 !important;
}

body:has(.cart-layout) .summary-panel h2 {
  margin: 0 0 18px !important;
  font-size: clamp(30px, 3.4vw, 46px) !important;
  line-height: 1.04 !important;
}

body:has(.cart-layout) .summary-lines {
  border: 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-radius: 0 !important;
  background: transparent !important;
}

body:has(.cart-layout) .summary-line {
  padding: 16px 0 !important;
  border-bottom-color: rgba(43, 49, 55, 0.12) !important;
}

body:has(.cart-layout) .checkout-form {
  margin-top: 22px !important;
}

body:has(.cart-layout) .checkout-form button[type="submit"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
}

body:has(.cart-layout) .checkout-form button[type="submit"]::before {
  content: "" !important;
  width: 20px !important;
  height: 20px !important;
  display: inline-block !important;
  background: currentColor !important;
  -webkit-mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 8h14l-1.4 7.2a2 2 0 0 1-2 1.6H9.2a2 2 0 0 1-2-1.7L5.6 4.8H3' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Ccircle cx='9.5' cy='20' r='1.2' fill='black'/%3E%3Ccircle cx='17.5' cy='20' r='1.2' fill='black'/%3E%3C/svg%3E") center / contain no-repeat !important;
  mask: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 8h14l-1.4 7.2a2 2 0 0 1-2 1.6H9.2a2 2 0 0 1-2-1.7L5.6 4.8H3' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Ccircle cx='9.5' cy='20' r='1.2' fill='black'/%3E%3Ccircle cx='17.5' cy='20' r='1.2' fill='black'/%3E%3C/svg%3E") center / contain no-repeat !important;
}

body:has(.cart-layout) .checkout-form input,
body:has(.cart-layout) .checkout-form select,
body:has(.cart-layout) .checkout-form textarea {
  border-color: rgba(43, 49, 55, 0.14) !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.72) !important;
  box-shadow: none !important;
}

@media (max-width: 1080px) {
  body:has(.cart-layout) .cart-lower,
  body:has(.cart-layout) .cart-hit-grid {
    grid-template-columns: 1fr !important;
  }

  body:has(.cart-layout) .summary-panel {
    position: static !important;
  }

  body:has(.cart-layout) .cart-hit-card {
    grid-template-columns: 120px minmax(0, 1fr) !important;
  }

  body:has(.cart-layout) .cart-hit-card + .cart-hit-card {
    border-top: 1px solid rgba(43, 49, 55, 0.12) !important;
  }

  body:has(.cart-layout) .cart-hit-media img {
    max-height: 118px !important;
  }
}

@media (max-width: 760px) {
  body:has(.cart-layout) main {
    padding-top: 28px !important;
    padding-bottom: 72px !important;
  }

  body:has(.cart-layout) .cart-hero {
    display: block !important;
    margin-bottom: 20px !important;
    padding-bottom: 18px !important;
  }

  body:has(.cart-layout) .cart-hero p {
    margin-top: 16px !important;
    font-size: 16px !important;
    line-height: 1.45 !important;
  }

  body:has(.cart-layout) .cart-layout {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  body:has(.cart-layout) .cart-panel {
    margin-top: 0 !important;
  }

  body:has(.cart-layout) .cart-lower {
    margin-top: 10px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  body:has(.cart-layout) .summary-panel {
    margin-top: 0 !important;
  }

  body:has(.cart-layout) .summary-panel h2 {
    display: none !important;
  }

  body:has(.cart-layout) .qty-input {
    grid-column: 1 !important;
    justify-self: start !important;
    align-self: end !important;
    margin-top: 4px !important;
    width: 56px !important;
    min-height: 34px !important;
    padding: 0 6px !important;
    border-radius: 10px !important;
    font-size: 16px !important;
    line-height: 1 !important;
  }

  body:has(.cart-layout) .cart-row {
    position: relative !important;
    grid-template-columns: 64px minmax(0, 1fr) !important;
    align-items: end !important;
  }

  body:has(.cart-layout) .remove-item {
    position: absolute !important;
    top: 16px !important;
    right: 0 !important;
    width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    font-size: 18px !important;
    z-index: 2 !important;
  }

  body:has(.cart-layout) .product-cell {
    grid-column: 1 / -1 !important;
    padding-right: 34px !important;
  }

  body:has(.cart-layout) .cart-row .line-total {
    grid-column: 2 !important;
    justify-self: end !important;
    align-self: end !important;
    font-size: 20px !important;
    line-height: 1 !important;
  }

  body:has(.cart-layout) .cart-empty {
    padding: 30px 0 !important;
  }

  body:has(.cart-layout) .cart-empty .btn {
    width: 100% !important;
  }

  body:has(.cart-layout) .cart-hits {
    display: none !important;
  }

  body:has(.cart-layout) .cart-hit-card {
    grid-template-columns: 92px minmax(0, 1fr) !important;
    gap: 14px !important;
    padding: 18px 0 !important;
  }

  body:has(.cart-layout) .cart-hit-media img {
    max-width: 82px !important;
    max-height: 105px !important;
  }

  body:has(.cart-layout) .cart-hit-copy h3 {
    font-size: clamp(18px, 5.4vw, 22px) !important;
  }

  body:has(.cart-layout) .cart-hit-copy p {
    font-size: 13.5px !important;
  }

  body:has(.cart-layout) .cart-hit-bottom {
    display: grid !important;
    gap: 10px !important;
  }

  body:has(.cart-layout) .cart-hit-bottom .btn {
    width: 100% !important;
    min-width: 0 !important;
  }
}

/* Targeted mobile type proportion fixes for contacts and warranty pages. */
@media (max-width: 760px) {
  body:has(#leadForm) main {
    padding-top: 48px !important;
  }

  body:has(#leadForm) .page-head {
    margin-bottom: 34px !important;
  }

  body:has(#leadForm) .page-head .kicker {
    display: block !important;
    margin-bottom: 14px !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
  }

  body:has(#leadForm) .page-head h1 {
    max-width: 8.8em !important;
    margin: 0 0 24px !important;
    font-size: clamp(42px, 13vw, 54px) !important;
    line-height: 1.02 !important;
  }

  body:has(#leadForm) .page-head .lead {
    max-width: 35ch !important;
    font-size: clamp(16.5px, 4.7vw, 18.5px) !important;
    line-height: 1.46 !important;
    font-weight: 640 !important;
  }

  body:has(#leadForm) .contact-card {
    padding: 24px 0 !important;
  }

  body:has(#leadForm) .contact-card h2 {
    margin-bottom: 16px !important;
    font-size: clamp(30px, 8.8vw, 38px) !important;
    line-height: 1.06 !important;
  }

  body:has(#leadForm) .contact-list {
    gap: 18px !important;
  }

  body:has(#leadForm) .contact-list small {
    margin-bottom: 5px !important;
    font-size: 11.5px !important;
    line-height: 1.15 !important;
    letter-spacing: 0.08em !important;
  }

  body:has(#leadForm) .contact-list a,
  body:has(#leadForm) .contact-list span {
    color: rgba(11, 13, 15, 0.58) !important;
    font-size: clamp(17px, 5.2vw, 21px) !important;
    font-weight: 780 !important;
    line-height: 1.42 !important;
  }

  body:has(#leadForm) #servicePointTitle {
    max-width: 9.8em !important;
    font-size: clamp(32px, 9.4vw, 42px) !important;
  }

  body:has(#leadForm) #servicePointTitle + .lead {
    max-width: 36ch !important;
    font-size: clamp(16.5px, 4.6vw, 18px) !important;
    line-height: 1.48 !important;
    font-weight: 620 !important;
  }

  body:has(.summary-grid) .legal > div {
    margin-bottom: 30px !important;
  }

  body:has(.summary-grid) .legal .lead {
    max-width: 38ch !important;
    font-size: clamp(16.5px, 4.7vw, 18.5px) !important;
    line-height: 1.46 !important;
    font-weight: 620 !important;
  }

  body:has(.summary-grid) .summary-grid {
    margin-bottom: 30px !important;
  }

  body:has(.summary-grid) .summary-card {
    min-height: 0 !important;
    grid-template-columns: 74px minmax(0, 1fr) !important;
    align-items: center !important;
    align-content: center !important;
    gap: 14px !important;
    padding: 22px 0 !important;
  }

  body:has(.summary-grid) .summary-card strong {
    font-size: clamp(42px, 13vw, 54px) !important;
    line-height: 1 !important;
  }

  body:has(.summary-grid) .summary-card span {
    color: rgba(11, 13, 15, 0.68) !important;
    font-size: clamp(17px, 5vw, 20px) !important;
    font-weight: 800 !important;
    line-height: 1.34 !important;
  }

  body:has(.summary-grid) .doc h2 {
    max-width: 11em !important;
    margin-top: 32px !important;
    font-size: clamp(28px, 8vw, 36px) !important;
    line-height: 1.08 !important;
  }

  body:has(.summary-grid) .doc p,
  body:has(.summary-grid) .doc li {
    font-size: clamp(15.5px, 4.5vw, 18px) !important;
    line-height: 1.58 !important;
    font-weight: 620 !important;
  }

  body:has(.summary-grid) .buyer-card span {
    font-size: 15.5px !important;
    line-height: 1.48 !important;
  }

  body:has(.summary-grid) .service-card h2 {
    max-width: 10em !important;
    font-size: clamp(31px, 8.8vw, 40px) !important;
    line-height: 1.06 !important;
  }
}

/* Final optical cleanup: remove any viewport-anchored halo around the header/hero edge. */
html,
body,
main,
.topbar,
.site-header,
.hero,
.hero .container {
  background-color: #F5F7F8 !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
}

html::before,
html::after,
body::before,
body::after,
main::before,
main::after,
.topbar::before,
.topbar::after,
.site-header::before,
.site-header::after,
.hero::before,
.hero::after,
.hero .container::before,
.hero .container::after {
  content: none !important;
  display: none !important;
  background: none !important;
  background-image: none !important;
  box-shadow: none !important;
  filter: none !important;
  backdrop-filter: none !important;
}

.topbar *,
.site-header *,
.hero .eyebrow,
.hero h1,
.hero p {
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
}

/* Homepage conversion layer: concrete proof, purchasable scenarios and calm pricing. */
.hero-trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 650px;
  margin: 14px 0 0;
}

.hero-trust-strip span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 11px;
  border: 1px solid rgba(26, 29, 33, 0.1);
  border-radius: 999px;
  background: rgba(245, 247, 248, 0.62);
  color: rgba(26, 29, 33, 0.72);
  font-size: 12.5px;
  font-weight: 850;
  line-height: 1.2;
}

.package-commercial-note {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 clamp(20px, 2.6vw, 32px);
  padding: 0;
  border: 0;
  text-align: center;
}

.package-commercial-note strong {
  color: #8FAE35;
  font-size: 1.28em;
  font-weight: 900;
  line-height: 1;
}

.package-commercial-note span {
  max-width: 720px;
  color: rgba(26, 29, 33, 0.82);
  font-size: clamp(15px, 1.18vw, 18px);
  font-weight: 720;
  line-height: 1.38;
}

#packages .package-common {
  opacity: 0.78;
}

#packages .common-item {
  border-color: rgba(118, 130, 140, 0.18) !important;
  background: transparent !important;
  color: rgba(118, 130, 140, 0.78) !important;
  font-weight: 440 !important;
}

#packages .common-item::before {
  display: none !important;
  content: none !important;
}

#packages .common-item strong {
  color: rgba(86, 96, 105, 0.86) !important;
  font-weight: 650 !important;
}

#packages {
  scroll-margin-top: 110px;
}

#packages .section-head {
  display: block !important;
  max-width: 980px !important;
  margin-inline: 0 auto !important;
}

#packages .section-head h2 {
  max-width: 920px !important;
}

#packages .section-head p {
  max-width: 860px !important;
  margin-top: 22px !important;
}

#packages .package.has-media > div:first-child {
  grid-template-rows: auto auto minmax(112px, auto) auto minmax(220px, 1fr) auto auto !important;
  row-gap: 0 !important;
}

#packages .package p {
  margin-bottom: 18px !important;
}

.package-price {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: end;
  gap: 4px 14px;
  margin: 0 0 18px;
  padding: 10px 0;
  border-top: 1px solid rgba(26, 29, 33, 0.1);
  border-bottom: 1px solid rgba(26, 29, 33, 0.1);
}

.package-price span,
.package-price small {
  color: var(--elx-muted, rgba(43, 49, 55, 0.66));
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.package-price s {
  justify-self: end;
  color: rgba(43, 49, 55, 0.44);
  font-size: clamp(16px, 1.4vw, 19px);
  font-weight: 850;
}

.package-price strong {
  grid-column: 1 / -1;
  color: #1A1D21;
  font-size: clamp(32px, 2.8vw, 44px);
  font-weight: 950;
  line-height: 0.96;
}

.package-price small {
  grid-column: 1 / -1;
  text-transform: none;
  letter-spacing: 0;
}

#packages .package-specs {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin: 16px 0 0 !important;
}

#packages .package-spec {
  min-height: 38px !important;
  padding: 8px !important;
  border-radius: 999px !important;
  background: rgba(245, 247, 248, 0.54) !important;
  font-size: 11px !important;
  line-height: 1.15 !important;
}

#packages .hv-package .package-media.product-media img {
  width: min(86%, 320px) !important;
  max-height: 220px !important;
}

#packages .package-media.product-media {
  height: 250px !important;
  min-height: 0 !important;
}

#packages .package-actions {
  min-height: 86px !important;
}

@media (min-width: 981px) {
  .home-page .hero-copy .hero-actions {
    max-width: 650px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft {
    min-height: 64px !important;
    padding-inline: 24px !important;
    font-size: 18px !important;
    white-space: nowrap !important;
  }

  .home-page .hero-actions .btn-primary {
    flex: 1 1 360px !important;
  }

  .home-page .hero-actions .hero-secondary-link {
    flex: 0 1 240px !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: 24px 112px 150px 124px 250px 92px 120px !important;
  }

  #packages .package h3 {
    min-height: 0 !important;
  }

  #packages .package p {
    min-height: 0 !important;
    margin-bottom: 0 !important;
  }

  #packages .package-price {
    align-self: start !important;
    margin-bottom: 0 !important;
  }
}

@media (min-width: 981px) and (max-width: 1999px) {
  .home-page .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: 390px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft,
  .home-page .hero-actions .hero-secondary-link {
    width: 100% !important;
    max-width: 390px !important;
    justify-content: center !important;
  }
}

@media (max-width: 980px) {
  .package-commercial-note {
    grid-template-columns: 1fr;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto auto auto auto !important;
  }
}

@media (max-width: 760px) {
  .hero-trust-strip {
    gap: 8px;
    margin-top: 16px;
  }

  .hero-trust-strip span {
    min-height: 32px;
    padding: 7px 10px;
    font-size: 12px;
  }

  .package-price {
    margin-bottom: 14px;
  }

  #packages .package-specs {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* Homepage conversion polish: keep CTAs calm, remove redundant package pills, and make reviews static. */
.home-page .hero-copy .hero-actions {
  gap: 12px !important;
  max-width: 420px !important;
}

.home-page .hero-actions .btn,
.home-page .hero-actions .btn-primary,
.home-page .hero-actions .btn-soft,
.home-page .hero-actions .hero-secondary-link {
  min-height: 54px !important;
  padding: 0 20px !important;
  border-radius: 7px !important;
  font-size: 16px !important;
  line-height: 1.15 !important;
  white-space: normal !important;
}

.home-page .hero-actions .hero-secondary-link {
  min-width: 0 !important;
}

#packages .package-specs {
  display: none !important;
}

#packages .package.has-media > div:first-child {
  grid-template-rows: 24px 112px 150px 124px 250px 116px !important;
}

#packages .package-actions {
  min-height: 0 !important;
  margin-top: 18px !important;
}

#packages .package-action.primary {
  min-height: 54px !important;
  border-radius: 7px !important;
}

.deep-band .metric strong,
.home-page .metric strong {
  font-size: clamp(25px, 1.75vw, 32px) !important;
  line-height: 1.06 !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: manual !important;
}

.review-card,
.review-card:hover {
  cursor: default !important;
  pointer-events: none !important;
  transform: none !important;
  border-color: rgba(43, 49, 55, 0.12) !important;
  box-shadow: var(--shadow-soft) !important;
  transition: none !important;
}

@media (min-width: 981px) and (max-width: 1599px) {
  .home-page .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: 360px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft,
  .home-page .hero-actions .hero-secondary-link {
    width: 100% !important;
    max-width: 360px !important;
  }
}

@media (min-width: 1600px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: minmax(720px, 0.78fr) minmax(820px, 1.22fr) !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding-inline: clamp(54px, 4vw, 72px) !important;
  }

  .home-page .hero h1 {
    max-width: 620px !important;
    font-size: clamp(58px, 3.4vw, 66px) !important;
    line-height: 1.03 !important;
  }

  .home-page .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: 360px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft,
  .home-page .hero-actions .hero-secondary-link {
    width: 100% !important;
    max-width: 360px !important;
    padding-inline: 18px !important;
    font-size: 16px !important;
    white-space: normal !important;
  }
}

@media (max-width: 980px) {
  .home-page .hero-copy .hero-actions {
    max-width: 420px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft,
  .home-page .hero-actions .hero-secondary-link {
    width: 100% !important;
    max-width: 420px !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto auto auto !important;
  }
}

/* Final homepage rhythm pass: reduce dead space and keep content from falling under the next section. */
.home-page .hero {
  min-height: auto !important;
  align-items: start !important;
  padding: clamp(18px, 2.6vw, 38px) 0 clamp(34px, 4vw, 58px) !important;
}

.home-page .hero-inner,
body.home-page:has(.hero-inner) .hero-inner {
  height: auto !important;
  min-height: clamp(620px, 45vw, 720px) !important;
}

.home-page .hero-copy,
body.home-page:has(.hero-inner) .hero-copy {
  justify-content: center !important;
  padding-top: clamp(38px, 4vw, 58px) !important;
  padding-bottom: clamp(34px, 3.5vw, 52px) !important;
}

.home-page .hero h1 {
  text-wrap: balance !important;
}

.home-page .hero-media,
body.home-page:has(.hero-inner) .hero-media {
  max-height: 720px !important;
}

#packages .package.has-media > div:first-child {
  display: grid !important;
  grid-template-rows: auto minmax(82px, auto) minmax(116px, auto) auto minmax(220px, 1fr) auto !important;
  row-gap: 14px !important;
  height: 100% !important;
}

#packages .package {
  opacity: 1 !important;
  transform: none !important;
}

#packages .package h3 {
  min-height: 0 !important;
  margin-bottom: 0 !important;
}

#packages .package p {
  min-height: 0 !important;
  margin-bottom: 0 !important;
}

#packages .package-price {
  margin: 0 !important;
}

#packages .package-media.product-media {
  height: 220px !important;
  align-self: center !important;
}

#packages .package-actions {
  margin-top: 0 !important;
}

.reviews-grid {
  align-items: stretch !important;
}

.review-card {
  grid-template-rows: auto auto auto !important;
  min-height: 0 !important;
  padding: clamp(22px, 2vw, 30px) !important;
}

.review-card blockquote {
  margin: 18px 0 22px !important;
  line-height: 1.5 !important;
}

.review-person {
  align-self: end !important;
}

@media (min-width: 981px) and (max-width: 1599px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: minmax(620px, 0.58fr) minmax(420px, 0.42fr) !important;
    min-height: clamp(660px, 55vw, 760px) !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding-left: clamp(54px, 7vw, 96px) !important;
    padding-right: clamp(42px, 5vw, 72px) !important;
  }

  .home-page .hero h1 {
    max-width: 780px !important;
    font-size: clamp(56px, 5.55vw, 74px) !important;
    line-height: 1.02 !important;
  }

  .home-page .hero-text {
    max-width: 560px !important;
    margin-bottom: 28px !important;
  }

  .home-page .hero-copy .hero-actions {
    max-width: 420px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn-soft,
  .home-page .hero-actions .hero-secondary-link {
    max-width: 420px !important;
  }
}

@media (min-width: 1600px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: minmax(760px, 0.52fr) minmax(720px, 0.48fr) !important;
    min-height: clamp(680px, 42vw, 780px) !important;
  }

  .home-page .hero h1 {
    max-width: 760px !important;
    font-size: clamp(66px, 4vw, 78px) !important;
  }

  .home-page .hero-text {
    max-width: 600px !important;
  }
}

@media (max-width: 980px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    min-height: 0 !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto auto auto !important;
    row-gap: 14px !important;
  }

  #packages .package-media.product-media {
    height: clamp(210px, 58vw, 280px) !important;
  }
}

/* Homepage v2 hero and package correction: calm 50/50 split, no diagonal mask, no image/button overlap. */
.home-page .hero {
  padding: clamp(24px, 3vw, 46px) 0 clamp(34px, 4vw, 56px) !important;
}

.home-page .hero-inner,
body.home-page:has(.hero-inner) .hero-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 0 !important;
  min-height: clamp(560px, 40vw, 680px) !important;
  height: auto !important;
  border: 1px solid rgba(43, 49, 55, 0.1) !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  background: #F5F7F8 !important;
}

.home-page .hero-copy,
body.home-page:has(.hero-inner) .hero-copy {
  justify-content: center !important;
  padding: clamp(48px, 5vw, 78px) clamp(42px, 5vw, 76px) !important;
}

.home-page .hero h1 {
  max-width: 720px !important;
  margin-bottom: 20px !important;
  font-size: clamp(54px, 4.6vw, 82px) !important;
  line-height: 0.98 !important;
  text-wrap: balance !important;
}

.home-page .hero-text {
  max-width: 610px !important;
  margin-bottom: 28px !important;
  font-size: clamp(17px, 1.25vw, 21px) !important;
  line-height: 1.48 !important;
}

.home-page .hero-copy .hero-actions {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 148px !important;
  gap: 12px !important;
  width: min(100%, 500px) !important;
  max-width: 500px !important;
}

.home-page .hero-actions .btn,
.home-page .hero-actions .btn-primary,
.home-page .hero-actions .btn-soft,
.home-page .hero-actions .hero-secondary-link {
  width: 100% !important;
  max-width: none !important;
  min-height: 54px !important;
  padding: 0 18px !important;
  border-radius: 7px !important;
  font-size: 16px !important;
}

.home-page .cta-reassurance {
  display: none !important;
}

.home-page .hero-trust-strip {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  width: min(100%, 620px) !important;
  max-width: 620px !important;
  margin-top: 22px !important;
}

.home-page .hero-trust-strip span {
  position: relative !important;
  min-height: 0 !important;
  padding: 0 0 0 18px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  text-align: left !important;
  box-shadow: none !important;
}

.home-page .hero-trust-strip span::before {
  content: "/" !important;
  position: absolute !important;
  left: 0 !important;
  top: -1px !important;
  color: #8FAE35 !important;
  font-weight: 950 !important;
}

.home-page .hero-cats {
  margin-top: 24px !important;
}

.home-page .hero-media,
body.home-page:has(.hero-inner) .hero-media {
  min-height: 100% !important;
  height: auto !important;
  max-height: none !important;
  border-radius: 0 !important;
  clip-path: none !important;
  transform: none !important;
}

.home-page .hero-media::before,
.home-page .hero-media::after {
  display: none !important;
}

.home-page .hero-media picture,
.home-page .hero-media img,
body.home-page:has(.hero-inner) .hero-media picture,
body.home-page:has(.hero-inner) .hero-media img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}

.home-page .media-caption {
  display: none !important;
}

#solutions .section-head p,
#solutions .system-number,
#solutions .system-cta,
#solutions .system p {
  display: none !important;
}

#solutions .section-head {
  margin-bottom: 24px !important;
}

#solutions .system {
  min-height: 0 !important;
}

#solutions .system h3 {
  margin-bottom: 0 !important;
}

#packages .package.has-media > div:first-child {
  grid-template-rows: auto minmax(82px, auto) minmax(110px, auto) auto minmax(260px, 1fr) auto !important;
}

#packages .package-media.product-media {
  height: 260px !important;
  margin-bottom: 0 !important;
}

#packages .package-media.product-media img {
  max-height: 250px !important;
}

#packages .hv-package .package-media.product-media img,
#packages .hv-package .package-media.hv-media img {
  width: min(94%, 380px) !important;
  max-height: 250px !important;
}

#packages .package-actions {
  position: relative !important;
  z-index: 2 !important;
  margin-top: 12px !important;
}

@media (min-width: 981px) and (max-width: 1280px) {
  .home-page .hero h1 {
    font-size: clamp(50px, 4.9vw, 64px) !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding-inline: clamp(34px, 4vw, 54px) !important;
  }
}

@media (max-width: 980px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: 1fr !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding: 30px 24px 22px !important;
  }

  .home-page .hero h1 {
    max-width: 9.6em !important;
    font-size: clamp(34px, 9vw, 48px) !important;
    line-height: 1.02 !important;
  }

  .home-page .hero-text {
    max-width: 34ch !important;
    font-size: clamp(15px, 4.1vw, 17px) !important;
  }

  .home-page .hero-copy .hero-actions {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: 360px !important;
  }

  .home-page .hero-trust-strip {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .home-page .hero-cats {
    display: none !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    min-height: 280px !important;
    aspect-ratio: 1.28 / 1 !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto auto auto !important;
  }

  #packages .package-media.product-media {
    height: clamp(240px, 64vw, 320px) !important;
  }
}

/* Final hero calibration: restrained split layout for trust and conversion. */
.home-page .hero {
  padding: clamp(28px, 4vw, 56px) 0 clamp(42px, 5vw, 72px) !important;
  background: #F5F7F8 !important;
}

.home-page .hero-inner.container,
body.home-page:has(.hero-inner) .hero-inner.container {
  width: min(1240px, calc(100% - clamp(32px, 5vw, 72px))) !important;
  max-width: 1240px !important;
}

.home-page .hero-inner,
body.home-page:has(.hero-inner) .hero-inner {
  display: grid !important;
  grid-template-columns: minmax(480px, 1fr) minmax(520px, 1fr) !important;
  gap: clamp(34px, 4vw, 52px) !important;
  min-height: clamp(520px, 56vh, 640px) !important;
  height: auto !important;
  align-items: center !important;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.home-page .hero-copy,
body.home-page:has(.hero-inner) .hero-copy {
  max-width: 590px !important;
  padding: clamp(30px, 4vw, 54px) 0 !important;
  justify-content: center !important;
  background: transparent !important;
}

.home-page .hero h1 {
  max-width: 590px !important;
  margin: 0 0 18px !important;
  font-size: clamp(40px, 3.55vw, 54px) !important;
  line-height: 1.06 !important;
  letter-spacing: 0 !important;
  text-wrap: balance !important;
}

.home-page .hero-text {
  max-width: 520px !important;
  margin-bottom: 26px !important;
  color: rgba(26, 29, 33, 0.68) !important;
  font-size: clamp(17px, 1.25vw, 20px) !important;
  line-height: 1.55 !important;
}

.home-page .hero-copy .hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  width: auto !important;
  max-width: none !important;
}

.home-page .hero-actions .btn,
.home-page .hero-actions .btn-primary,
.home-page .hero-actions .btn-soft,
.home-page .hero-actions .hero-secondary-link {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  min-height: 52px !important;
  padding: 0 22px !important;
  border-radius: 8px !important;
  font-size: 15px !important;
  white-space: nowrap !important;
}

.home-page .hero-actions .btn-primary {
  min-width: 312px !important;
}

.home-page .hero-actions .hero-secondary-link {
  min-width: 132px !important;
}

.home-page .hero-actions .hero-secondary-link::after {
  display: none !important;
  content: none !important;
}

.home-page .hero-trust-strip {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  width: min(100%, 520px) !important;
  max-width: 520px !important;
  margin-top: 22px !important;
}

.home-page .hero-trust-strip span {
  position: relative !important;
  min-height: 0 !important;
  padding: 0 0 0 22px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: 13px !important;
  font-weight: 750 !important;
  line-height: 1.35 !important;
  text-align: left !important;
  box-shadow: none !important;
}

.home-page .hero-trust-strip span::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.62em !important;
  width: 13px !important;
  height: 2px !important;
  background: #8FAE35 !important;
  transform: rotate(-52deg) !important;
  transform-origin: left center !important;
}

.home-page .hero-cats {
  margin-top: 28px !important;
  gap: 14px 24px !important;
}

.home-page .hero-media,
body.home-page:has(.hero-inner) .hero-media {
  margin: 0 !important;
  min-height: 0 !important;
  height: clamp(480px, 52vw, 640px) !important;
  max-height: 640px !important;
  border-radius: 8px !important;
  clip-path: none !important;
  overflow: hidden !important;
  background: #E9ECEE !important;
  box-shadow: none !important;
}

.home-page .hero-media picture,
.home-page .hero-media img,
body.home-page:has(.hero-inner) .hero-media picture,
body.home-page:has(.hero-inner) .hero-media img {
  width: 100% !important;
  height: 100% !important;
  min-height: 0 !important;
  object-fit: cover !important;
  object-position: 68% center !important;
}

@media (max-width: 980px) {
  .home-page .hero {
    padding: 22px 0 44px !important;
  }

  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(calc(100% - 28px), 680px) !important;
    max-width: 680px !important;
  }

  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: 1fr !important;
    gap: 26px !important;
    min-height: 0 !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    max-width: none !important;
    padding: 20px 0 0 !important;
  }

  .home-page .hero h1 {
    max-width: 420px !important;
    font-size: clamp(34px, 9vw, 44px) !important;
    line-height: 1.08 !important;
  }

  .home-page .hero-text {
    max-width: 440px !important;
    font-size: 17px !important;
  }

  .home-page .hero-copy .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    max-width: 420px !important;
  }

  .home-page .hero-actions .btn,
  .home-page .hero-actions .hero-secondary-link {
    width: 100% !important;
    max-width: 420px !important;
    min-width: 0 !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    height: clamp(300px, 68vw, 440px) !important;
    border-radius: 8px !important;
  }
}
/* Final product detail guard: this must stay at the very end of the cascade. */
body:has(.product-layout) main:has(.product-layout) {
  padding-top: 96px !important;
  padding-bottom: clamp(62px, 6vw, 96px) !important;
}

body:has(.product-layout) main:has(.product-layout) .product-back-link {
  min-height: 40px !important;
  margin: 0 0 clamp(12px, 1.4vw, 18px) !important;
  padding: 0 15px !important;
}

body:has(.product-layout) main:has(.product-layout) .crumb {
  margin-bottom: clamp(24px, 2.8vw, 42px) !important;
}

body:has(.product-layout) main:has(.product-layout) .product-layout {
  margin-top: 0 !important;
  padding-top: 0 !important;
  gap: clamp(34px, 4.8vw, 64px) !important;
}

@media (max-width: 1100px) {
  body:has(.product-layout) main:has(.product-layout) {
    padding-top: 104px !important;
  }
}

@media (max-width: 760px) {
  body:has(.product-layout) main:has(.product-layout) {
    padding-top: 104px !important;
    padding-bottom: 62px !important;
  }

  body:has(.product-layout) main:has(.product-layout) .product-back-link {
    max-width: min(100%, calc(100vw - 28px)) !important;
    min-height: 42px !important;
    margin-bottom: 14px !important;
    padding: 0 14px !important;
    font-size: 14px !important;
    line-height: 1.15 !important;
    background: rgba(245, 247, 248, 0.88) !important;
  }

  body:has(.product-layout) main:has(.product-layout) .crumb {
    margin-bottom: 22px !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  body:has(.product-layout) main:has(.product-layout) .product-layout {
    gap: 24px !important;
  }
}

/* Final responsive hardening pass: prevent small-screen header, CTA and card edge cases. */
@media (max-width: 560px) {
  .site-header .logo img,
  .topbar .brand img {
    width: 104px !important;
    height: auto !important;
    max-height: 42px !important;
  }

  .site-header .nav-actions .btn,
  .topbar .nav-actions .btn,
  .topbar .nav-actions .cta {
    display: none !important;
  }

  .site-header .nav,
  .topbar .nav {
    gap: 8px !important;
  }
}

@media (max-width: 980px) {
  .topbar .nav-links {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    min-height: 100dvh !important;
    padding: calc(112px + env(safe-area-inset-top)) 24px calc(24px + env(safe-area-inset-bottom)) !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #1A1D21 !important;
    overflow: auto !important;
    overscroll-behavior: contain !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
    padding-top: calc(86px + 24px) !important;
  }
}

@media (max-width: 760px) {
  .home-page .hero-copy .hero-actions {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    width: 100% !important;
    max-width: 420px !important;
  }

  .home-page .hero-actions .btn-primary,
  .home-page .hero-actions .btn {
    width: 100% !important;
    max-width: 420px !important;
  }

  .home-page .hero-actions .hero-secondary-link,
  .home-page .hero-actions .btn-soft {
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 46px !important;
    padding-inline: 18px !important;
  }

  .call-close,
  .cookie-close {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }
}

@media (max-width: 420px) {
  body:has(.cart-layout) .cart-hit-card {
    grid-template-columns: 1fr !important;
  }

  body:has(.cart-layout) .cart-hit-media {
    width: 100% !important;
    min-height: 132px !important;
  }
}

/* Production QA polish: keep local/file renders stable across zoom levels and small viewports. */
.call-close,
.cookie-close {
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  flex: 0 0 44px !important;
}

.cookie-banner {
  max-height: min(72vh, 520px) !important;
  overflow: auto !important;
}

body:has(.cookie-banner.is-visible) .call-widget {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(10px) !important;
}

body:has(.shop-layout) .shop-card.reveal,
body:has(.shop-layout) .guide-card.reveal,
body:has(.shop-layout) .shop-card.reveal.in-view,
body:has(.shop-layout) .guide-card.reveal.in-view {
  opacity: 1 !important;
  transform: none !important;
}

body:has(.catalog-hero) .hero.catalog-hero {
  padding-top: clamp(96px, 7vw, 128px) !important;
  padding-bottom: clamp(44px, 4.5vw, 68px) !important;
}

body:has(.catalog-hero) .catalog-hero h1,
body:has(.catalog-hero) .hero.catalog-hero h1 {
  font-size: clamp(44px, 5vw, 72px) !important;
  line-height: 0.98 !important;
  max-width: 920px !important;
}

body:has(.catalog-hero) .catalog-hero p {
  max-width: 760px !important;
}

.home-page .hero-inner {
  align-items: center !important;
}

#packages .package.has-media > div:first-child {
  grid-template-rows: auto minmax(76px, auto) minmax(96px, auto) auto minmax(218px, 1fr) auto !important;
}

#packages .package-media.product-media {
  height: 218px !important;
  min-height: 218px !important;
}

#packages .package-media.product-media img {
  max-height: 210px !important;
}

#packages .hv-package .package-media.product-media img,
#packages .hv-package .package-media.hv-media img {
  max-height: 220px !important;
  transform: scale(1.12) !important;
}

@media (max-width: 980px) {
  .home-page .hero-inner {
    min-height: auto !important;
  }

  .home-page .hero-media {
    height: clamp(220px, 48vw, 340px) !important;
  }

  #packages .package.has-media > div:first-child {
    grid-template-rows: auto auto auto auto minmax(190px, auto) auto !important;
  }

  #packages .package p {
    display: -webkit-box !important;
    -webkit-line-clamp: 4 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  #packages .package-media.product-media {
    height: clamp(180px, 46vw, 240px) !important;
    min-height: clamp(180px, 46vw, 240px) !important;
  }

  #packages .package-media.product-media img {
    max-height: min(220px, 86%) !important;
  }
}

@media (max-width: 760px) {
  body:has(.catalog-hero) .hero.catalog-hero {
    padding-top: calc(86px + 26px) !important;
    padding-bottom: 42px !important;
  }

  body:has(.catalog-hero) .catalog-hero h1,
  body:has(.catalog-hero) .hero.catalog-hero h1 {
    font-size: clamp(34px, 11vw, 42px) !important;
    line-height: 1.02 !important;
  }

  .home-page .hero {
    padding-top: 20px !important;
    padding-bottom: 34px !important;
  }

  .home-page .hero-media {
    height: clamp(190px, 52vw, 260px) !important;
  }

  .home-page .hero-trust-strip {
    gap: 8px !important;
    margin-top: 14px !important;
  }

  .home-page .trust-pill {
    min-height: 34px !important;
    padding: 7px 12px !important;
    font-size: 12px !important;
  }

  body:has(.product-layout) .gallery-main {
    width: 100% !important;
    min-width: 0 !important;
    min-height: auto !important;
    aspect-ratio: 1 / 1 !important;
  }

  body:has(.product-layout) .gallery-main img,
  body:has(.product-layout) .battery-gallery .gallery-main img {
    width: auto !important;
    max-width: min(82%, 300px) !important;
    max-height: 82% !important;
    object-fit: contain !important;
  }

  body:has(.product-layout) main:has(.product-layout),
  body:has(.cart-layout) main,
  body:has(.contact-grid) main {
    padding-bottom: 120px !important;
  }

  .call-button {
    width: 56px !important;
    height: 56px !important;
  }

  .call-widget {
    right: 14px !important;
    bottom: calc(14px + env(safe-area-inset-bottom)) !important;
  }
}

/* Final QA guard: catalog cards must never depend on JS reveal state for visibility. */
.shop-card.reveal,
.catalog-card.reveal,
.guide-card.reveal,
.shop-card.reveal.in-view,
.catalog-card.reveal.in-view,
.guide-card.reveal.in-view {
  opacity: 1 !important;
  transform: none !important;
}

@media (max-width: 1100px) {
  .home-page .hero-inner,
  body.home-page:has(.hero-inner) .hero-inner {
    grid-template-columns: 1fr !important;
    overflow: hidden !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 0 !important;
    height: clamp(220px, 38vw, 320px) !important;
    aspect-ratio: auto !important;
  }

  .home-page .hero-media picture,
  .home-page .hero-media img,
  body.home-page:has(.hero-inner) .hero-media picture,
  body.home-page:has(.hero-inner) .hero-media img {
    width: 100% !important;
    min-height: 0 !important;
    height: 100% !important;
  }
}

@media (max-width: 760px) {
  .home-page .hero-inner.container,
  body.home-page:has(.hero-inner) .hero-inner.container {
    width: min(100% - 28px, 560px) !important;
  }

  .home-page .hero-copy,
  body.home-page:has(.hero-inner) .hero-copy {
    padding: 22px 18px 18px !important;
  }

  .home-page .hero-text {
    margin-bottom: 18px !important;
  }

  .home-page .hero-media,
  body.home-page:has(.hero-inner) .hero-media {
    height: clamp(180px, 50vw, 240px) !important;
  }
}

.filter-pill,
.filter-chip,
.catalog-filter,
.category-filter {
  min-width: 44px !important;
}

@media (max-width: 340px) {
  body:has(.product-card) .shop-grid,
  body:has(.product-card) .product-grid,
  body:has(.product-card) .products-grid,
  body:has(.product-card) .catalog-grid {
    grid-template-columns: 1fr !important;
  }

  body:has(.product-card) .shop-card.product-card,
  body:has(.product-card) .product-card {
    width: 100% !important;
    min-width: 0 !important;
  }
}

@media (max-width: 420px) {
  body:has(.shop-layout) .shop-card.product-card,
  body:has(.shop-layout) .shop-card.product-card > div:first-child,
  body:has(.shop-layout) .shop-card-top,
  body:has(.shop-layout) .product-card-image,
  body:has(.shop-layout) .product-specs {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body:has(.shop-layout) .shop-card.product-card {
    overflow: hidden !important;
  }

  body:has(.shop-layout) .shop-card-top {
    align-items: flex-start !important;
  }

  body:has(.shop-layout) .product-specs {
    flex: 1 1 auto !important;
    justify-content: flex-start !important;
  }

  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv-wide {
    max-width: 88% !important;
    max-height: 96px !important;
  }
}

.availability-status {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  gap: 8px;
  margin: 0 0 14px;
  color: rgba(11, 13, 15, 0.72);
  font-size: clamp(12px, 0.9vw, 14px);
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0;
}

.availability-status::before {
  content: "";
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: #8FAE35;
  flex: 0 0 auto;
}

.availability-status--preorder::before,
.availability-status--backorder::before,
.availability-status--quote::before {
  background: rgba(11, 13, 15, 0.42);
}

.availability-status--out_of_stock {
  color: rgba(11, 13, 15, 0.48);
}

.availability-status--out_of_stock::before {
  background: rgba(11, 13, 15, 0.24);
}

.product-info > .availability-status {
  margin: -4px 0 18px;
  font-size: clamp(14px, 1vw, 16px);
}

.shop-card .availability-status,
.catalog-card .availability-status {
  margin-top: auto;
  margin-bottom: 10px;
}

/* Final mobile guard for homepage packages: keep media and CTA in normal flow. */
@media (max-width: 760px) {
  #packages .package.has-media > div:first-child {
    grid-template-rows: none !important;
    grid-auto-rows: auto !important;
    row-gap: 14px !important;
    align-content: start !important;
  }

  #packages .package-media.product-media {
    position: relative !important;
    z-index: 1 !important;
    width: 100% !important;
    height: clamp(210px, 58vw, 280px) !important;
    min-height: clamp(210px, 58vw, 280px) !important;
    margin: 2px 0 18px !important;
    overflow: hidden !important;
  }

  #packages .package-media.product-media img {
    max-height: 88% !important;
    transform: none !important;
  }

  #packages .hv-package .package-media.product-media img,
  #packages .hv-package .package-media.hv-media img {
    max-height: 92% !important;
    transform: scale(1.08) !important;
  }

  #packages .package-specs {
    margin: 2px 0 0 !important;
  }

  #packages .package-actions {
    position: relative !important;
    z-index: 1 !important;
    min-height: 0 !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    transform: none !important;
  }

  #packages .package-action {
    width: 100% !important;
    min-height: 54px !important;
  }
}

/* iPhone Pro Max catalog guard: keep two-column battery cards contained. */
@media (min-width: 381px) and (max-width: 520px) {
  body:has(.shop-layout) .shop-grid {
    gap: 10px !important;
  }

  body:has(.shop-layout) .shop-card,
  body:has(.shop-layout) .shop-card.product-card {
    min-width: 0 !important;
    overflow: hidden !important;
    padding: 14px !important;
    height: auto !important;
    display: grid !important;
    grid-template-rows: auto auto !important;
    align-content: start !important;
  }

  body:has(.shop-layout) .shop-card.product-card > div:first-child {
    min-width: 0 !important;
    width: 100% !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    grid-template-rows: none !important;
  }

  body:has(.shop-layout) .shop-card-top {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 18px !important;
  }

  body:has(.shop-layout) .product-specs {
    display: none !important;
  }

  body:has(.shop-layout) .product-card-image,
  body:has(.shop-layout) .product-card-image.is-battery {
    width: 100% !important;
    min-width: 0 !important;
    height: 154px !important;
    min-height: 154px !important;
    margin: 8px 0 12px !important;
    overflow: hidden !important;
  }

  body:has(.shop-layout) .product-card-image img,
  body:has(.shop-layout) .product-card-image.is-battery img,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-image-fill.battery-size-lv,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-lv-wide,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-module,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-rack,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-system-wide,
  body:has(.shop-layout) .product-card-image.is-battery img.battery-size-ess {
    width: 100% !important;
    height: 100% !important;
    max-width: 100% !important;
    max-height: 100% !important;
    padding: 8px !important;
    object-fit: contain !important;
    object-position: center !important;
  }

  body:has(.shop-layout) .shop-card h3,
  body:has(.shop-layout) .shop-card.product-card h3 {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-bottom: 10px !important;
    font-size: clamp(15px, 3.9vw, 17px) !important;
    line-height: 1.12 !important;
    overflow: visible !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
  }

  body:has(.shop-layout) .shop-card .item-price,
  body:has(.shop-layout) .item-price {
    align-self: start !important;
    margin-top: 10px !important;
    padding-top: 10px !important;
  }
}

/* Conversion quick wins: compact consent, lighter mobile menu, product-first mobile catalog. */
.lead-scenario {
  grid-column: 1 / -1 !important;
  margin: 2px 0 4px !important;
  padding: 0 !important;
  border: 0 !important;
}

.lead-scenario legend {
  margin: 0 0 10px !important;
  color: rgba(245, 247, 248, 0.72) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.lead-scenario-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.lead-scenario-option {
  min-width: 0 !important;
  display: block !important;
  cursor: pointer !important;
}

.lead-scenario-option input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.lead-scenario-option span {
  min-height: 48px !important;
  display: grid !important;
  place-items: center !important;
  gap: 0 !important;
  padding: 10px 9px !important;
  border: 1px solid rgba(245, 247, 248, 0.16) !important;
  border-radius: 8px !important;
  background: rgba(245, 247, 248, 0.07) !important;
  color: rgba(245, 247, 248, 0.82) !important;
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease !important;
  text-align: center !important;
}

.lead-scenario-option strong {
  color: #F5F7F8 !important;
  font-size: 12.5px !important;
  font-weight: 850 !important;
  line-height: 1.1 !important;
}

.lead-scenario-option small {
  color: rgba(245, 247, 248, 0.58) !important;
  font-size: 11px !important;
  font-weight: 760 !important;
  line-height: 1.25 !important;
}

.lead-scenario-option input:checked + span {
  border-color: rgba(143, 174, 53, 0.82) !important;
  background: rgba(143, 174, 53, 0.15) !important;
}

.lead-scenario-option input:focus-visible + span {
  outline: 2px solid rgba(143, 174, 53, 0.82) !important;
  outline-offset: 3px !important;
}

.lead-form .lead-scenario--page {
  margin: 0 0 2px !important;
}

.lead-form .lead-scenario--page .lead-scenario-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.lead-form .lead-scenario--page .lead-scenario-option span {
  min-height: 52px !important;
  border-color: rgba(43, 49, 55, 0.12) !important;
  background: rgba(255, 255, 255, 0.58) !important;
  color: rgba(26, 29, 33, 0.74) !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

.lead-form .lead-scenario--page .lead-scenario-option strong {
  color: inherit !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.lead-form .lead-scenario--page .lead-scenario-option input:checked + span {
  border-color: rgba(143, 174, 53, 0.70) !important;
  background: rgba(143, 174, 53, 0.13) !important;
  color: #1A1D21 !important;
}

.lead-form .lead-scenario--page .lead-scenario-option input:focus-visible + span {
  outline: 2px solid rgba(143, 174, 53, 0.78) !important;
  outline-offset: 3px !important;
}

.cookie-banner {
  left: 24px !important;
  right: 24px !important;
  bottom: 18px !important;
  width: auto !important;
  max-width: none !important;
  max-height: min(48vh, 260px) !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 14px 18px !important;
  padding: 14px 16px !important;
  border-radius: 14px !important;
  box-shadow: 0 18px 54px rgba(11, 13, 15, 0.14) !important;
}

.cookie-banner h3 {
  margin: 0 0 4px !important;
  font-size: 18px !important;
  line-height: 1.15 !important;
}

.cookie-banner p {
  margin: 0 !important;
  max-width: 78ch !important;
  font-size: 13px !important;
  line-height: 1.42 !important;
}

.cookie-actions {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  margin: 0 !important;
}

.cookie-actions button {
  min-height: 44px !important;
  padding: 0 16px !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
}

.catalog-mobile-filter-bar {
  display: none;
}

@media (max-width: 980px) {
  .lead-scenario-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body.menu-open .topbar .nav-links {
    gap: 6px !important;
  }

  .topbar .mobile-menu-cta {
    margin-top: 22px !important;
  }

  body.menu-open .topbar .menu-toggle {
    box-shadow: 0 8px 22px rgba(11, 13, 15, 0.14) !important;
    outline: 0 !important;
  }

  body.menu-open .topbar .menu-toggle:focus-visible {
    outline: 2px solid rgba(143, 174, 53, 0.72) !important;
    outline-offset: 3px !important;
  }
}

@media (max-width: 760px) {
  .lead-scenario legend {
    text-align: left !important;
  }

  .lead-scenario-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  .lead-scenario-option span {
    min-height: 82px !important;
    padding: 12px !important;
  }

  .lead-scenario-option strong {
    font-size: 14px !important;
  }

  .lead-scenario-option small {
    font-size: 10.5px !important;
  }

  .lead-form .lead-scenario--page .lead-scenario-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 7px !important;
  }

  .lead-form .lead-scenario--page .lead-scenario-option span {
    min-height: 48px !important;
    padding: 9px 6px !important;
  }

  .lead-form .lead-scenario--page .lead-scenario-option strong {
    font-size: 11.5px !important;
  }

  .cookie-banner {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    width: auto !important;
    max-height: min(48vh, 300px) !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 16px !important;
    border: 1px solid rgba(26, 29, 33, 0.12) !important;
    border-radius: 18px !important;
  }

  .cookie-banner .cookie-close {
    top: 10px !important;
    right: 10px !important;
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    min-height: 34px !important;
    font-size: 24px !important;
  }

  .cookie-banner h3 {
    max-width: calc(100% - 44px) !important;
    font-size: 18px !important;
    line-height: 1.15 !important;
  }

  .cookie-banner p {
    padding-right: 0 !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
  }

  .cookie-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  .cookie-actions button {
    min-height: 46px !important;
    padding: 0 12px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
  }

  .catalog-mobile-filter-bar {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin: 0 0 14px !important;
    padding: 10px !important;
    border: 1px solid rgba(43, 49, 55, 0.12) !important;
    border-radius: 10px !important;
    background: rgba(245, 247, 248, 0.9) !important;
  }

  .catalog-mobile-filter-toggle {
    min-height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 16px !important;
    border: 1px solid #1A1D21 !important;
    border-radius: 8px !important;
    background: #1A1D21 !important;
    color: #F5F7F8 !important;
    font: inherit !important;
    font-size: 14px !important;
    font-weight: 900 !important;
  }

  .catalog-mobile-filter-toggle::after {
    content: "+";
    margin-left: 9px;
    font-size: 17px;
    line-height: 1;
  }

  .catalog-mobile-filter-toggle[aria-expanded="true"]::after {
    content: "−";
  }

  .catalog-mobile-filter-count {
    min-width: 0 !important;
    color: #6B7077 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    line-height: 1.25 !important;
    text-align: right !important;
  }

  body:has(.shop-layout) .shop-filter {
    display: none !important;
    margin-bottom: 16px !important;
  }

  body:has(.shop-layout) .shop-filter.is-mobile-open {
    display: block !important;
  }
}

/* Catalog-first pass: get users to useful choices and products sooner. */
body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
  padding-top: clamp(86px, 6.5vw, 110px) !important;
  padding-bottom: clamp(24px, 3.2vw, 44px) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
  align-items: center !important;
  gap: clamp(24px, 4vw, 52px) !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
  max-width: 760px !important;
  font-size: clamp(46px, 5.2vw, 76px) !important;
  line-height: 0.98 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero p {
  max-width: 720px !important;
  margin-top: 20px !important;
  font-size: clamp(17px, 1.35vw, 21px) !important;
  line-height: 1.48 !important;
}

body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
  max-width: 360px !important;
  padding: 24px !important;
}

body:has(.shop-layout) #shop {
  padding-top: clamp(22px, 3vw, 44px) !important;
}

.catalog-choice-guide {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 18px !important;
  align-items: center !important;
  margin: 0 0 18px !important;
  padding: 18px !important;
  border: 1px solid rgba(43, 49, 55, 0.12) !important;
  border-radius: 10px !important;
  background: rgba(245, 247, 248, 0.72) !important;
}

.catalog-choice-guide strong {
  display: block !important;
  color: #0B0D0F !important;
  font-size: clamp(20px, 2vw, 28px) !important;
  font-weight: 950 !important;
  line-height: 1.08 !important;
}

.catalog-choice-guide p {
  max-width: 760px !important;
  margin: 7px 0 0 !important;
  color: rgba(26, 29, 33, 0.68) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1.45 !important;
}

.catalog-choice-cta {
  min-height: 46px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 16px !important;
  border: 1px solid #1A1D21 !important;
  border-radius: 8px !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
  font: inherit !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
  cursor: pointer !important;
}

.catalog-preset-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 0 14px !important;
}

.catalog-preset-chip {
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 14px !important;
  border: 1px solid rgba(26, 29, 33, 0.14) !important;
  border-radius: 999px !important;
  background: rgba(245, 247, 248, 0.82) !important;
  color: #1A1D21 !important;
  font: inherit !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}

.catalog-preset-chip.is-active {
  border-color: #1A1D21 !important;
  background: #1A1D21 !important;
  color: #F5F7F8 !important;
}

@media (max-width: 980px) {
  body:has(.shop-layout):not(:has(.catalog-hero)) .hero {
    padding-top: calc(86px + 18px) !important;
    padding-bottom: 24px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-grid {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero h1 {
    font-size: clamp(40px, 10.5vw, 58px) !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero p {
    margin-top: 14px !important;
    font-size: 16px !important;
    line-height: 1.42 !important;
  }

  body:has(.shop-layout):not(:has(.catalog-hero)) .hero-warranty {
    display: none !important;
  }

  .catalog-choice-guide {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 14px !important;
  }

  .catalog-choice-cta {
    width: 100% !important;
  }
}

@media (max-width: 760px) {
  body:has(.shop-layout) #shop {
    padding-top: 14px !important;
  }

  body:has(.shop-layout) .financial-note {
    margin-bottom: 14px !important;
    padding: 14px !important;
  }

  .catalog-choice-guide {
    margin-bottom: 14px !important;
  }

  .catalog-choice-guide strong {
    font-size: 20px !important;
  }

  .catalog-choice-guide p {
    font-size: 13px !important;
  }

  .catalog-preset-bar {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .catalog-preset-chip {
    width: 100% !important;
    min-height: 42px !important;
  }

  body:has(.shop-layout) .shop-grid {
    gap: 10px !important;
  }

  body:has(.shop-layout) .shop-count {
    margin-bottom: 10px !important;
    font-size: 13px !important;
  }
}

.home-quick {
  padding: clamp(28px, 5vw, 56px) 0 clamp(18px, 3vw, 28px);
  background: #fff;
}

.home-quick-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: start;
}

.home-quick-copy h2 {
  margin: 8px 0 12px;
  max-width: 520px;
  color: #101315;
  font-size: clamp(32px, 4.4vw, 58px);
  line-height: 1;
  letter-spacing: 0;
}

.home-quick-copy p {
  max-width: 480px;
  color: rgba(16, 19, 21, 0.66);
  font-size: clamp(16px, 1.8vw, 19px);
  line-height: 1.55;
}

.home-quick-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.home-quick-actions a {
  display: grid;
  gap: 8px;
  min-height: 118px;
  padding: 18px;
  border: 1px solid rgba(43, 49, 55, 0.12);
  border-radius: 8px;
  background: #f8faf6;
  color: #111518;
  text-decoration: none;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.home-quick-actions a:hover,
.home-quick-actions a:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(143, 174, 53, 0.55);
  background: #fff;
}

.home-quick-actions strong {
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.1;
  letter-spacing: 0;
}

.home-quick-actions span {
  max-width: 260px;
  color: rgba(16, 19, 21, 0.62);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.35;
}

.package-fit {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 18px;
}

.package-fit span {
  padding: 7px 10px;
  border: 1px solid rgba(143, 174, 53, 0.28);
  border-radius: 999px;
  background: rgba(143, 174, 53, 0.08);
  color: rgba(16, 19, 21, 0.76);
  font-size: 12px;
  font-weight: 850;
  line-height: 1;
}

.install-gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.install-gallery-head {
  display: grid;
  gap: 6px;
  margin-top: 26px;
}

.install-gallery-head strong {
  color: #101315;
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.08;
  letter-spacing: 0;
}

.install-gallery-head span {
  max-width: 520px;
  color: rgba(16, 19, 21, 0.62);
  font-size: 14px;
  font-weight: 750;
  line-height: 1.45;
}

.install-gallery figure {
  position: relative;
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  aspect-ratio: 3 / 4;
  background: #eef1ec;
}

.install-gallery img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.install-gallery figcaption {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  padding: 7px 9px;
  border-radius: 8px;
  background: rgba(15, 18, 20, 0.72);
  color: #fff;
  font-size: 12px;
  font-weight: 850;
  line-height: 1.2;
}

.install-gallery-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.install-gallery-actions a,
.install-gallery-actions button {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border: 1px solid rgba(16, 19, 21, 0.14);
  border-radius: 999px;
  background: rgba(245, 247, 248, 0.72);
  color: #101315;
  font: inherit;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
}

.install-gallery-actions button {
  border-color: rgba(143, 174, 53, 0.34);
  background: rgba(143, 174, 53, 0.1);
}

.install-gallery-actions a:hover,
.install-gallery-actions button:hover,
.install-gallery-actions a:focus-visible,
.install-gallery-actions button:focus-visible {
  border-color: rgba(143, 174, 53, 0.58);
  background: #fff;
}

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

@media (max-width: 760px) {
  .home-quick {
    padding: 28px 0 18px;
  }

  .home-quick-actions {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 2px 1px 12px;
    scroll-snap-type: x proximity;
  }

  .home-quick-actions a {
    flex: 0 0 min(78vw, 280px);
    min-height: 126px;
    scroll-snap-align: start;
  }

  .install-gallery {
    grid-template-columns: repeat(3, minmax(96px, 1fr));
    overflow-x: auto;
    padding-bottom: 10px;
  }
}

/* Homepage proof block: real installation photos instead of synthetic review cards. */
.install-section {
  background: #f5f7f8;
}

.install-showcase {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

.install-showcase .install-gallery-head,
.install-showcase .section-head {
  display: grid !important;
  grid-template-columns: minmax(0, 760px) !important;
  gap: 0 !important;
  align-items: start !important;
  margin-top: 0 !important;
  margin-bottom: clamp(30px, 4vw, 56px) !important;
  text-align: left !important;
}

.install-showcase .install-gallery-head .section-kicker {
  align-self: start;
  margin-bottom: clamp(18px, 2vw, 26px);
}

.install-showcase .install-gallery-head h2 {
  max-width: 760px !important;
  margin: 0 0 clamp(18px, 2vw, 28px) !important;
}

.install-showcase .install-gallery-head p {
  max-width: 760px;
  margin: 0 !important;
  color: rgba(118, 130, 140, 0.95) !important;
  font-weight: 400 !important;
}

.install-showcase .install-gallery {
  gap: clamp(12px, 1.5vw, 20px);
  margin-top: 0;
}

.install-showcase .install-gallery figure {
  aspect-ratio: 4 / 5;
  border: 1px solid rgba(43, 49, 55, 0.12);
  box-shadow: 0 18px 48px rgba(11, 13, 15, 0.08);
}

.install-showcase .install-gallery figcaption {
  left: 12px;
  right: 12px;
  bottom: 12px;
  padding: 9px 11px;
  background: rgba(15, 18, 20, 0.76);
  font-size: 13px;
}

.install-showcase .install-gallery-actions {
  justify-content: center;
  gap: 12px;
  margin-top: clamp(28px, 3.2vw, 40px);
}

.install-showcase .install-gallery-actions a,
.install-showcase .install-gallery-actions button {
  min-width: min(100%, 260px);
  min-height: 54px;
  padding: 0 22px;
  border-radius: 7px;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.1;
  box-shadow: none;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.install-showcase .install-gallery-actions a {
  border-color: rgba(26, 29, 33, 0.16);
  background: #fff;
  color: #1A1D21;
}

.install-showcase .install-gallery-actions button {
  border-color: rgba(26, 29, 33, 0.18);
  background: #1A1D21;
  color: #F5F7F8;
}

.install-showcase .install-gallery-actions a:hover,
.install-showcase .install-gallery-actions a:focus-visible {
  border-color: rgba(26, 29, 33, 0.28);
  background: #F5F7F8;
}

.install-showcase .install-gallery-actions button:hover,
.install-showcase .install-gallery-actions button:focus-visible {
  border-color: rgba(26, 29, 33, 0.24);
  background: #0B0D0F;
}

@media (max-width: 760px) {
  .install-showcase {
    margin-top: 0;
    padding-top: 0;
  }

  .install-showcase .install-gallery-head {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .install-showcase .install-gallery {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding: 2px 1px 12px;
    scroll-snap-type: x proximity;
  }

  .install-showcase .install-gallery figure {
    flex: 0 0 min(78vw, 320px);
    scroll-snap-align: start;
  }

  .install-showcase .install-gallery-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    margin-top: 24px;
  }

  .install-showcase .install-gallery-actions a,
  .install-showcase .install-gallery-actions button {
    width: 100%;
  }
}

.cookie-banner .cookie-close,
.cookie-close {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

.cookie-banner .cookie-close {
  top: 8px !important;
  right: 8px !important;
}

@media (min-width: 761px) {
  .cookie-banner:has(.cookie-close) {
    padding-right: 54px !important;
  }
}

@media (max-width: 760px) {
  .cookie-banner {
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
    z-index: 9999 !important;
  }

  .cookie-actions,
  .cookie-actions button {
    position: relative !important;
    z-index: 2 !important;
    pointer-events: auto !important;
  }

  .cookie-banner .cookie-close,
  .cookie-close {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    min-height: 30px !important;
    font-size: 19px !important;
  }
}

.cookie-banner:not(.is-visible) {
  display: none !important;
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.cookie-banner.is-visible {
  display: grid !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

html,
body {
  max-width: 100% !important;
  overflow-x: hidden !important;
}

.lead-modal,
.lead-modal.is-open {
  width: 100dvw !important;
  max-width: 100dvw !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
}

.lead-modal-dialog {
  box-sizing: border-box !important;
  width: min(620px, calc(100dvw - 28px)) !important;
  max-width: calc(100dvw - 28px) !important;
  margin-inline: auto !important;
  overflow-x: hidden !important;
  overscroll-behavior: contain !important;
  touch-action: pan-y !important;
}

.lead-modal-dialog *,
.lead-modal-form *,
.lead-scenario *,
.lead-scenario-option * {
  box-sizing: border-box !important;
  max-width: 100% !important;
}

.lead-modal-form,
.lead-scenario,
.lead-scenario-grid,
.lead-scenario-option,
.lead-scenario-option span {
  min-width: 0 !important;
}

.lead-scenario-option input[type="radio"] {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  min-width: 1px !important;
  min-height: 1px !important;
  max-width: 1px !important;
  max-height: 1px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  pointer-events: none !important;
}

.lead-modal-form input:not([type="radio"]),
.lead-modal-form select,
.lead-modal-form textarea,
.lead-modal-form button[type="submit"] {
  width: 100% !important;
  max-width: 100% !important;
}

body:has(.lead-modal.is-open) {
  width: 100% !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

@media (max-width: 760px) {
  .lead-modal {
    padding-inline: 12px !important;
    justify-items: center !important;
  }

  .lead-modal-dialog {
    width: calc(100dvw - 24px) !important;
    max-width: calc(100dvw - 24px) !important;
    max-height: calc(100dvh - 28px) !important;
    padding-inline: 18px !important;
  }

  .lead-modal-dialog h2 {
    max-width: calc(100% - 56px) !important;
    font-size: clamp(28px, 8vw, 36px) !important;
    line-height: 1.04 !important;
  }

  .lead-modal-dialog > p {
    max-width: 92% !important;
    font-size: 15px !important;
    line-height: 1.42 !important;
  }

  .lead-modal-form {
    gap: 12px !important;
  }

  .lead-modal-form textarea {
    min-height: 86px !important;
  }
}

.hero-actions .btn,
.hero-actions .btn-primary,
body:has(.shop-layout) .hero-actions .btn,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn,
.nav-actions .btn-primary,
.mobile-sticky-cta .btn,
.lead-modal-form button[type="submit"],
.cart-form .btn,
.catalog-choice-cta {
  position: relative !important;
  overflow: hidden !important;
  border: 1px solid rgba(26, 29, 33, 0.18) !important;
  background: #1A1D21 !important;
  background-image: none !important;
  color: #F5F7F8 !important;
  box-shadow: none !important;
  animation: none !important;
  transform: none !important;
  cursor: pointer !important;
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease !important;
}

.hero-actions .btn::before,
.hero-actions .btn::after,
.hero-actions .btn-primary::before,
.hero-actions .btn-primary::after,
body:has(.shop-layout) .hero-actions .btn::before,
body:has(.shop-layout) .hero-actions .btn::after,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn::before,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn::after,
.nav-actions .btn-primary::before,
.nav-actions .btn-primary::after,
.mobile-sticky-cta .btn::before,
.mobile-sticky-cta .btn::after,
.lead-modal-form button[type="submit"]::before,
.lead-modal-form button[type="submit"]::after,
.cart-form .btn::before,
.cart-form .btn::after,
.catalog-choice-cta::before,
.catalog-choice-cta::after {
  content: none !important;
  display: none !important;
  animation: none !important;
}

.hero-actions .btn:hover,
.hero-actions .btn-primary:hover,
body:has(.shop-layout) .hero-actions .btn:hover,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn:hover,
.nav-actions .btn-primary:hover,
.mobile-sticky-cta .btn:hover,
.lead-modal-form button[type="submit"]:hover,
.cart-form .btn:hover,
.catalog-choice-cta:hover {
  border-color: rgba(26, 29, 33, 0.24) !important;
  background: #0B0D0F !important;
  background-image: none !important;
  box-shadow: none !important;
  transform: none !important;
}

.hero-actions .btn:focus-visible,
.hero-actions .btn-primary:focus-visible,
body:has(.shop-layout) .hero-actions .btn:focus-visible,
body:has(.catalog-hero) .catalog-hero .hero-actions .btn:focus-visible,
.nav-actions .btn-primary:focus-visible,
.mobile-sticky-cta .btn:focus-visible,
.lead-modal-form button[type="submit"]:focus-visible,
.cart-form .btn:focus-visible,
.catalog-choice-cta:focus-visible {
  outline: 2px solid rgba(143, 174, 53, 0.72) !important;
  outline-offset: 3px !important;
}

.is-lightboxable {
  cursor: zoom-in !important;
}

body.image-lightbox-open {
  overflow: hidden !important;
}

.image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: grid;
  place-items: center;
  padding: 24px;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, visibility 180ms ease;
}

.image-lightbox.is-open {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.image-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 9, 10, 0.84);
  backdrop-filter: blur(10px);
}

.image-lightbox__stage {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.image-lightbox__image {
  max-width: calc(100vw - 48px);
  max-height: calc(100dvh - 128px);
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
  transform-origin: center;
  transition: transform 120ms ease;
  cursor: zoom-in;
  touch-action: none;
  user-select: none;
}

.image-lightbox__image.is-zoomed {
  cursor: grab;
}

.image-lightbox__image.is-zoomed:active {
  cursor: grabbing;
}

.image-lightbox__close,
.image-lightbox__nav,
.image-lightbox__tools button {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
  box-shadow: none;
  cursor: pointer;
  font: 700 28px/1 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  backdrop-filter: blur(12px);
}

.image-lightbox__close:hover,
.image-lightbox__nav:hover,
.image-lightbox__tools button:hover {
  background: rgba(255, 255, 255, 0.18);
}

.image-lightbox__close:focus-visible,
.image-lightbox__nav:focus-visible,
.image-lightbox__tools button:focus-visible {
  outline: 2px solid rgba(143, 174, 53, 0.86);
  outline-offset: 3px;
}

.image-lightbox__close {
  position: absolute;
  top: max(18px, env(safe-area-inset-top));
  right: max(18px, env(safe-area-inset-right));
  z-index: 3;
}

.image-lightbox__nav {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: 52px;
  height: 52px;
  transform: translateY(-50%);
  font-size: 42px;
  line-height: 1;
}

.image-lightbox__nav[hidden] {
  display: none !important;
}

.image-lightbox__nav--prev {
  left: max(18px, env(safe-area-inset-left));
}

.image-lightbox__nav--next {
  right: max(18px, env(safe-area-inset-right));
}

.image-lightbox__tools {
  position: absolute;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(22px, env(safe-area-inset-bottom));
  z-index: 3;
  display: flex;
  gap: 10px;
}

.image-lightbox__caption {
  position: absolute;
  left: 50%;
  bottom: max(22px, env(safe-area-inset-bottom));
  z-index: 2;
  max-width: min(720px, calc(100vw - 148px));
  margin: 0;
  padding: 10px 14px;
  transform: translateX(-50%);
  border-radius: 8px;
  background: rgba(10, 12, 14, 0.72);
  color: rgba(255, 255, 255, 0.86);
  font: 600 14px/1.35 system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-align: center;
  backdrop-filter: blur(10px);
}

@media (max-width: 760px) {
  .image-lightbox {
    padding: 12px;
  }

  .image-lightbox__image {
    max-width: calc(100vw - 24px);
    max-height: calc(100dvh - 112px);
  }

  .image-lightbox__close,
  .image-lightbox__nav,
  .image-lightbox__tools button {
    width: 40px;
    height: 40px;
    font-size: 25px;
  }

  .image-lightbox__nav {
    top: auto;
    bottom: max(22px, env(safe-area-inset-bottom));
    transform: none;
    font-size: 34px;
  }

  .image-lightbox__nav--prev {
    left: 12px;
  }

  .image-lightbox__nav--next {
    right: 130px;
  }

  .image-lightbox__caption {
    bottom: calc(max(22px, env(safe-area-inset-bottom)) + 52px);
    max-width: calc(100vw - 24px);
    padding: 8px 10px;
    font-size: 12px;
  }
}

/* Product detail experiment: full-width description/specs under the media row. */
body:has(.product-layout--wide-detail) .product-wide-sections {
  grid-column: 1 / -1 !important;
  display: grid !important;
  gap: 12px !important;
  margin-top: 0 !important;
  min-width: 0 !important;
  overflow-anchor: none !important;
}

body:has(.product-layout--wide-detail) .product-topline {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 16px !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  scrollbar-width: none !important;
  margin: 0 0 clamp(14px, 1.8vw, 24px) !important;
}

body:has(.product-layout--wide-detail) .product-topline::-webkit-scrollbar {
  display: none !important;
}

body:has(.product-layout--wide-detail) .product-topline .product-back-link {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

body:has(.product-layout--wide-detail) main:has(.product-layout--wide-detail) .product-topline .product-back-link {
  margin: 0 !important;
}

body:has(.product-layout--wide-detail) .product-topline .crumb {
  flex: 0 0 auto !important;
  margin: 0 !important;
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 13px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
}

body:has(.product-layout--wide-detail) .product-topline .crumb a {
  display: inline !important;
  color: inherit !important;
}

body:has(.product-layout--wide-detail) main:has(.product-layout--wide-detail) .product-topline .crumb {
  margin: 0 !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail {
  grid-template-columns: minmax(340px, 0.76fr) minmax(0, 1.24fr) !important;
  column-gap: clamp(38px, 4.2vw, 62px) !important;
  row-gap: clamp(16px, 2vw, 28px) !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .product-info {
  width: 100% !important;
  max-width: 820px !important;
  padding-top: 0 !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail h1 {
  max-width: 800px !important;
  font-size: clamp(32px, 2.55vw, 44px) !important;
  line-height: 1.04 !important;
  margin-bottom: 18px !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .badges {
  margin-bottom: 22px !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .price {
  font-size: clamp(36px, 3vw, 48px) !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .actions {
  grid-template-columns: minmax(200px, 0.92fr) minmax(240px, 1.08fr) !important;
  width: min(100%, 660px) !important;
  max-width: 660px !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .actions .btn {
  min-height: 54px !important;
  padding-inline: clamp(20px, 2vw, 30px) !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .bundle-highlight {
  width: min(100%, 660px) !important;
  max-width: 660px !important;
  margin-bottom: 0 !important;
  padding: 12px 16px !important;
  gap: 12px !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .bundle-highlight strong {
  font-size: 22px !important;
}

body:has(.product-layout--wide-detail) .product-layout--wide-detail .bundle-highlight span {
  font-size: clamp(13px, 1vw, 15px) !important;
}

body:has(.product-layout) .product-fit {
  margin: 16px 0 0;
  padding: 14px 0 14px 18px;
  border-left: 3px solid var(--green, #8FAE35);
  color: rgba(11, 13, 15, 0.68);
}

body:has(.product-layout) .product-fit strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink, #0B0D0F);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 900;
}

body:has(.product-layout) .product-fit p {
  max-width: 660px;
  margin: 0;
  font-size: 15px;
  line-height: 1.48;
  font-weight: 500;
}

body:has(.product-layout--wide-detail) .product-wide-sections .section-tabs {
  margin: 0 !important;
  padding-top: 0 !important;
  border-top: 0 !important;
  gap: clamp(14px, 1.8vw, 26px) !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .section-tab {
  min-height: 44px !important;
  padding-inline: 0 !important;
  font-size: clamp(17px, 1.35vw, 22px) !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .section-card {
  width: 100% !important;
  max-width: none !important;
  padding: clamp(18px, 2.1vw, 30px) !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections #description p,
body:has(.product-layout--wide-detail) .product-wide-sections #description h3 {
  max-width: 1120px !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections #description p,
body:has(.product-layout--wide-detail) .product-wide-sections #description li {
  font-size: clamp(14px, 1vw, 16px) !important;
  line-height: 1.55 !important;
  font-weight: 500 !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections #description h3 {
  font-size: clamp(17px, 1.25vw, 21px) !important;
  line-height: 1.25 !important;
  margin-top: 22px !important;
  margin-bottom: 8px !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact {
  margin-top: 10px !important;
  border-top: 0 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-trigger {
  min-height: 38px !important;
  font-size: clamp(14px, 1vw, 16px) !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
  color: #1A1D21 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .accordion-mark {
  font-size: 22px !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel {
  padding-bottom: 10px !important;
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel p,
body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel li,
body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel a {
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 14px !important;
  font-weight: 430 !important;
  line-height: 1.5 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel strong {
  color: rgba(26, 29, 33, 0.58) !important;
  font-size: 14px !important;
  font-weight: 760 !important;
  line-height: 1.5 !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .spec-panel {
  border-top: 1px solid rgba(43, 49, 55, 0.11) !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.11) !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .spec-row {
  grid-template-columns: minmax(190px, 0.32fr) minmax(0, 1fr) !important;
  gap: clamp(20px, 2.8vw, 48px) !important;
  padding: clamp(10px, 0.95vw, 14px) 0 !important;
  border-top: 1px solid rgba(43, 49, 55, 0.11) !important;
  color: rgba(26, 29, 33, 0.72) !important;
  font-size: clamp(13.5px, 0.9vw, 15.5px) !important;
  line-height: 1.42 !important;
  font-weight: 430 !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .spec-row:first-child {
  border-top: 0 !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .spec-row strong {
  color: rgba(79, 89, 99, 0.72) !important;
  font-size: inherit !important;
  font-weight: 760 !important;
  line-height: inherit !important;
}

body:has(.product-layout--wide-detail) .product-wide-sections .spec-row span {
  color: rgba(11, 13, 15, 0.86) !important;
  font-size: inherit !important;
  font-weight: 430 !important;
  line-height: inherit !important;
}

body:has(.product-layout--wide-detail) .gallery .thumbs,
body:has(.product-layout--wide-detail) .battery-gallery .thumbs,
body:has(.product-layout--wide-detail) .bos-gallery .thumbs,
body:has(.product-layout--wide-detail) .panel-gallery .thumbs {
  display: flex !important;
  grid-template-columns: none !important;
  grid-auto-flow: unset !important;
  gap: 12px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding-bottom: 4px !important;
  scroll-snap-type: x proximity !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(43, 49, 55, 0.24) transparent !important;
}

body:has(.product-layout--wide-detail) .gallery .thumbs::-webkit-scrollbar {
  height: 6px !important;
}

body:has(.product-layout--wide-detail) .gallery .thumbs::-webkit-scrollbar-track {
  background: transparent !important;
}

body:has(.product-layout--wide-detail) .gallery .thumbs::-webkit-scrollbar-thumb {
  border-radius: 999px !important;
  background: rgba(43, 49, 55, 0.22) !important;
}

body:has(.product-layout--wide-detail) .gallery .thumb {
  flex: 0 0 clamp(116px, 8.8vw, 150px) !important;
  width: clamp(116px, 8.8vw, 150px) !important;
  height: clamp(78px, 6.2vw, 98px) !important;
  min-width: 0 !important;
  scroll-snap-align: start !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel h3 {
  margin: 0 0 6px !important;
  color: #1A1D21 !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .product-accordion-panel .delivery-payment-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .delivery-list,
body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .delivery-payment-block {
  gap: 6px !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .delivery-list li {
  padding-left: 0 !important;
}

body:has(.product-layout--wide-detail) .product-info > .product-accordions--compact .delivery-list li::before {
  display: none !important;
}

@media (max-width: 900px) {
  body:has(.product-layout--wide-detail) .product-topline {
    align-items: center !important;
    flex-direction: row !important;
    gap: 12px !important;
  }

  body:has(.product-layout--wide-detail) .product-layout--wide-detail {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  body:has(.product-layout--wide-detail) .product-layout--wide-detail .actions,
  body:has(.product-layout--wide-detail) .product-layout--wide-detail .bundle-highlight {
    width: 100% !important;
    max-width: none !important;
  }
}

@media (max-width: 760px) {
  body:has(.product-layout--wide-detail) .product-layout--wide-detail h1 {
    font-size: clamp(30px, 9vw, 40px) !important;
    line-height: 1.03 !important;
  }

  body:has(.product-layout--wide-detail) .product-layout--wide-detail .actions {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    max-width: none !important;
  }

  body:has(.product-layout--wide-detail) .product-layout--wide-detail .actions .btn {
    width: 100% !important;
    min-width: 0 !important;
  }

  body:has(.product-layout) .product-fit {
    margin-top: 14px;
    padding: 12px 0 12px 16px;
  }

  body:has(.product-layout) .product-fit p {
    font-size: 14px;
    line-height: 1.5;
  }

  body:has(.product-layout--wide-detail) .product-wide-sections .section-tabs {
    gap: 18px !important;
    overflow-x: auto !important;
    padding-bottom: 2px !important;
  }

  body:has(.product-layout--wide-detail) .product-wide-sections .section-tab {
    flex: 0 0 auto !important;
    min-height: 42px !important;
    font-size: clamp(18px, 5vw, 22px) !important;
  }

  body:has(.product-layout--wide-detail) .product-wide-sections .section-card {
    padding: clamp(18px, 5vw, 24px) !important;
  }

  body:has(.product-layout--wide-detail) .product-wide-sections .spec-row {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
    padding: 11px 0 !important;
    font-size: 14px !important;
  }
}

/* Keep package support notes secondary so the -5% line stays the main accent. */
#packages .package-common {
  opacity: 0.76 !important;
}

#packages .common-item {
  border-color: rgba(118, 130, 140, 0.16) !important;
  background: transparent !important;
  color: rgba(118, 130, 140, 0.76) !important;
  font-weight: 420 !important;
}

#packages .common-item::before {
  display: none !important;
  content: none !important;
}

#packages .common-item strong {
  color: rgba(86, 96, 105, 0.82) !important;
  font-weight: 620 !important;
}

/* Catalog scenario landing cards: SEO routes instead of fragile pseudo-filters. */
.catalog-scenarios {
  padding: clamp(48px, 7vw, 88px) 0 !important;
  border-bottom: 1px solid rgba(43, 49, 55, 0.10) !important;
}

.catalog-scenario-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.catalog-scenario-card {
  min-height: 100% !important;
  display: grid !important;
  align-content: start !important;
  gap: 10px !important;
  padding: clamp(18px, 2vw, 24px) !important;
  border: 1px solid rgba(43, 49, 55, 0.11) !important;
  border-radius: 12px !important;
  background: rgba(255, 255, 255, 0.58) !important;
  color: inherit !important;
  box-shadow: none !important;
  transition: border-color 160ms ease, background-color 160ms ease !important;
}

.catalog-scenario-card:hover {
  border-color: rgba(143, 174, 53, 0.48) !important;
  background: rgba(255, 255, 255, 0.78) !important;
}

.catalog-scenario-card span {
  color: #8FAE35 !important;
  font-size: 12px !important;
  font-weight: 850 !important;
  line-height: 1.2 !important;
}

.catalog-scenario-card strong {
  color: #0B0D0F !important;
  font-size: clamp(17px, 1.5vw, 21px) !important;
  font-weight: 820 !important;
  line-height: 1.16 !important;
}

.catalog-scenario-card p {
  margin: 0 !important;
  color: rgba(118, 130, 140, 0.94) !important;
  font-size: 14px !important;
  font-weight: 430 !important;
  line-height: 1.5 !important;
}

@media (max-width: 1180px) {
  .catalog-scenario-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 760px) {
  .catalog-scenarios .container {
    width: 100% !important;
    padding-inline: clamp(24px, 6.4vw, 30px) !important;
  }

  .catalog-scenario-grid {
    grid-template-columns: 1fr !important;
  }

  .catalog-scenario-card {
    padding: 18px !important;
  }
}
