/* =========================================================
   WATT WAGON THEME REFRESH
   Pastel UAE clean-energy visual system
   ========================================================= */

:root {
  --clr-charcoal: #10281e;
  --clr-charcoal-2: #1c3f31;
  --clr-teal: #B4E5A2;
  --clr-teal-dark: #3f7f35;
  --clr-mint: #D9F2D0;
  --clr-mint-2: #E4F4DE;
  --clr-sage: #9FD48E;
  --clr-sand: #eef4dc;
  --clr-sand-2: #dfeabc;
  --clr-amber: #b98b36;
  --clr-ink: #0b241a;
  --clr-white: #ffffff;
  --clr-stone: #edf6e9;
  --clr-grey-mid: #60766a;
  --clr-grey-dark: #284b38;
  --clr-border: #b9dcb0;
  --shadow-sm: 0 1px 8px rgba(18, 64, 38, .12);
  --shadow-md: 0 14px 34px rgba(18, 64, 38, .17);
  --shadow-lg: 0 24px 60px rgba(18, 64, 38, .22);
  --r-md: 10px;
  --r-lg: 14px;
}

body {
  color: var(--clr-ink);
  background:
    linear-gradient(90deg, rgba(63, 127, 53, .055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(63, 127, 53, .045) 1px, transparent 1px),
    #eef7ea;
  background-size: 72px 72px;
}

h1, h2, h3, h4, h5, h6 {
  letter-spacing: 0;
}

p {
  color: var(--clr-grey-dark);
}

.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.section {
  padding-block: clamp(3.5rem, 6vw, 5.25rem);
}

.label {
  color: var(--clr-teal-dark);
}

.text-white {
  color: var(--clr-ink);
}

.btn {
  border-radius: 999px;
}

.btn--primary {
  background: linear-gradient(135deg, #69ad55, #B4E5A2);
  color: #083126;
  box-shadow: 0 10px 24px rgba(63, 127, 53, .24);
}

.btn--primary:hover {
  background: linear-gradient(135deg, #5b9b49, #a8db96);
  color: #06241c;
  box-shadow: 0 14px 30px rgba(63, 127, 53, .3);
}

.btn--outline,
.btn--outline-dark {
  color: var(--clr-ink);
  border: 1px solid rgba(32, 133, 99, .35);
  background: rgba(255, 255, 255, .7);
}

.btn--outline:hover,
.btn--outline-dark:hover {
  background: var(--clr-mint);
  border-color: var(--clr-teal-dark);
  color: var(--clr-ink);
}

.site-nav {
  background: rgba(232, 246, 225, .9);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(63, 127, 53, .18);
}

.site-nav.scrolled {
  background: rgba(229, 244, 221, .97);
  box-shadow: 0 10px 30px rgba(18, 64, 38, .13);
}

.nav-logo__mark {
  background: linear-gradient(135deg, #6eae5a, #B4E5A2);
  box-shadow: 0 8px 18px rgba(63, 127, 53, .26);
}

.nav-logo {
  gap: 0;
}

.nav-logo__image {
  display: block;
  width: clamp(150px, 13vw, 205px);
  height: auto;
  max-height: 54px;
  object-fit: contain;
}

.nav-logo__name {
  color: var(--clr-ink);
}

.nav-logo__tagline,
.nav-link,
.nav-dropdown__spec {
  color: var(--clr-teal-dark);
}

.nav-link:hover,
.nav-link.active {
  color: var(--clr-ink);
  background: var(--clr-mint);
}

.nav-dropdown {
  background: rgba(255, 255, 255, .96);
  border-color: var(--clr-border);
  box-shadow: var(--shadow-lg);
}

.nav-dropdown__title {
  color: var(--clr-ink);
}

.nav-dropdown__desc {
  color: var(--clr-grey-mid);
}

.nav-dropdown__item:hover {
  background: var(--clr-mint-2);
}

.nav-hamburger span {
  background: var(--clr-ink);
}

.mobile-menu {
  background: linear-gradient(180deg, #f8fff9, #EFF9EA);
}

.mobile-menu__link {
  color: var(--clr-ink);
  border-color: rgba(32, 133, 99, .14);
}

/* Homepage */
.hero {
  min-height: 100vh;
  min-height: 100svh;
  background: #9ccc89;
  align-items: stretch;
}

.hero .container {
  position: relative;
  z-index: 5;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 1;
  border-radius: 0;
  background: #a7d796;
  border: 0;
  box-shadow: none;
  overflow: hidden;
  pointer-events: none;
}

.hero-video {
  min-height: 100%;
}

.hero-video__media,
.hero-video__fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.hero-video__media {
  z-index: 0;
  opacity: 1;
  filter: saturate(.9) contrast(.96);
}

.hero-video__fallback {
  z-index: -1;
  opacity: 0;
}

.hero-video::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(217, 242, 208, .96) 0%, rgba(217, 242, 208, .9) 30%, rgba(180, 229, 162, .46) 56%, rgba(18, 70, 39, .22) 100%),
    linear-gradient(180deg, rgba(15, 57, 31, .12) 0%, rgba(15, 57, 31, .04) 52%, rgba(15, 57, 31, .24) 100%);
  pointer-events: none;
}

.hero__bg::after {
  display: none;
}

.hero__grid-lines {
  background-image:
    linear-gradient(rgba(32, 133, 99, .08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(32, 133, 99, .08) 1px, transparent 1px);
  opacity: .45;
  pointer-events: none;
}

.hero-video__media,
.hero-video__fallback {
  pointer-events: none;
}

.hero__content {
  max-width: 640px;
  width: min(640px, 48vw);
  padding: clamp(1.25rem, 2.4vw, 2.35rem);
  margin-block: calc(var(--nav-h) + 1.2rem) clamp(4.5rem, 7vw, 6rem);
  background: rgba(226, 247, 218, .88);
  border: 1px solid rgba(16, 40, 30, .14);
  border-radius: 28px;
  box-shadow: 0 28px 70px rgba(18, 64, 38, .2);
  backdrop-filter: blur(18px);
}

.hero__eyebrow {
  background: rgba(217, 242, 208, .82);
  border: 1px solid rgba(63, 127, 53, .28);
  border-radius: 999px;
  padding: .55rem 1rem;
  box-shadow: var(--shadow-sm);
}

.hero__eyebrow-line {
  background: var(--clr-teal-dark);
}

.hero__eyebrow-text {
  color: var(--clr-teal-dark);
}

.hero h1,
.hero h1 em,
.hero__sub,
.hero__std-label,
.hero__scroll span,
.hero__scroll svg {
  color: var(--clr-ink);
  stroke: var(--clr-ink);
}

.hero h1 em {
  color: var(--clr-teal-dark);
}

.hero__sub {
  color: #31564a;
  max-width: 50ch;
}

.hero__standards {
  background: rgba(236, 248, 230, .74);
  border: 1px solid rgba(63, 127, 53, .22);
  border-radius: 18px;
  padding: var(--sp-4);
  max-width: 680px;
  width: min(100%, 590px);
}

.hero__scroll {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  left: 50%;
  right: auto;
  bottom: clamp(1.25rem, 3vw, 2.5rem);
  transform: translateX(-50%) !important;
  z-index: 10;
  opacity: 1 !important;
  animation: none !important;
  padding: .25rem;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  text-decoration: none;
  color: #ffffff;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .38);
}

.hero__scroll:hover {
  transform: translateX(-50%) translateY(-2px) !important;
}

.hero__scroll span {
  color: #ffffff !important;
  font-weight: 800;
  opacity: 1;
}

.hero__scroll svg {
  width: 24px;
  height: 24px;
  stroke: #ffffff !important;
  flex-shrink: 0;
  filter: drop-shadow(0 2px 10px rgba(0, 0, 0, .4));
  animation: heroScrollDoubleArrow 1.35s ease-in-out infinite;
}

@keyframes heroScrollDoubleArrow {
  0%, 100% {
    transform: translateY(0);
    opacity: .72;
  }
  50% {
    transform: translateY(5px);
    opacity: 1;
  }
}

.std-pill,
.std-badge {
  background: #ffffff;
  color: var(--clr-teal-dark);
  border-color: rgba(32, 133, 99, .22);
}

.std-pill--emirates {
  background: linear-gradient(135deg, #c8eabb, #eef4dc);
  color: #315d27;
  border-color: rgba(63, 127, 53, .28);
  box-shadow: 0 8px 18px rgba(63, 127, 53, .12);
}

.stats-strip {
  background: linear-gradient(135deg, #cfecc5, #edf7e8);
  border-color: rgba(63, 127, 53, .2);
}

.stats-grid {
  gap: var(--sp-4);
}

.stat-item {
  background: rgba(245, 251, 242, .86);
  border: 1px solid rgba(63, 127, 53, .18);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  box-shadow: var(--shadow-sm);
}

.stat-item::after {
  display: none;
}

.stat-number {
  color: var(--clr-teal-dark);
}

.stat-label,
.stats-context p {
  color: var(--clr-grey-dark);
}

.products-overview,
.stack-callout,
.about-strip,
.product-features,
.product-applications,
.app-problem,
.contact-main {
  background: linear-gradient(180deg, #edf7e8, #d9f0d1);
}

.product-card,
.feature-tile,
.product-app-tile,
.related-card,
.resource-card,
.card {
  border-color: rgba(63, 127, 53, .18);
  box-shadow: var(--shadow-sm);
}

.product-card__img,
.product-hero__visual,
.product-overview__img,
.stack-callout__img,
.about-strip__img {
  background:
    linear-gradient(135deg, #e6f5df, #D9F2D0 62%, #c5e4b9);
  border: 1px solid rgba(63, 127, 53, .18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.52), var(--shadow-sm);
}

.product-card__img img,
.product-hero__visual img,
.product-overview__img img,
.stack-callout__img img,
.about-strip__img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  padding: clamp(1.25rem, 3.2vw, 2.75rem);
  opacity: 1;
}

.stack-callout__img img,
.product-overview__img img,
.about-strip__img img {
  padding: clamp(1rem, 2.5vw, 2rem);
}

.product-card__img {
  align-items: center;
  justify-content: center;
}

.product-image-empty {
  width: 100%;
  height: 100%;
  min-height: inherit;
  border-radius: inherit;
  background:
    linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,0) 42%),
    repeating-linear-gradient(135deg, rgba(28, 89, 53, .055) 0 1px, transparent 1px 18px),
    linear-gradient(135deg, #e9f7e3, #D9F2D0 58%, #bfe6b2);
}

.product-overview__layout--text-only {
  grid-template-columns: minmax(0, 920px) !important;
  justify-content: center;
  gap: 0;
  text-align: center;
}

.product-overview__layout--text-only .product-overview__text {
  max-width: 920px;
  margin-inline: auto;
}

.product-overview__layout--text-only .label {
  display: inline-flex;
  justify-content: center;
}

.product-overview__layout--text-only .product-overview__text h2 {
  max-width: 760px;
  margin-inline: auto;
}

.product-overview__layout--text-only .product-overview__text p {
  max-width: 860px;
  margin-inline: auto;
}

.product-card__img img {
  max-width: 92%;
  max-height: 92%;
}

.why-section,
.sustainability-banner,
.product-cta,
.how-it-works,
.app-product,
.cta-banner,
.app-hero,
.product-hero,
.contact-hero,
.page-hero {
  background:
    radial-gradient(circle at 85% 15%, rgba(79, 143, 64, .22), transparent 30%),
    radial-gradient(circle at 15% 12%, rgba(180, 229, 162, .58), transparent 30%),
    linear-gradient(135deg, #d7efcf 0%, #B4E5A2 50%, #8fca7d 100%) !important;
  color: var(--clr-ink);
}

.why-section .text-white,
.sustainability-banner .text-white,
.app-product .text-white,
.product-cta h2,
.how-it-works .text-white,
.cta-banner h2,
.app-hero h1,
.app-hero h1 em,
.product-hero h1,
.product-hero h1 em,
.contact-hero h1,
.page-hero h1,
.sustainability-text h2,
.why-tile__title,
.step-item__title,
.app-product__card-name {
  color: var(--clr-ink) !important;
}

.why-text p,
.sustainability-text p,
.sus-badge__sub,
.step-item__desc,
.product-cta__text p,
.cta-banner__sub,
.app-hero__intro,
.product-hero__tagline,
.contact-hero p,
.page-hero p,
.app-product p,
.app-product__card-tagline {
  color: var(--clr-grey-dark) !important;
}

.why-tile,
.sus-badge,
.step-item__number,
.app-product__card,
.product-hero__stat,
.stack-spec {
  background: rgba(239, 249, 234, .78);
  border-color: rgba(63, 127, 53, .2);
  box-shadow: var(--shadow-sm);
}

.why-tile:hover {
  background: #fff;
}

.why-tile__icon,
.sus-badge__icon,
.feature-tile__icon,
.product-app-tile__icon,
.contact-info__icon {
  background: var(--clr-mint);
}

.app-grid {
  gap: var(--sp-5);
}

.app-tile {
  background: linear-gradient(135deg, #f5fbf1, #D9F2D0);
  border: 1px solid rgba(63, 127, 53, .18);
  box-shadow: var(--shadow-sm);
}

.app-tile__name {
  color: var(--clr-ink);
}

.app-tile__desc {
  color: var(--clr-grey-dark);
  max-height: 60px;
  opacity: 1;
}

.app-tile__icon {
  opacity: .55;
}

.sustainability-banner {
  position: relative;
}

.sustainability-banner::after {
  content: "MAKE IT IN THE EMIRATES";
  position: absolute;
  right: max(2rem, 8vw);
  top: 2rem;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(2.1rem, 8vw, 7rem);
  line-height: .9;
  color: rgba(11, 36, 26, .09);
  max-width: 8ch;
  text-align: right;
  pointer-events: none;
}

.sustainability-layout,
.why-layout,
.stack-callout-layout,
.about-strip-layout,
.product-overview__layout,
.product-hero__layout,
.app-product__layout,
.product-cta-layout {
  align-items: center;
}

.standards-strip,
.site-footer {
  background: #dcefd5;
  border-color: rgba(63, 127, 53, .18);
}

.site-footer {
  color: var(--clr-ink);
}

.footer-col__heading,
.footer-bottom__copy {
  color: var(--clr-ink);
}

.footer-col__link,
.footer-brand__desc,
.footer-bottom__link {
  color: var(--clr-grey-dark);
}

.footer-uae-badge,
.footer-brand__igs {
  background: var(--clr-sand);
  color: #315d27;
  border-color: rgba(63, 127, 53, .24);
}

.specs-table thead tr {
  background: var(--clr-teal-dark);
}

.specs-table tbody tr:nth-child(even) {
  background: var(--clr-mint-2);
}

.contact-form,
.contact-form--light {
  background: rgba(242, 250, 238, .86);
  border-color: rgba(63, 127, 53, .2);
  box-shadow: var(--shadow-md);
}

.form-label,
.contact-form--light .form-label {
  color: var(--clr-ink);
}

.form-input,
.form-select,
.form-textarea,
.contact-form--light .form-input,
.contact-form--light .form-select,
.contact-form--light .form-textarea {
  background: #fff;
  color: var(--clr-ink);
  border-color: var(--clr-border);
}

.form-note,
.contact-form--light .form-note {
  color: var(--clr-grey-mid);
}

/* Some generated pages still have inline light-text styles from the earlier dark theme.
   Pull them back into the green system so copy stays readable on the refreshed panels. */
[style*="color:var(--clr-white)"],
[style*="color: var(--clr-white)"],
[style*="color:rgba(255,255,255"],
[style*="color: rgba(255,255,255"],
[style*="color:rgba(255, 255, 255"],
[style*="color: rgba(255, 255, 255"] {
  color: var(--clr-ink) !important;
}

[style*="background:rgba(255,255,255"],
[style*="background: rgba(255,255,255"],
[style*="background:rgba(255, 255, 255"],
[style*="background: rgba(255, 255, 255"] {
  background: rgba(239, 249, 234, .82) !important;
  border-color: rgba(63, 127, 53, .18) !important;
}

.std-badge,
.stack-spec__label,
.product-hero__stat-label,
.app-product__spec-label,
.form-success__msg,
.form-success__title,
.related-card__desc,
.resource-card p {
  color: var(--clr-grey-dark) !important;
}

.app-hero__breadcrumb,
.app-hero__breadcrumb a {
  color: var(--clr-teal-dark) !important;
}

.app-hero__breadcrumb svg,
.product-hero__eyebrow svg,
.app-nav-link svg {
  stroke: var(--clr-teal-dark) !important;
}

.page-hero__content,
.contact-hero__content,
.app-hero__content {
  max-width: 760px;
}

@media (min-width: 1025px) {
  .section-header {
    margin-bottom: var(--sp-8);
  }

  .about-strip,
  .standards-strip,
  .cta-banner {
    padding-block: clamp(3rem, 5vw, 4.5rem);
  }

  .product-card__img {
    height: 260px;
  }

  .product-hero__visual {
    min-height: 430px;
  }
}

@media (max-width: 1024px) {
  .hero__bg {
    inset: 0;
    opacity: 1;
    box-shadow: none;
  }

  .hero-video::after {
    background:
      linear-gradient(90deg, rgba(217, 242, 208, .96) 0%, rgba(217, 242, 208, .86) 48%, rgba(45, 94, 53, .3) 100%),
      linear-gradient(180deg, rgba(15, 57, 31, .14), rgba(15, 57, 31, .16));
  }

  .hero__content {
    width: min(600px, 64vw);
  }
}

@media (max-width: 768px) {
  .nav-logo__image {
    width: 132px;
    max-height: 44px;
  }

  .hero {
    min-height: 100vh;
    min-height: 100svh;
    display: flex;
  }

  .hero__bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    opacity: 1;
  }

  .hero .container {
    min-height: 100vh;
    min-height: 100svh;
    align-items: flex-start;
    padding-top: calc(var(--nav-h) + 1rem);
    padding-bottom: 6rem;
  }

  .hero-video__media,
  .hero-video__fallback {
    object-position: center;
  }

  .hero-video::after {
    background:
      linear-gradient(180deg, rgba(217, 242, 208, .94) 0%, rgba(217, 242, 208, .9) 46%, rgba(98, 144, 76, .54) 100%),
      linear-gradient(90deg, rgba(217, 242, 208, .82), rgba(217, 242, 208, .42));
  }

  .hero__content {
    padding: 1rem;
    margin: 0;
    width: 100%;
    max-width: 100%;
    border-radius: 22px;
  }

  .hero__standards {
    max-height: 150px;
    overflow: auto;
  }

  .hero__scroll {
    left: 50%;
    bottom: 1rem;
    transform: translateX(-50%) !important;
  }

  .stats-grid,
  .app-grid {
    grid-template-columns: 1fr;
  }

  .hero__ctas,
  .cta-banner__actions {
    align-items: stretch;
  }

  .hero__ctas .btn,
  .cta-banner__actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* Readability pass: keep cards pastel, but make all card copy unmistakably dark. */
.product-card,
.feature-tile,
.product-app-tile,
.related-card,
.resource-card,
.app-tile,
.why-tile,
.sus-badge,
.solution-box,
.benefit-row,
.app-product__card,
.product-hero__stat,
.stack-spec,
.contact-info__item,
.download-card,
.value-card,
.blog-card,
.case-card {
  background: linear-gradient(180deg, rgba(250, 255, 247, .97), rgba(224, 244, 216, .95)) !important;
  border-color: rgba(42, 104, 53, .26) !important;
  color: var(--clr-ink) !important;
}

.product-card h3,
.product-card__name,
.feature-tile__title,
.product-app-tile__title,
.related-card__name,
.resource-card h3,
.resource-card h4,
.app-tile__name,
.why-tile__title,
.sus-badge__title,
.solution-box h3,
.benefit-row__title,
.app-product__card-name,
.stack-spec__value,
.download-card h3,
.value-card h3,
.blog-card h3,
.case-card h3 {
  color: #071f15 !important;
}

.product-card p,
.product-card__tagline,
.product-card__specs li,
.feature-tile__desc,
.product-app-tile__desc,
.related-card__desc,
.resource-card p,
.app-tile__desc,
.why-tile__desc,
.sus-badge__desc,
.solution-box p,
.benefit-row__desc,
.app-product__card-tagline,
.app-product__spec-label,
.stack-spec__label,
.download-card p,
.value-card p,
.blog-card p,
.case-card p {
  color: #183b2b !important;
  opacity: 1 !important;
}

.product-card__link,
.related-card__link,
.resource-card a,
.app-tile a,
.download-card a,
.blog-card a,
.case-card a {
  color: #275f2f !important;
  font-weight: 800;
}

.product-card__badge,
.std-pill,
.std-badge,
.app-product__spec,
.product-hero__stat,
.stack-spec {
  background: #f7fff4 !important;
  color: #10281e !important;
  border-color: rgba(42, 104, 53, .3) !important;
}

.product-card__img-placeholder span,
.product-overview__img-placeholder span,
.product-hero__visual-placeholder span,
.related-card__img span {
  color: #183b2b !important;
  opacity: 1 !important;
}

/* =========================================================
   RESPONSIVE HARDENING LAYER
   Cross-browser layout safety for desktop, tablet, and mobile
   ========================================================= */

html {
  min-width: 320px;
  scroll-padding-top: var(--nav-h);
}

body {
  min-width: 320px;
}

body,
section,
main,
nav,
footer,
.container,
.nav-inner,
.product-card,
.feature-tile,
.app-tile,
.why-tile,
.sus-badge,
.related-card,
.product-hero__layout,
.product-overview__layout,
.stack-callout-layout,
.about-strip-layout,
.sustainability-layout,
.app-product__layout,
.contact-page-grid,
.footer-grid {
  min-width: 0;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
button,
label,
input,
textarea,
select,
td,
th,
span,
div {
  overflow-wrap: anywhere;
  word-break: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  letter-spacing: 0 !important;
}

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

.hero-video__media,
.hero-video__fallback,
.hero__bg img,
.product-card__img img,
.product-hero__visual img,
.product-overview__img img,
.stack-callout__img img,
.about-strip__img img,
.app-hero__bg img,
.page-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btn,
.nav-link,
.mobile-menu__link,
.form-input,
.form-textarea,
.form-select,
input,
select,
textarea,
button {
  min-height: 44px;
}

.btn {
  justify-content: center;
  text-align: center;
  white-space: normal;
}

.section {
  padding-block: clamp(3.5rem, 7vw, 6rem);
}

.section-header {
  max-width: 860px;
  margin-inline: auto;
}

.section-header p {
  max-width: 66ch;
}

/* Safer default grids: keep panels aligned while allowing graceful wrapping. */
.product-cards,
.features-grid,
.app-grid,
.why-tiles,
.sustainability-badges,
.stack-specs,
.standards-pills,
.product-app-grid,
.related-grid,
.steps-row,
.benefits-list,
.resources-grid,
.downloads-grid,
.values-grid,
.blog-grid,
.case-grid,
.app-product__specs {
  min-width: 0;
}

.product-cards {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
  align-items: stretch;
}

.features-grid,
.app-grid,
.product-app-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.why-tiles,
.stack-specs,
.related-grid,
.app-product__specs,
.benefits-list {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
}

.product-card,
.feature-tile,
.why-tile,
.app-tile,
.sus-badge,
.related-card,
.product-app-tile,
.benefit-row,
.app-product__card,
.download-card,
.resource-card,
.value-card,
.blog-card,
.case-card {
  height: 100%;
}

.product-card__body,
.related-card__body,
.feature-tile,
.why-tile,
.product-app-tile,
.benefit-row {
  min-width: 0;
}

.product-card__img,
.product-hero__visual,
.product-overview__img,
.stack-callout__img,
.about-strip__img {
  aspect-ratio: 16 / 10;
  min-height: auto;
}

.product-card__tagline,
.feature-tile__desc,
.why-tile__desc,
.app-tile__desc,
.related-card__desc,
.product-app-tile__desc,
.benefit-row__desc {
  max-width: 100%;
}

.app-tile__desc {
  max-height: none;
  opacity: 1;
}

/* Desktop and small-laptop navigation alignment. */
@media (min-width: 1025px) {
  .nav-inner {
    gap: clamp(.75rem, 1.5vw, 1.5rem);
  }

  .nav-links {
    flex: 1 1 auto;
    justify-content: center;
    min-width: 0;
  }

  .nav-right,
  .nav-logo {
    flex: 0 0 auto;
  }

  .nav-dropdown {
    width: min(calc(100vw - 2rem), 900px);
    min-width: 0;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    left: 50%;
  }
}

@media (min-width: 1025px) and (max-width: 1180px) {
  .nav-inner {
    padding-inline: 1rem;
  }

  .nav-logo__image {
    width: 140px;
  }

  .nav-link {
    padding-inline: .55rem;
    font-size: .8rem;
  }

  .nav-cta {
    padding-inline: .8rem;
    font-size: .8rem;
  }

}

/* Tablet layout: one strong column where two-column blocks become cramped. */
@media (max-width: 1024px) {
  :root {
    --nav-h: 68px;
  }

  .container,
  .nav-inner {
    padding-inline: clamp(1rem, 3vw, 2rem);
  }

  .grid-2,
  .product-hero__layout,
  .product-overview__layout,
  .stack-callout-layout,
  .about-strip-layout,
  .sustainability-layout,
  .app-product__layout,
  .product-cta-layout,
  .contact-page-grid,
  .app-cta__layout,
  .app-problem__layout {
    grid-template-columns: 1fr !important;
    gap: clamp(2rem, 5vw, 3.5rem);
  }

  .product-hero__visual,
  .product-overview__img,
  .stack-callout__img,
  .about-strip__img {
    max-height: 520px;
  }

  .product-hero__layout > *,
  .product-overview__layout > *,
  .stack-callout-layout > *,
  .about-strip-layout > *,
  .sustainability-layout > * {
    min-width: 0;
  }
}

/* Phones and narrow tablets. */
@media (max-width: 768px) {
  :root {
    --fs-body: 1rem;
    --nav-h: 64px;
  }

  html,
  body {
    overflow-x: clip;
  }

  @supports not (overflow-x: clip) {
    html,
    body {
      overflow-x: hidden;
    }
  }

  .container,
  .nav-inner {
    padding-inline: 1rem;
  }

  .section {
    padding-block: clamp(3rem, 12vw, 4.5rem);
  }

  .section-header {
    margin-bottom: 2rem;
    text-align: left;
  }

  .section-header.center {
    text-align: center;
  }

  .hero,
  .product-hero,
  .app-hero,
  .page-hero,
  .contact-hero {
    min-height: auto;
  }

  .hero {
    min-height: 100vh;
    min-height: 100svh;
  }

  .product-hero,
  .app-hero,
  .page-hero,
  .contact-hero {
    padding-top: calc(var(--nav-h) + 2rem);
    padding-bottom: 3rem;
  }

  .product-hero__ctas,
  .hero__ctas,
  .cta-banner__actions,
  .app-hero__ctas,
  .product-hero__eyebrow,
  .app-nav-strip__inner,
  .footer-bottom {
    flex-direction: column;
    align-items: stretch;
  }

  .product-hero__ctas .btn,
  .hero__ctas .btn,
  .cta-banner__actions .btn,
  .app-hero__ctas .btn,
  .mobile-menu__cta {
    width: 100%;
  }

  .stats-grid,
  .product-hero__stats,
  .app-product__specs {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: .75rem;
  }

  .stat-item,
  .product-hero__stat,
  .stack-spec,
  .app-product__spec {
    padding: 1rem;
  }

  .stat-item::after {
    display: none !important;
  }

  .product-card__img,
  .product-hero__visual,
  .product-overview__img,
  .stack-callout__img,
  .about-strip__img {
    aspect-ratio: 4 / 3;
  }

  .related-card,
  .product-app-tile,
  .sus-badge,
  .benefit-row {
    flex-direction: column;
  }

  .related-card__img {
    width: 100%;
    min-height: 120px;
  }

  .standards-pills {
    justify-content: flex-start;
  }

  .std-badge,
  .std-pill {
    white-space: normal;
  }

  .mobile-menu {
    width: 100%;
    overscroll-behavior: contain;
  }

  .mobile-menu__link {
    line-height: 1.25;
  }
}

/* Very small devices. */
@media (max-width: 480px) {
  .container,
  .nav-inner {
    padding-inline: .875rem;
  }

  .nav-logo__image {
    width: 118px;
  }

  h1 {
    font-size: clamp(2rem, 11vw, 2.65rem);
  }

  h2 {
    font-size: clamp(1.55rem, 8vw, 2.1rem);
  }

  .stats-grid,
  .product-hero__stats,
  .app-product__specs,
  .stack-specs {
    grid-template-columns: 1fr !important;
  }

  .product-card__body,
  .feature-tile,
  .why-tile,
  .product-app-tile,
  .benefit-row,
  .related-card__body,
  .app-product__card {
    padding: 1.1rem;
  }

  .product-card__img,
  .product-hero__visual,
  .product-overview__img,
  .stack-callout__img,
  .about-strip__img {
    aspect-ratio: 1 / 1;
  }

  .specs-table td {
    display: block;
  }

  .specs-table td + td {
    padding-top: .25rem;
  }
}

/* Older Safari/iOS fallback for modern viewport units. */
@supports (-webkit-touch-callout: none) {
  .hero {
    min-height: -webkit-fill-available;
  }
}

/* Homepage video: full-bleed browser fit with no visible background behind it. */
.hero-video {
  background: #000 !important;
}

.hero-video::after,
.hero__bg::after,
.hero__grid-lines {
  display: none !important;
  content: none !important;
}

.hero-video__media,
.hero-video__fallback {
  object-fit: cover !important;
  object-position: center center !important;
  background: transparent !important;
}

.hero__bg img {
  object-fit: cover !important;
  object-position: center center !important;
}

@media (max-width: 1280px) {
  .hero-video__media,
  .hero-video__fallback,
  .hero__bg img {
    object-fit: cover !important;
  }
}

@media (max-width: 768px) {
  .hero-video {
    background: #000 !important;
  }
}

/* Standards strip: keep the full block centered and improve icon contrast. */
.standards-strip .container {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.standards-label {
  width: 100%;
  max-width: 820px;
  margin-inline: auto !important;
  color: #1f4d2a !important;
  text-align: center !important;
}

.standards-pills {
  width: 100%;
  max-width: 980px;
  margin-inline: auto !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center;
}

.std-badge {
  justify-content: center;
  color: #173d24 !important;
  border-color: rgba(31, 77, 42, .34) !important;
  background: rgba(247, 255, 244, .86) !important;
}

.std-badge svg {
  stroke: #235c2c !important;
  stroke-width: 2.35;
}

/* Homepage application cards: keep 8 cards balanced as 4 + 4, not 5 + 3. */
.applications-section .app-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

@media (max-width: 1024px) {
  .applications-section .app-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 560px) {
  .applications-section .app-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Watt Stack PV component section: restore readable light text on dark panel. */
.watt-stack-pv-section {
  background:
    radial-gradient(circle at 78% 36%, rgba(180, 229, 162, .13), transparent 38%),
    linear-gradient(135deg, #183821 0%, #0f2618 62%, #07180f 100%) !important;
}

.watt-stack-pv-section .label {
  color: #b4e5a2 !important;
}

.watt-stack-pv-section h2,
.watt-stack-pv-section .text-white {
  color: #f7fff4 !important;
}

.watt-stack-pv-section p {
  color: rgba(247, 255, 244, .82) !important;
}

.watt-stack-pv-section [style*="background:rgba(255,255,255"] {
  background: rgba(247, 255, 244, .08) !important;
  border-color: rgba(180, 229, 162, .25) !important;
}

.watt-stack-pv-section [style*="color:var(--clr-teal)"] {
  color: #c8f0b9 !important;
}

.watt-stack-pv-section [style*="color:rgba(255,255,255,.45)"] {
  color: rgba(247, 255, 244, .68) !important;
}

.watt-stack-pv-section svg {
  stroke: #b4e5a2 !important;
}

/* Tonal contrast pass: readable without making the site feel black-and-white. */
.label,
.section-header .label,
.why-section .label,
.stack-callout .label,
.applications-section .label,
.product-features .label,
.product-overview .label,
.product-specs .label,
.contact-main .label,
.standards-label {
  color: #3f7f35 !important;
  font-weight: 700;
  opacity: 1 !important;
}

.why-section h2,
.why-section h3,
.stack-callout h2,
.applications-section h2,
.product-features h2,
.product-overview h2,
.product-specs h2,
.section-header h2 {
  color: #163d28 !important;
}

.why-section p,
.stack-callout p,
.applications-section .section-header p,
.product-features .section-header p,
.product-overview p,
.product-specs p,
.section-header p {
  color: #46634d !important;
  opacity: 1 !important;
}

.product-card,
.feature-tile,
.product-app-tile,
.related-card,
.app-tile,
.why-tile,
.sus-badge,
.reason-card,
.tco-cell,
.contact-info__item,
.stack-spec,
.std-badge {
  color: #21482f !important;
}

.product-card__name,
.feature-tile__title,
.product-app-tile__title,
.related-card__name,
.app-tile__name,
.why-tile__title,
.sus-badge__title,
.reason-card h3,
.tco-cell__val,
.contact-info__label,
.stack-spec__value,
.std-badge {
  color: #1b402a !important;
}

.product-card__tagline,
.product-card__specs li,
.feature-tile__desc,
.product-app-tile__desc,
.related-card__desc,
.app-tile__desc,
.why-tile__desc,
.sus-badge__desc,
.reason-card p,
.tco-cell__lab,
.contact-info__value,
.stack-spec__label {
  color: #506d56 !important;
  opacity: 1 !important;
}

.feature-tile__icon svg,
.product-app-tile__icon svg,
.why-tile__icon svg,
.app-tile__icon svg,
.contact-info__icon svg,
.std-badge svg,
.spec-row svg {
  stroke: #4f8f40 !important;
  opacity: 1 !important;
}

.applications-section .app-tile {
  justify-content: flex-start !important;
  align-items: center;
  text-align: center;
  gap: var(--sp-3);
  padding: clamp(1.2rem, 2.4vw, 1.6rem) clamp(1rem, 2vw, 1.4rem) !important;
  min-height: 190px;
}

.applications-section .app-tile::before {
  pointer-events: none;
}

.applications-section .app-tile__icon {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  width: 52px !important;
  height: 52px !important;
  margin: 0 auto var(--sp-1);
  opacity: 1 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(180, 229, 162, .45);
  border: 1px solid rgba(79, 143, 64, .22);
  flex: 0 0 auto;
  z-index: 1;
}

.applications-section .app-tile__icon svg {
  width: 28px !important;
  height: 28px !important;
}

.applications-section .app-tile__name,
.applications-section .app-tile__desc {
  position: relative;
  z-index: 1;
}

.applications-section .app-tile__desc {
  margin-top: 0 !important;
}

.app-hub-card .app-hub-card__body {
  justify-content: center;
}

.app-hub-card .app-hub-card__body {
  min-height: 160px;
}

.section--dark .label,
.watt-stack-pv-section .label {
  color: #b4e5a2 !important;
}

.section--dark h1,
.section--dark h2,
.section--dark h3,
.watt-stack-pv-section h2 {
  color: #f0f8eb !important;
}

.section--dark p,
.watt-stack-pv-section p {
  color: rgba(231, 244, 224, .78) !important;
}

.product-cta .label,
.cta-banner .label,
.site-footer .label {
  color: #3f7f35 !important;
}

.product-cta h2,
.cta-banner h2,
.site-footer h3 {
  color: #163d28 !important;
}

.product-cta p,
.cta-banner p,
.site-footer p,
.site-footer a {
  color: #506d56 !important;
}

/* Page-level dark bands: readable, but softer than stark white. */
.why-hero .label,
.sus-hero .label,
.page-hero .label,
.tco-banner .label,
section[style*="background:#0a1520"] .label,
section[style*="background:var(--clr-charcoal)"] .label,
section[style*="background:linear-gradient(135deg,#0a1f14"] .label {
  color: #b4e5a2 !important;
}

.why-hero h1,
.sus-hero h1,
.page-hero h1,
.tco-banner h1,
.tco-banner h2,
section[style*="background:#0a1520"] h1,
section[style*="background:#0a1520"] h2,
section[style*="background:var(--clr-charcoal)"] h1,
section[style*="background:var(--clr-charcoal)"] h2,
section[style*="background:var(--clr-charcoal)"] h3,
section[style*="background:linear-gradient(135deg,#0a1f14"] h1,
section[style*="background:linear-gradient(135deg,#0a1f14"] h2 {
  color: #f1f8ec !important;
}

.why-hero p,
.sus-hero p,
.page-hero p,
.tco-banner p,
section[style*="background:#0a1520"] p,
section[style*="background:var(--clr-charcoal)"] p,
section[style*="background:linear-gradient(135deg,#0a1f14"] p {
  color: rgba(231, 244, 224, .78) !important;
}

.tco-banner .tco-grid {
  background: rgba(180, 229, 162, .16) !important;
}

.tco-banner .tco-cell {
  background: rgba(217, 242, 208, .11) !important;
  border-color: rgba(180, 229, 162, .22) !important;
  color: #eaf5e5 !important;
}

.tco-banner .tco-cell__val {
  color: #cbeebb !important;
}

.tco-banner .tco-cell__label {
  color: rgba(231, 244, 224, .76) !important;
}

.impact-card {
  background: rgba(217, 242, 208, .11) !important;
  border-color: rgba(180, 229, 162, .24) !important;
  color: #eaf5e5 !important;
}

.impact-card__number {
  color: var(--clr-teal-dark) !important;
}

.impact-card__unit,
.impact-card__measure {
  color: var(--clr-amber) !important;
}

.impact-card__label {
  color: rgba(231, 244, 224, .76) !important;
}

.mv-card {
  background: linear-gradient(135deg, #26583a, #1b3f2a) !important;
  border-color: rgba(180, 229, 162, .3) !important;
}

.mv-card__label {
  color: #b4e5a2 !important;
}

.mv-card h3 {
  color: #f1f8ec !important;
}

.mv-card p {
  color: rgba(231, 244, 224, .78) !important;
}

.about-proof-card,
section[style*="background:var(--clr-charcoal)"] [style*="background:rgba(255,255,255,.04)"] {
  background: rgba(217, 242, 208, .1) !important;
  border-color: rgba(180, 229, 162, .24) !important;
}

.about-proof-card__title,
section[style*="background:var(--clr-charcoal)"] [style*="color:var(--clr-white)"] {
  color: #f1f8ec !important;
}

.about-proof-card__text,
section[style*="background:var(--clr-charcoal)"] [style*="color:rgba(255,255,255,.45)"],
section[style*="background:var(--clr-charcoal)"] [style*="color:rgba(255,255,255,.65)"] {
  color: rgba(231, 244, 224, .72) !important;
}

/* Pastel page heroes: Applications and About use light refreshed hero bands. */
.page-hero .label {
  color: #4f8f40 !important;
}

.page-hero h1,
.page-hero h1 em {
  color: #1b402a !important;
}

.page-hero p {
  color: #506d56 !important;
}

.page-hero .hero-badge {
  color: #1b402a !important;
  background: rgba(247, 255, 244, .82) !important;
  border-color: rgba(63, 127, 53, .32) !important;
  box-shadow: 0 10px 24px rgba(31, 85, 43, .08);
}

.page-hero .hero-proof__value {
  color: #1b402a !important;
}

.page-hero .hero-proof__label {
  color: #3d5f45 !important;
  font-weight: 600;
}

/* Sustainability final CTA keeps its explicit dark gradient, so restore light copy there. */
.cta-banner[style*="background:linear-gradient(135deg,#0a1f14"] .label {
  color: #b4e5a2 !important;
}

.cta-banner[style*="background:linear-gradient(135deg,#0a1f14"] h2 {
  color: #f1f8ec !important;
}

.cta-banner[style*="background:linear-gradient(135deg,#0a1f14"] p {
  color: rgba(231, 244, 224, .78) !important;
}

.about-final-cta {
  text-align: center;
}

.about-final-cta h2,
.about-final-cta p {
  margin-left: auto !important;
  margin-right: auto !important;
}

.about-final-cta .btn {
  min-width: 190px;
}

.sustainability-final-cta {
  text-align: center;
  background:
    linear-gradient(111deg, transparent 0 18%, rgba(180, 229, 162, .22) 18.2% 30%, transparent 30.2% 100%),
    linear-gradient(111deg, transparent 0 67%, rgba(217, 242, 208, .36) 67.2% 82%, transparent 82.2% 100%),
    linear-gradient(90deg, #0f3b26 0%, #17472b 55%, #235f38 100%) !important;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(180, 229, 162, .45);
  border-bottom: 1px solid rgba(63, 127, 53, .18);
}

.sustainability-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(90deg, rgba(0,0,0,.7), transparent 68%);
}

.sustainability-final-cta .container {
  position: relative;
  z-index: 1;
  max-width: 940px;
}

.sustainability-final-cta .label {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  color: #d9f2d0 !important;
  background: rgba(13, 59, 43, .72);
  border: 1px solid rgba(180, 229, 162, .34);
  border-radius: 999px;
  padding: .42rem .85rem;
  font-weight: 800;
  text-shadow: 0 1px 10px rgba(0,0,0,.22);
}

.sustainability-final-cta h2 {
  color: #f7fff4 !important;
  text-shadow: 0 2px 18px rgba(7, 33, 20, .22);
}

.sustainability-final-cta .cta-accent {
  display: inline-block;
}

.sustainability-final-cta .cta-accent--mint {
  color: #b4e5a2;
}

.sustainability-final-cta .cta-accent--gold {
  color: #f2d36b;
}

.sustainability-final-cta p {
  color: #d9f2d0 !important;
}

.sustainability-final-cta .sustainability-final-copy {
  display: block;
  color: #e9f7e3 !important;
  background: transparent !important;
  border: 0;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  text-shadow: none;
  max-width: 58ch !important;
  line-height: 1.65;
}

.sustainability-final-cta .sustainability-final-copy span {
  color: #f2d36b;
}

.sustainability-final-cta .btn--primary {
  background: #b4e5a2 !important;
  border-color: #b4e5a2 !important;
  color: #102d1d !important;
  box-shadow: 0 16px 34px rgba(12, 45, 28, .26);
}

.sustainability-final-cta .btn--outline {
  background: rgba(255,255,255,.92) !important;
  border-color: rgba(16, 45, 29, .2) !important;
  color: #102d1d !important;
}

.sustainability-final-cta .btn--primary:hover,
.sustainability-final-cta .btn--outline:hover {
  transform: translateY(-2px);
}

.sustainability-final-cta h2,
.sustainability-final-cta p {
  margin-left: auto !important;
  margin-right: auto !important;
}

.sustainability-final-cta .btn {
  min-width: 190px;
}

.applications-final-cta {
  text-align: center;
}

.applications-final-cta h2 {
  color: #1b402a !important;
}

.applications-final-cta p {
  color: #506d56 !important;
}

.applications-final-cta h2,
.applications-final-cta p {
  margin-left: auto !important;
  margin-right: auto !important;
}

.applications-final-cta .btn {
  min-width: 210px;
}

/* Applications sector atlas: replace ordinary cards with a modern industrial mosaic. */
.app-hub-grid {
  counter-reset: sector-card;
  grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
  gap: clamp(1rem, 2vw, 1.5rem) !important;
  align-items: stretch;
  padding: clamp(1rem, 2.5vw, 1.5rem);
  border: 1px solid rgba(63, 127, 53, .16);
  border-radius: 24px;
  background:
    radial-gradient(circle at 12% 14%, rgba(180, 229, 162, .5), transparent 28%),
    radial-gradient(circle at 88% 74%, rgba(217, 242, 208, .72), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.72), rgba(217,242,208,.62));
  box-shadow: 0 22px 56px rgba(31, 85, 43, .12);
}

.app-hub-card {
  counter-increment: sector-card;
  position: relative;
  grid-column: span 6;
  display: grid !important;
  grid-template-columns: minmax(110px, .32fr) 1fr;
  min-height: 236px;
  overflow: hidden;
  border: 1px solid rgba(63, 127, 53, .2) !important;
  border-radius: 20px !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(235,248,229,.82) 48%, rgba(198,231,185,.64)) !important;
  box-shadow: 0 12px 32px rgba(35, 91, 50, .1) !important;
  transform: none !important;
}

.app-hub-card::before {
  content: "0" counter(sector-card);
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 2;
  font-family: var(--font-head);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  color: rgba(63, 127, 53, .62);
}

.app-hub-card::after {
  content: "";
  position: absolute;
  inset: auto 1.2rem 1rem auto;
  width: 80px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(63, 127, 53, .35));
}

.app-hub-card:hover {
  box-shadow: 0 18px 44px rgba(35, 91, 50, .16) !important;
  transform: translateY(-3px) !important;
}

.app-hub-card__img {
  height: auto !important;
  min-height: 100%;
  background:
    linear-gradient(160deg, rgba(63, 127, 53, .16), rgba(180, 229, 162, .2)),
    linear-gradient(135deg, #e5f4df, #ccebc0) !important;
  border-right: 1px solid rgba(63, 127, 53, .16);
}

.app-hub-card__img img {
  width: clamp(66px, 8vw, 96px) !important;
  height: clamp(66px, 8vw, 96px) !important;
  object-fit: contain !important;
  opacity: .7 !important;
  filter: saturate(.82) contrast(.94);
}

.app-hub-card__body {
  justify-content: center;
  padding: clamp(1.35rem, 2.8vw, 2.15rem) !important;
}

.app-hub-card__name {
  color: #1d4f31 !important;
  font-size: clamp(1.08rem, 1.4vw, 1.35rem) !important;
  margin-bottom: .65rem !important;
}

.app-hub-card__desc {
  color: #506d56 !important;
  font-size: .94rem !important;
  line-height: 1.72 !important;
  margin-bottom: 0 !important;
}

.app-hub-card:nth-child(3),
.app-hub-card:nth-child(7) {
  grid-column: span 12;
  grid-template-columns: minmax(160px, .22fr) 1fr;
  min-height: 250px;
  background:
    linear-gradient(135deg, rgba(218, 243, 208, .86), rgba(255,255,255,.86) 46%, rgba(180,229,162,.52)) !important;
}

.app-hub-card:nth-child(4),
.app-hub-card:nth-child(5),
.app-hub-card:nth-child(6) {
  grid-column: span 4;
  grid-template-columns: 1fr;
  min-height: 310px;
}

.app-hub-card:nth-child(4) .app-hub-card__img,
.app-hub-card:nth-child(5) .app-hub-card__img,
.app-hub-card:nth-child(6) .app-hub-card__img {
  min-height: 112px;
  border-right: 0;
  border-bottom: 1px solid rgba(63, 127, 53, .16);
}

@media (max-width: 1024px) {
  .app-hub-card,
  .app-hub-card:nth-child(4),
  .app-hub-card:nth-child(5),
  .app-hub-card:nth-child(6) {
    grid-column: span 6;
    grid-template-columns: minmax(100px, .34fr) 1fr;
    min-height: 230px;
  }

  .app-hub-card:nth-child(3),
  .app-hub-card:nth-child(7) {
    grid-column: span 12;
  }

  .app-hub-card:nth-child(4) .app-hub-card__img,
  .app-hub-card:nth-child(5) .app-hub-card__img,
  .app-hub-card:nth-child(6) .app-hub-card__img {
    min-height: 100%;
    border-right: 1px solid rgba(63, 127, 53, .16);
    border-bottom: 0;
  }
}

@media (max-width: 700px) {
  .app-hub-grid {
    padding: .8rem;
    border-radius: 18px;
  }

  .app-hub-card,
  .app-hub-card:nth-child(3),
  .app-hub-card:nth-child(4),
  .app-hub-card:nth-child(5),
  .app-hub-card:nth-child(6),
  .app-hub-card:nth-child(7) {
    grid-column: span 12;
    grid-template-columns: 82px 1fr;
    min-height: 0;
    border-radius: 16px !important;
  }

  .app-hub-card__img,
  .app-hub-card:nth-child(4) .app-hub-card__img,
  .app-hub-card:nth-child(5) .app-hub-card__img,
  .app-hub-card:nth-child(6) .app-hub-card__img {
    min-height: 100%;
    border-right: 1px solid rgba(63, 127, 53, .16);
    border-bottom: 0;
  }

  .app-hub-card__body {
    padding: 1.15rem 1rem !important;
  }

  .app-hub-card::before {
    top: .75rem;
    right: .75rem;
    font-size: .7rem;
  }
}

/* Applications sector wheel: circular ecosystem view with Watt Wagon at the center. */
.app-hub-grid {
  position: relative;
  width: min(92vw, 860px);
  aspect-ratio: 1;
  margin: 0 auto;
  padding: 0 !important;
  display: block !important;
  border-radius: 50%;
  border: 1px solid rgba(63, 127, 53, .22);
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 17%, rgba(255,255,255,0) 18%),
    conic-gradient(
      from -90deg,
      rgba(180,229,162,.96) 0deg 51.42deg,
      rgba(217,242,208,.96) 51.42deg 102.84deg,
      rgba(159,212,142,.9) 102.84deg 154.26deg,
      rgba(231,246,224,.98) 154.26deg 205.68deg,
      rgba(188,226,174,.92) 205.68deg 257.1deg,
      rgba(221,241,213,.98) 257.1deg 308.52deg,
      rgba(148,201,132,.88) 308.52deg 360deg
    ) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.48),
    inset 0 0 0 108px rgba(255,255,255,.13),
    0 28px 70px rgba(31, 85, 43, .16);
  overflow: visible;
}

.app-hub-grid::before {
  content: "";
  position: absolute;
  inset: 15.5%;
  z-index: 1;
  border-radius: 50%;
  border: 1px solid rgba(63, 127, 53, .18);
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.9), transparent 24%),
    linear-gradient(135deg, #f7fff4, #d9f2d0);
  box-shadow: 0 18px 44px rgba(31, 85, 43, .15);
}

.app-hub-grid::after {
  content: "Watt\A Wagon";
  white-space: pre;
  position: absolute;
  inset: 34%;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #fff, #e5f6dd);
  border: 1px solid rgba(63, 127, 53, .22);
  box-shadow: 0 14px 34px rgba(31, 85, 43, .18);
  color: #1b402a;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(1.05rem, 2.1vw, 1.8rem);
  line-height: 1.08;
  text-align: center;
}

.app-hub-card,
.app-hub-card:nth-child(3),
.app-hub-card:nth-child(4),
.app-hub-card:nth-child(5),
.app-hub-card:nth-child(6),
.app-hub-card:nth-child(7) {
  position: absolute !important;
  z-index: 3;
  width: clamp(145px, 19vw, 218px) !important;
  min-height: 0 !important;
  display: block !important;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .74) !important;
  box-shadow: 0 12px 28px rgba(31, 85, 43, .12) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transform: translate(-50%, -50%) !important;
  transition: transform var(--t-mid), box-shadow var(--t-mid), background var(--t-mid);
}

.app-hub-card:hover {
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 18px 42px rgba(31, 85, 43, .2) !important;
  transform: translate(-50%, -50%) scale(1.035) !important;
}

.app-hub-card::before {
  top: 50%;
  left: -16px;
  right: auto;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-50%);
  border-radius: 50%;
  background: #f7fff4;
  border: 1px solid rgba(63, 127, 53, .22);
  color: #4f8f40;
  font-size: .66rem;
}

.app-hub-card::after {
  display: none;
}

.app-hub-card__img {
  position: absolute;
  top: 50%;
  left: 18px;
  width: 42px;
  height: 42px;
  min-height: 0 !important;
  transform: translateY(-50%);
  border: 0 !important;
  background: transparent !important;
}

.app-hub-card__img img {
  width: 34px !important;
  height: 34px !important;
  opacity: .55 !important;
}

.app-hub-card__body {
  padding: .9rem 1rem .9rem 4rem !important;
}

.app-hub-card__name {
  margin: 0 !important;
  color: #1d4f31 !important;
  font-size: clamp(.88rem, 1.15vw, 1.02rem) !important;
  line-height: 1.15 !important;
}

.app-hub-card__desc {
  position: absolute;
  left: 50%;
  top: calc(100% + .65rem);
  width: min(310px, 74vw);
  max-width: none !important;
  margin: 0 !important;
  padding: .9rem 1rem;
  border-radius: 14px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(63, 127, 53, .18);
  box-shadow: 0 14px 34px rgba(31, 85, 43, .14);
  color: #506d56 !important;
  font-size: .78rem !important;
  line-height: 1.55 !important;
  opacity: 0 !important;
  pointer-events: none;
  transform: translate(-50%, -8px);
  transition: opacity var(--t-fast), transform var(--t-fast);
}

.app-hub-card:hover .app-hub-card__desc,
.app-hub-card:focus-within .app-hub-card__desc {
  opacity: 1 !important;
  transform: translate(-50%, 0);
}

.app-hub-card:nth-child(1) { left: 50%; top: 7%; }
.app-hub-card:nth-child(2) { left: 82%; top: 23%; }
.app-hub-card:nth-child(3) { left: 88%; top: 56%; }
.app-hub-card:nth-child(4) { left: 68%; top: 88%; }
.app-hub-card:nth-child(5) { left: 32%; top: 88%; }
.app-hub-card:nth-child(6) { left: 12%; top: 56%; }
.app-hub-card:nth-child(7) { left: 18%; top: 23%; }

@media (max-width: 760px) {
  .app-hub-grid {
    width: min(94vw, 560px);
    min-height: 760px;
    aspect-ratio: auto;
    border-radius: 28px;
    background:
      radial-gradient(circle at 50% 130px, rgba(255,255,255,.98) 0 78px, rgba(255,255,255,0) 80px),
      linear-gradient(135deg, rgba(255,255,255,.78), rgba(217,242,208,.76)) !important;
    box-shadow: 0 20px 50px rgba(31, 85, 43, .13);
  }

  .app-hub-grid::before {
    inset: 34px auto auto 50%;
    width: 160px;
    height: 160px;
    transform: translateX(-50%);
  }

  .app-hub-grid::after {
    inset: 72px auto auto 50%;
    width: 84px;
    height: 84px;
    transform: translateX(-50%);
    font-size: .92rem;
  }

  .app-hub-card,
  .app-hub-card:nth-child(3),
  .app-hub-card:nth-child(4),
  .app-hub-card:nth-child(5),
  .app-hub-card:nth-child(6),
  .app-hub-card:nth-child(7) {
    left: 50% !important;
    top: auto !important;
    width: calc(100% - 2rem) !important;
    transform: translateX(-50%) !important;
  }

  .app-hub-card:hover {
    transform: translateX(-50%) !important;
  }

  .app-hub-card:nth-child(1) { top: 230px !important; }
  .app-hub-card:nth-child(2) { top: 306px !important; }
  .app-hub-card:nth-child(3) { top: 382px !important; }
  .app-hub-card:nth-child(4) { top: 458px !important; }
  .app-hub-card:nth-child(5) { top: 534px !important; }
  .app-hub-card:nth-child(6) { top: 610px !important; }
  .app-hub-card:nth-child(7) { top: 686px !important; }

  .app-hub-card__desc {
    display: none;
  }
}

/* Product feature and application wheels: replaces repeated card grids with a circular system view. */
.product-features .features-grid,
.product-applications .product-app-grid {
  position: relative;
  width: min(92vw, 860px);
  aspect-ratio: 1;
  margin: 0 auto;
  padding: 0 !important;
  display: block !important;
  border-radius: 50%;
  border: 1px solid rgba(70, 133, 61, .22);
  background:
    radial-gradient(circle at center, rgba(255,255,255,.98) 0 17%, rgba(255,255,255,0) 18%),
    conic-gradient(
      from -90deg,
      rgba(180,229,162,.95) 0deg 45deg,
      rgba(217,242,208,.96) 45deg 90deg,
      rgba(155,209,139,.88) 90deg 135deg,
      rgba(229,246,223,.98) 135deg 180deg,
      rgba(188,226,174,.94) 180deg 225deg,
      rgba(217,242,208,.96) 225deg 270deg,
      rgba(144,199,127,.86) 270deg 315deg,
      rgba(231,248,225,.98) 315deg 360deg
    ) !important;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.5),
    inset 0 0 0 108px rgba(255,255,255,.13),
    0 28px 70px rgba(31, 85, 43, .15);
  overflow: visible;
}

.product-features .features-grid::before,
.product-applications .product-app-grid::before {
  content: "";
  position: absolute;
  inset: 15.5%;
  z-index: 1;
  border-radius: 50%;
  border: 1px solid rgba(70, 133, 61, .18);
  background:
    radial-gradient(circle at 35% 28%, rgba(255,255,255,.88), transparent 24%),
    linear-gradient(135deg, #f7fff4, #d9f2d0);
  box-shadow: 0 18px 44px rgba(31, 85, 43, .14);
}

.product-features .features-grid::after,
.product-applications .product-app-grid::after {
  white-space: pre;
  position: absolute;
  inset: 34%;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #fff, #e5f6dd);
  border: 1px solid rgba(70, 133, 61, .22);
  box-shadow: 0 14px 34px rgba(31, 85, 43, .17);
  color: #1b402a;
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(1rem, 2vw, 1.75rem);
  line-height: 1.08;
  text-align: center;
}

.product-features .features-grid::after {
  content: "Key\A Features";
}

.product-applications .product-app-grid::after {
  content: "Site\A Applications";
}

.product-features .feature-tile,
.product-applications .product-app-tile {
  position: absolute !important;
  z-index: 3;
  width: clamp(150px, 19vw, 224px) !important;
  height: auto !important;
  min-height: 0 !important;
  padding: .9rem 1rem !important;
  display: flex !important;
  align-items: center;
  gap: .72rem;
  overflow: visible !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .76) !important;
  box-shadow: 0 12px 28px rgba(31, 85, 43, .12) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transform: translate(-50%, -50%) !important;
  transition: transform var(--t-mid), box-shadow var(--t-mid), background var(--t-mid);
}

.product-features .feature-tile:hover,
.product-applications .product-app-tile:hover,
.product-applications .product-app-tile:focus-visible {
  background: rgba(255, 255, 255, .94) !important;
  box-shadow: 0 18px 42px rgba(31, 85, 43, .2) !important;
  transform: translate(-50%, -50%) scale(1.035) !important;
}

.product-features .feature-tile__icon,
.product-applications .product-app-tile__icon {
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  margin: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #f7fff4 !important;
  border: 1px solid rgba(70, 133, 61, .22);
  color: #4f8f40 !important;
}

.product-features .feature-tile__icon svg,
.product-applications .product-app-tile__icon svg {
  width: 21px;
  height: 21px;
  stroke: currentColor;
}

.product-features .feature-tile__title,
.product-applications .product-app-tile__title {
  margin: 0 !important;
  color: #1d4f31 !important;
  font-size: clamp(.88rem, 1.08vw, 1rem) !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
}

.product-applications .product-app-tile > div:last-child {
  min-width: 0;
}

/* Keep feature wheel labels lighter and less bulky than application labels. */
.product-features .feature-tile {
  width: clamp(122px, 15vw, 174px) !important;
  height: auto !important;
  padding: .58rem .68rem !important;
  gap: .48rem !important;
}

.product-features .feature-tile__icon {
  flex: 0 0 30px !important;
  width: 30px !important;
  height: 30px !important;
}

.product-features .feature-tile__icon svg {
  width: 16px !important;
  height: 16px !important;
}

.product-features .feature-tile__title {
  font-size: clamp(.72rem, .88vw, .86rem) !important;
  line-height: 1.12 !important;
}

.product-features .feature-tile__desc,
.product-applications .product-app-tile__desc {
  position: absolute;
  left: 50%;
  top: calc(100% + .65rem);
  width: min(320px, 74vw);
  max-width: none !important;
  margin: 0 !important;
  padding: .9rem 1rem;
  border-radius: 14px;
  background: rgba(255,255,255,.97);
  border: 1px solid rgba(70, 133, 61, .18);
  box-shadow: 0 14px 34px rgba(31, 85, 43, .14);
  color: #506d56 !important;
  font-size: .78rem !important;
  line-height: 1.55 !important;
  opacity: 0 !important;
  pointer-events: none;
  transform: translate(-50%, -8px);
  transition: opacity var(--t-fast), transform var(--t-fast);
}

.product-features .feature-tile:hover .feature-tile__desc,
.product-features .feature-tile:focus-within .feature-tile__desc,
.product-applications .product-app-tile:hover .product-app-tile__desc,
.product-applications .product-app-tile:focus-within .product-app-tile__desc {
  opacity: 1 !important;
  transform: translate(-50%, 0);
}

.product-features .feature-tile:nth-child(1) { left: 50%; top: 6%; }
.product-features .feature-tile:nth-child(2) { left: 78%; top: 18%; }
.product-features .feature-tile:nth-child(3) { left: 94%; top: 43%; }
.product-features .feature-tile:nth-child(4) { left: 82%; top: 74%; }
.product-features .feature-tile:nth-child(5) { left: 50%; top: 94%; }
.product-features .feature-tile:nth-child(6) { left: 18%; top: 74%; }
.product-features .feature-tile:nth-child(7) { left: 6%; top: 43%; }
.product-features .feature-tile:nth-child(8) { left: 22%; top: 18%; }

.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(1) { left: 50%; top: 7%; }
.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(2) { left: 82%; top: 25%; }
.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(3) { left: 82%; top: 75%; }
.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(4) { left: 50%; top: 93%; }
.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(5) { left: 18%; top: 75%; }
.product-features .features-grid:has(.feature-tile:nth-child(6):last-child) .feature-tile:nth-child(6) { left: 18%; top: 25%; }

.product-applications .product-app-tile:nth-child(1) { left: 50%; top: 7%; }
.product-applications .product-app-tile:nth-child(2) { left: 82%; top: 25%; }
.product-applications .product-app-tile:nth-child(3) { left: 82%; top: 75%; }
.product-applications .product-app-tile:nth-child(4) { left: 50%; top: 93%; }
.product-applications .product-app-tile:nth-child(5) { left: 18%; top: 75%; }
.product-applications .product-app-tile:nth-child(6) { left: 18%; top: 25%; }

@media (max-width: 900px) {
  .product-features .features-grid,
  .product-applications .product-app-grid {
    width: min(94vw, 680px);
  }

  .product-features .feature-tile,
  .product-applications .product-app-tile {
    width: clamp(138px, 24vw, 190px) !important;
    padding: .78rem .88rem !important;
  }

  .product-features .feature-tile {
    width: clamp(118px, 21vw, 160px) !important;
    padding: .54rem .62rem !important;
  }

  .product-features .feature-tile__icon,
  .product-applications .product-app-tile__icon {
    flex-basis: 34px;
    width: 34px;
    height: 34px;
  }

  .product-features .feature-tile__icon {
    flex-basis: 28px !important;
    width: 28px !important;
    height: 28px !important;
  }

  .product-features .feature-tile__title {
    font-size: .76rem !important;
  }
}

@media (max-width: 760px) {
  .product-features .features-grid,
  .product-applications .product-app-grid {
    width: min(94vw, 560px);
    min-height: 720px;
    aspect-ratio: auto;
    border-radius: 28px;
    background:
      radial-gradient(circle at 50% 130px, rgba(255,255,255,.98) 0 78px, rgba(255,255,255,0) 80px),
      linear-gradient(135deg, rgba(255,255,255,.78), rgba(217,242,208,.76)) !important;
    box-shadow: 0 20px 50px rgba(31, 85, 43, .13);
  }

  .product-features .features-grid::before,
  .product-applications .product-app-grid::before {
    inset: 34px auto auto 50%;
    width: 160px;
    height: 160px;
    transform: translateX(-50%);
  }

  .product-features .features-grid::after,
  .product-applications .product-app-grid::after {
    inset: 72px auto auto 50%;
    width: 84px;
    height: 84px;
    transform: translateX(-50%);
    font-size: .88rem;
  }

  .product-features .feature-tile,
  .product-applications .product-app-tile {
    left: 50% !important;
    top: auto !important;
    width: calc(100% - 2rem) !important;
    transform: translateX(-50%) !important;
  }

  .product-features .feature-tile {
    width: calc(100% - 2.4rem) !important;
    padding: .64rem .78rem !important;
  }

  .product-features .feature-tile__icon {
    flex-basis: 32px !important;
    width: 32px !important;
    height: 32px !important;
  }

  .product-features .feature-tile__title {
    font-size: .84rem !important;
  }

  .product-features .feature-tile:hover,
  .product-applications .product-app-tile:hover,
  .product-applications .product-app-tile:focus-visible {
    transform: translateX(-50%) !important;
  }

  .product-features .feature-tile:nth-child(1),
  .product-applications .product-app-tile:nth-child(1) { top: 230px !important; }
  .product-features .feature-tile:nth-child(2),
  .product-applications .product-app-tile:nth-child(2) { top: 306px !important; }
  .product-features .feature-tile:nth-child(3),
  .product-applications .product-app-tile:nth-child(3) { top: 382px !important; }
  .product-features .feature-tile:nth-child(4),
  .product-applications .product-app-tile:nth-child(4) { top: 458px !important; }
  .product-features .feature-tile:nth-child(5),
  .product-applications .product-app-tile:nth-child(5) { top: 534px !important; }
  .product-features .feature-tile:nth-child(6),
  .product-applications .product-app-tile:nth-child(6) { top: 610px !important; }
  .product-features .feature-tile:nth-child(7) { top: 686px !important; }
  .product-features .feature-tile:nth-child(8) { top: 762px !important; }

  .product-features .features-grid:has(.feature-tile:nth-child(7)) {
    min-height: 860px;
  }

  .product-features .feature-tile__desc,
  .product-applications .product-app-tile__desc {
    display: none;
  }
}

/* Accessibility and low-power browser settings. */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}

/* ----------------------------------------------------------
   Site-wide alignment hardening.
   Keeps the existing theme intact while making every major
   section, grid, card, table, form, and CTA behave consistently
   across desktop, tablet, and mobile.
   ---------------------------------------------------------- */
html,
body {
  width: 100%;
  max-width: 100%;
}

body {
  overflow-x: hidden;
}

body > * {
  min-width: 0;
}

.site-nav,
.mobile-menu,
main,
section,
footer {
  max-width: 100vw;
}

.container,
.nav-inner {
  width: min(100%, var(--max-w));
  margin-inline: auto;
  padding-inline: clamp(1rem, 3.5vw, 1.5rem);
}

.container--narrow {
  width: min(100%, var(--max-w-narrow));
}

.section,
.page-hero,
.product-hero,
.cta-banner {
  position: relative;
}

.section > .container,
.page-hero > .container,
.product-hero > .container,
.cta-banner > .container {
  position: relative;
  z-index: 1;
}

.section-header,
.page-hero__content,
.product-overview__text,
.product-cta__text,
.sustainability-final-cta,
.about-final-cta,
.applications-final-cta {
  min-width: 0;
}

.section-header.center,
.section-header.center > *,
.cta-banner .container,
.applications-final-cta .container,
.sustainability-final-cta .container,
.about-final-cta .container {
  text-align: center;
}

.section-header.center p,
.cta-banner p,
.applications-final-cta p,
.sustainability-final-cta p,
.about-final-cta p {
  margin-inline: auto;
}

.hero__ctas,
.product-hero__ctas,
.app-hero__ctas,
.product-cta .btn,
.apps-cta,
.cta-banner .btn,
.applications-final-cta .btn,
.sustainability-final-cta .btn,
.about-final-cta .btn {
  max-width: 100%;
}

.btn {
  justify-content: center;
  min-height: 44px;
  max-width: 100%;
  text-align: center;
}

.nav-logo,
.nav-right,
.nav-links {
  min-width: 0;
}

.nav-logo__image {
  max-width: min(205px, 42vw);
  height: auto;
  object-fit: contain;
}

.nav-dropdown {
  width: min(calc(100vw - 2rem), 900px) !important;
  min-width: 0 !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.nav-dropdown__item,
.nav-dropdown__title,
.nav-dropdown__desc,
.nav-dropdown__spec {
  min-width: 0;
}

.nav-dropdown__desc,
.nav-dropdown__spec {
  overflow-wrap: anywhere;
}

.stats-grid,
.product-cards,
.why-layout,
.why-tiles,
.app-grid,
.sustainability-layout,
.sustainability-badges,
.stack-callout-layout,
.stack-specs,
.standards-pills,
.about-strip-layout,
.footer-grid,
.contact-page-grid,
.product-hero__layout,
.product-hero__stats,
.product-overview__layout,
.product-cta-layout,
.related-grid,
.app-hub-grid,
.pillar-row,
.impact-grid,
.values-grid,
.architecture-grid {
  width: 100%;
  min-width: 0;
}

.stats-grid,
.product-cards,
.app-grid,
.sustainability-badges,
.stack-specs,
.standards-pills,
.related-grid,
.impact-grid,
.values-grid,
.architecture-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.product-cards,
.app-hub-grid,
.related-grid,
.footer-grid,
.contact-page-grid {
  align-items: stretch;
}

.product-card,
.app-hub-card,
.related-card,
.why-tile,
.sus-badge,
.stack-spec,
.std-badge,
.impact-card,
.value-card,
.architecture-card,
.contact-card,
.form-card {
  min-width: 0;
}

.product-card,
.app-hub-card,
.related-card,
.contact-card,
.form-card {
  height: 100%;
}

.product-card__body,
.app-hub-card__body,
.related-card__body {
  min-width: 0;
}

.product-card__name,
.app-hub-card__name,
.related-card__name,
.feature-tile__title,
.why-tile__title,
.sus-badge__title,
.footer-col__heading {
  overflow-wrap: anywhere;
}

.product-card__tagline,
.product-card__specs,
.app-hub-card__desc,
.related-card__desc,
.why-tile__desc,
.sus-badge__sub,
.footer-brand__desc,
.footer-col__link {
  max-width: 100%;
}

.product-card__img,
.product-hero__visual,
.stack-callout__img,
.app-hub-card__img {
  width: 100%;
}

.product-card__img img,
.product-hero__visual img,
.stack-callout__img img,
.app-hub-card__img img {
  max-width: 100%;
}

.related-card__img img {
  width: 100%;
  height: 100%;
  min-height: 170px;
  object-fit: contain;
  padding: clamp(0.75rem, 2vw, 1.15rem);
}

.related-card__img {
  background: linear-gradient(135deg, rgba(217, 242, 208, 0.95), rgba(255, 255, 255, 0.94));
}

.product-hero__stats,
.stack-specs,
.standards-pills {
  justify-content: center;
}

.standards-pills {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.std-badge {
  justify-content: center;
  text-align: center;
}

.product-specs .container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.specs-table,
.comparison-table {
  width: 100%;
}

.specs-table th,
.specs-table td,
.comparison-table th,
.comparison-table td {
  vertical-align: middle;
}

.contact-form,
.form-row,
.form-group,
.form-input,
.form-select,
.form-textarea {
  min-width: 0;
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
}

.footer-grid {
  grid-template-columns: minmax(260px, 1.4fr) repeat(3, minmax(160px, 1fr));
}

.footer-bottom {
  gap: var(--sp-4);
}

@media (max-width: 1180px) {
  .nav-dropdown {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: min(calc(100vw - 2rem), 620px) !important;
  }

  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .hero__content,
  .page-hero__content,
  .product-hero__layout > *,
  .why-layout > *,
  .sustainability-layout > *,
  .stack-callout-layout > *,
  .about-strip-layout > *,
  .product-cta-layout > *,
  .contact-page-grid > * {
    max-width: 100%;
  }

  .product-hero__layout,
  .why-layout,
  .sustainability-layout,
  .stack-callout-layout,
  .about-strip-layout,
  .product-cta-layout,
  .contact-page-grid,
  .pillar-row {
    grid-template-columns: 1fr !important;
  }

  .product-hero__visual,
  .stack-callout__img {
    max-width: min(100%, 760px);
    margin-inline: auto;
  }
}

@media (max-width: 768px) {
  .container,
  .nav-inner {
    padding-inline: clamp(1rem, 5vw, 1.25rem);
  }

  .section {
    padding-block: clamp(3rem, 11vw, 4.5rem);
  }

  .page-hero,
  .product-hero {
    padding-top: calc(var(--nav-h) + clamp(2rem, 8vw, 3rem)) !important;
  }

  .section-header {
    margin-bottom: clamp(2rem, 8vw, 3rem);
  }

  .product-cards,
  .app-hub-grid,
  .stats-grid,
  .app-grid,
  .sustainability-badges,
  .stack-specs,
  .standards-pills,
  .impact-grid,
  .values-grid,
  .architecture-grid,
  .related-grid {
    grid-template-columns: 1fr !important;
  }

  .impact-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    width: min(100%, 340px) !important;
    max-width: calc(100vw - 2.5rem) !important;
    margin-inline: auto !important;
  }

  .impact-card {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    padding: clamp(1.25rem, 5vw, 2rem) !important;
  }

  .impact-card__number,
  .impact-card__label {
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .product-hero__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .hero__ctas,
  .product-hero__ctas,
  .app-hero__ctas,
  .cta-banner .container > div,
  .footer-bottom {
    align-items: stretch;
  }

  .hero__ctas .btn,
  .product-hero__ctas .btn,
  .app-hero__ctas .btn,
  .cta-banner .btn,
  .applications-final-cta .btn,
  .sustainability-final-cta .btn,
  .about-final-cta .btn {
    width: 100%;
  }

  .form-row {
    flex-direction: column;
  }

  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }

  .specs-table,
  .comparison-table {
    min-width: 640px;
  }
}

@media (max-width: 560px) {
  .product-hero__stats {
    grid-template-columns: 1fr !important;
  }

  .nav-logo__image {
    max-width: min(170px, 58vw);
  }

  .btn {
    width: 100%;
  }
}

/* Final corrections for absolute-positioned wheel cards and narrow hero text. */
.app-hub-grid .app-hub-card {
  height: auto !important;
  max-height: none !important;
}

.app-hub-grid .app-hub-card__body {
  height: auto !important;
}

.product-hero h1,
.product-hero h1 em,
.page-hero h1,
.page-hero h1 em,
.sus-hero h1,
.sus-hero h1 em,
.why-hero h1,
.why-hero h1 em,
.app-hero h1,
.app-hero h1 em,
.contact-hero h1,
.contact-hero h1 em,
.product-hero__tagline {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal !important;
}

.page-hero__content,
.page-hero__content h1,
.page-hero__content p,
.sus-hero__content,
.sus-hero__content h1,
.sus-hero__content p,
.why-hero__content,
.why-hero__content h1,
.why-hero__content p {
  width: 100%;
  max-width: min(100%, 760px) !important;
}

@media (max-width: 560px) {
  .page-hero {
    overflow: visible !important;
  }

  .page-hero .container,
  .page-hero__content,
  .page-hero__content h1,
  .page-hero__content p,
  .sus-hero .container,
  .sus-hero__content,
  .sus-hero__content h1,
  .sus-hero__content p,
  .why-hero .container,
  .why-hero__content,
  .why-hero__content h1,
  .why-hero__content p {
    max-width: min(100%, 300px) !important;
  }

  .page-hero h1,
  .sus-hero h1,
  .why-hero h1 {
    font-size: clamp(1.85rem, 8.2vw, 2.05rem) !important;
  }

  .app-hub-grid,
  .product-features .features-grid,
  .product-applications .product-app-grid {
    width: 100% !important;
  }

  .product-hero h1,
  .app-hero h1,
  .contact-hero h1 {
    font-size: clamp(2rem, 9.4vw, 2.35rem);
    line-height: 1.12;
  }

  .product-hero h1 em,
  .page-hero h1 em,
  .sus-hero h1 em,
  .why-hero h1 em,
  .app-hero h1 em,
  .contact-hero h1 em {
    display: block;
  }

  .product-hero__tagline,
  .page-hero p,
  .app-hero__intro,
  .contact-hero p {
    font-size: 1rem;
    line-height: 1.65;
  }
}

/* Bootstrap-like responsive product specifications: table on desktop, cards on smaller devices. */
.product-specs .container {
  overflow-x: visible !important;
}

.product-specs .specs-table {
  width: 100% !important;
  min-width: 0 !important;
  table-layout: fixed;
}

.product-specs .specs-table th:first-child,
.product-specs .specs-table td:first-child {
  width: 34%;
}

.product-specs .specs-table th,
.product-specs .specs-table td {
  overflow-wrap: anywhere;
  word-break: normal;
}

@media (max-width: 900px) {
  .product-specs .specs-table {
    display: block !important;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
  }

  .product-specs .specs-table thead {
    display: none !important;
  }

  .product-specs .specs-table tbody {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--sp-4);
    width: 100%;
  }

  .product-specs .specs-table tr {
    display: flex !important;
    flex-direction: column;
    min-width: 0;
    margin: 0 !important;
    border: 1px solid var(--clr-border);
    border-radius: var(--r-md);
    overflow: hidden;
    background: var(--clr-white);
    box-shadow: var(--shadow-sm);
  }

  .product-specs .specs-table td {
    display: block !important;
    width: 100% !important;
    padding: 0.95rem 1rem !important;
  }

  .product-specs .specs-table td:first-child {
    width: 100% !important;
    border-bottom: 1px solid var(--clr-border);
    background: var(--clr-stone);
  }

  .product-specs .specs-table td:last-child {
    min-height: 3.25rem;
  }
}

@media (max-width: 640px) {
  .product-specs .specs-table tbody {
    grid-template-columns: 1fr;
  }

  .product-specs .specs-table td {
    padding: 0.9rem 0.95rem !important;
  }
}

/* Compact applications wheel: match the product-page circular system without oversized sector pills. */
.app-hub-grid {
  width: min(78vw, 680px) !important;
  max-width: 680px !important;
  margin-inline: auto !important;
  box-shadow:
    inset 0 0 0 1px rgba(93, 151, 74, 0.26),
    inset 0 0 0 76px rgba(255, 255, 255, 0.12),
    0 22px 50px rgba(26, 79, 45, 0.13) !important;
}

.app-hub-grid::before {
  inset: 18% !important;
  box-shadow:
    0 15px 34px rgba(44, 114, 59, 0.13),
    inset 0 0 0 1px rgba(93, 151, 74, 0.14) !important;
}

.app-hub-grid::after {
  inset: 36.5% !important;
  font-size: clamp(0.92rem, 1.45vw, 1.22rem) !important;
  line-height: 1.12 !important;
  box-shadow: 0 12px 28px rgba(32, 92, 50, 0.13) !important;
}

.app-hub-card,
.app-hub-card:nth-child(3),
.app-hub-card:nth-child(4),
.app-hub-card:nth-child(5),
.app-hub-card:nth-child(6),
.app-hub-card:nth-child(7) {
  width: clamp(108px, 12vw, 150px) !important;
  min-height: 42px !important;
  height: auto !important;
  padding: 0.55rem 0.72rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.7) !important;
  box-shadow: 0 9px 20px rgba(31, 85, 43, 0.1) !important;
  backdrop-filter: blur(6px) !important;
}

.app-hub-card:hover {
  transform: translate(-50%, -50%) translateY(-3px) !important;
  box-shadow: 0 13px 26px rgba(31, 85, 43, 0.14) !important;
}

.app-hub-card::before {
  left: -9px !important;
  width: 23px !important;
  height: 23px !important;
  font-size: 0.52rem !important;
  border-width: 1px !important;
}

.app-hub-card__body {
  min-height: 0 !important;
  height: auto !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.app-hub-card__name {
  margin: 0 !important;
  color: var(--clr-charcoal) !important;
  font-size: clamp(0.64rem, 0.82vw, 0.78rem) !important;
  line-height: 1.08 !important;
}

.app-hub-card__desc {
  width: min(300px, 74vw) !important;
  font-size: 0.74rem !important;
}

.app-hub-card:nth-child(1) { left: 50% !important; top: 8% !important; }
.app-hub-card:nth-child(2) { left: 80% !important; top: 25% !important; }
.app-hub-card:nth-child(3) { left: 84% !important; top: 58% !important; }
.app-hub-card:nth-child(4) { left: 66% !important; top: 86% !important; }
.app-hub-card:nth-child(5) { left: 34% !important; top: 86% !important; }
.app-hub-card:nth-child(6) { left: 16% !important; top: 58% !important; }
.app-hub-card:nth-child(7) { left: 20% !important; top: 25% !important; }

@media (max-width: 760px) {
  .app-hub-grid {
    width: 100% !important;
    min-height: 650px !important;
    aspect-ratio: auto !important;
    border-radius: 30px !important;
    box-shadow:
      inset 0 0 0 1px rgba(93, 151, 74, 0.22),
      0 16px 38px rgba(26, 79, 45, 0.1) !important;
  }

  .app-hub-grid::before {
    inset: 1.1rem 1.1rem auto !important;
    height: 125px !important;
  }

  .app-hub-grid::after {
    inset: 2.35rem calc(50% - 58px) auto !important;
    width: 116px !important;
    height: 116px !important;
    font-size: 0.95rem !important;
  }

  .app-hub-card,
  .app-hub-card:nth-child(3),
  .app-hub-card:nth-child(4),
  .app-hub-card:nth-child(5),
  .app-hub-card:nth-child(6),
  .app-hub-card:nth-child(7) {
    left: 50% !important;
    width: min(86%, 320px) !important;
    min-height: 0 !important;
    padding: 0.72rem 1rem !important;
    border-radius: 999px !important;
    transform: translateX(-50%) !important;
  }

  .app-hub-card:hover {
    transform: translateX(-50%) translateY(-2px) !important;
  }

  .app-hub-card:nth-child(1) { top: 190px !important; }
  .app-hub-card:nth-child(2) { left: 50% !important; top: 255px !important; }
  .app-hub-card:nth-child(3) { left: 50% !important; top: 320px !important; }
  .app-hub-card:nth-child(4) { left: 50% !important; top: 385px !important; }
  .app-hub-card:nth-child(5) { left: 50% !important; top: 450px !important; }
  .app-hub-card:nth-child(6) { left: 50% !important; top: 515px !important; }
  .app-hub-card:nth-child(7) { left: 50% !important; top: 580px !important; }

  .app-hub-card__name {
    font-size: 0.82rem !important;
  }
}
