﻿:root {
  --bg: #f6faff;
  --bg-2: #eef6ff;
  --white: #ffffff;
  --ink: #071b3a;
  --text: #29405f;
  --muted: #5a6f8c;
  --line: rgba(31, 123, 255, 0.16);
  --line-strong: rgba(31, 123, 255, 0.28);
  --blue: #1f7bff;
  --blue-2: #69a9ff;
  --blue-dark: #0b4cbd;
  --shadow: 0 24px 80px rgba(15, 55, 115, 0.12);
  --shadow-soft: 0 16px 48px rgba(15, 55, 115, 0.08);
  --radius-lg: 34px;
  --radius-md: 24px;
  --container: 1180px;
}

body.aquasync-route .aquasync-page {
  background: #f4fbff;
  color: #09263b;
}

body.aquasync-route .aquasync-page .reveal {
  opacity: 1;
  transform: none;
}

body.aquasync-route .aquasync-slide {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
  overflow: hidden;
  padding: 0;
  background: #f4fbff;
}

body.aquasync-route .aquasync-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

body.aquasync-route .aquasync-inner {
  position: relative;
  z-index: 1;
  min-height: 100svh;
}

body.aquasync-route .aquasync-copy {
  width: min(56%, 760px);
  padding-top: clamp(52px, 7svh, 96px);
  padding-bottom: clamp(48px, 7svh, 88px);
  color: #0a2c42;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.aquasync-route .aquasync-copy--left {
  margin-right: auto;
}

body.aquasync-route .aquasync-copy--right {
  margin-left: auto;
}

body.aquasync-route .aquasync-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  color: #168d76;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.aquasync-route .aquasync-kicker::before {
  width: 28px;
  height: 2px;
  content: "";
  background: #42b883;
}

body.aquasync-route .aquasync-copy h1,
body.aquasync-route .aquasync-copy h2,
body.aquasync-route .aquasync-process-copy h2 {
  max-width: 820px;
  margin-bottom: 16px;
  color: #061c30;
  letter-spacing: 0;
  line-height: 1.06;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.aquasync-route .aquasync-copy h1 {
  font-size: clamp(40px, 4.6vw, 68px);
}

body.aquasync-route .aquasync-copy h2,
body.aquasync-route .aquasync-process-copy h2 {
  font-size: clamp(32px, 3.35vw, 50px);
}

body.aquasync-route .aquasync-copy p,
body.aquasync-route .aquasync-copy li,
body.aquasync-route .aquasync-process-copy p,
body.aquasync-route .aquasync-process-note p {
  color: #25445a;
  font-size: clamp(16px, 1.22vw, 19px);
  line-height: 1.46;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.aquasync-route .aquasync-lead {
  color: #11324a;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.34;
}

body.aquasync-route .aquasync-result {
  color: #0e334f;
}

body.aquasync-route .aquasync-copy p + p {
  margin-top: 12px;
}

body.aquasync-route .aquasync-list {
  display: grid;
  gap: 7px;
  margin-top: 16px;
  padding-left: 0;
  list-style: none;
}

body.aquasync-route .aquasync-list li {
  position: relative;
  padding-left: 22px;
}

body.aquasync-route .aquasync-list li::before {
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  content: "";
  background: #20a6c9;
}

body.aquasync-route .aquasync-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

body.aquasync-route .aquasync-actions .btn {
  white-space: normal;
}

body.aquasync-route .aquasync-actions .btn-primary {
  border-color: #0b80a8;
  background: #0b80a8;
  color: #ffffff;
}

body.aquasync-route .aquasync-actions .btn-secondary {
  border-color: rgba(11, 128, 168, 0.28);
  background: rgba(255, 255, 255, 0.72);
  color: #075c78;
}

body.aquasync-route .aquasync-process-inner {
  display: grid;
  min-height: 100svh;
  grid-template-rows: minmax(0, 31svh) minmax(0, 39svh) minmax(0, 30svh);
}

body.aquasync-route .aquasync-process-copy {
  align-self: end;
  max-width: 1120px;
  padding-bottom: clamp(8px, 1.8svh, 16px);
  color: #0a2c42;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.aquasync-route .aquasync-process-copy h2 {
  max-width: 1120px;
  margin-bottom: 10px;
}

body.aquasync-route .aquasync-process-copy p {
  max-width: 980px;
}

body.aquasync-route .aquasync-process-note {
  grid-row: 3;
  align-self: start;
  max-width: 1160px;
  padding-top: clamp(10px, 1.8svh, 18px);
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.aquasync-route .aquasync-process-note p + p {
  margin-top: 10px;
}

@media (max-width: 1180px) {
  body.aquasync-route .aquasync-copy {
    width: min(58%, 700px);
  }
}

@media (max-height: 820px) and (min-width: 781px) {
  body.aquasync-route .aquasync-copy {
    padding-top: clamp(34px, 5svh, 58px);
    padding-bottom: clamp(30px, 5svh, 54px);
  }

  body.aquasync-route .aquasync-copy h1 {
    font-size: clamp(36px, 4vw, 58px);
  }

  body.aquasync-route .aquasync-copy h2,
  body.aquasync-route .aquasync-process-copy h2 {
    font-size: clamp(28px, 3vw, 42px);
  }

  body.aquasync-route .aquasync-copy p,
  body.aquasync-route .aquasync-copy li,
  body.aquasync-route .aquasync-process-copy p,
  body.aquasync-route .aquasync-process-note p {
    font-size: clamp(15px, 1.08vw, 17px);
    line-height: 1.36;
  }
}

@media (max-width: 780px) {
  body.aquasync-route .aquasync-slide {
    min-height: auto;
    overflow: visible;
    padding: 0;
    background: #f4fbff;
  }

  body.aquasync-route .aquasync-bg,
  body.aquasync-route [data-slide-background],
  body.aquasync-route [data-role="immutable-background"] {
    display: none !important;
  }

  body.aquasync-route .aquasync-inner,
  body.aquasync-route .aquasync-process-inner {
    display: block;
    min-height: auto;
    padding-top: clamp(42px, 10vw, 72px);
    padding-bottom: clamp(42px, 10vw, 72px);
  }

  body.aquasync-route .aquasync-copy,
  body.aquasync-route .aquasync-copy--left,
  body.aquasync-route .aquasync-copy--right,
  body.aquasync-route .aquasync-process-copy,
  body.aquasync-route .aquasync-process-note {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
  }

  body.aquasync-route .aquasync-process-note {
    margin-top: 20px;
  }

  body.aquasync-route .aquasync-copy h1 {
    font-size: clamp(34px, 10vw, 46px);
  }

  body.aquasync-route .aquasync-copy h2,
  body.aquasync-route .aquasync-process-copy h2 {
    font-size: clamp(28px, 8vw, 38px);
  }

  body.aquasync-route .aquasync-copy p,
  body.aquasync-route .aquasync-copy li,
  body.aquasync-route .aquasync-process-copy p,
  body.aquasync-route .aquasync-process-note p {
    font-size: clamp(16px, 4.4vw, 18px);
    line-height: 1.48;
  }

  body.aquasync-route .aquasync-lead {
    font-size: clamp(18px, 5vw, 21px);
  }

  body.aquasync-route .aquasync-actions {
    gap: 10px;
    margin-top: 22px;
  }

  body.aquasync-route .aquasync-actions .btn {
    width: 100%;
    min-height: 46px;
    justify-content: center;
    padding: 12px 16px;
  }
}

@media (max-width: 420px) {
  body.aquasync-route .aquasync-copy h1 {
    font-size: clamp(31px, 9vw, 38px);
  }

  body.aquasync-route .aquasync-copy h2,
  body.aquasync-route .aquasync-process-copy h2 {
    font-size: clamp(25px, 7.4vw, 32px);
  }
}

@media (max-width: 780px) {
  [data-role="immutable-background"],
  [data-role="abstract-background"],
  [data-slide-background],
  [data-visual-role*="background"],
  img[aria-hidden="true"][class*="-bg"],
  img[aria-hidden="true"][class*="bg-"],
  .products-wf-bg,
  .mg-wf-bg,
  .pm-wf-bg,
  .software-bg,
  .electronics-bg,
  .development-v2-bg,
  .development-index-bg,
  .rf-bg,
  .leak-bg,
  .leak-slide-bg,
  .askue-bg,
  .cases-bg,
  .grocery-bg,
  .hvac-bg,
  .wastewater-bg,
  .ventilation-bg,
  .refrigeration-bg,
  .dev-auto-bg {
    display: none !important;
  }

  [data-background-asset],
  [class*="-slide"],
  [class*="-section"],
  [class*="-hero"],
  [class*="-route"] {
    background-image: none !important;
  }
}

/* Development index Phase 3 integration */
.development-index-route {
  background: #f7fbff;
}

.development-index-route .generated-page {
  background: #f7fbff;
}

.development-index-section,
.development-index-section * {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.development-index-section {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: 0;
  color: #071b3a;
  background: #f7fbff;
}

.development-index-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

.development-index-inner {
  position: relative;
  z-index: 1;
  padding-top: clamp(58px, 7vw, 104px);
  padding-bottom: clamp(64px, 8vw, 118px);
}

.development-index-head {
  max-width: 1080px;
}

.development-index-head h1 {
  max-width: 980px;
  margin-bottom: 22px;
  color: #071b3a;
  font-size: clamp(42px, 5vw, 72px);
  line-height: 1.02;
  overflow-wrap: normal;
  word-break: normal;
}

.development-index-head p {
  max-width: 980px;
  margin-bottom: 14px;
  color: #29405f;
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.52;
}

.development-index-head .development-index-lead {
  color: #102b4c;
  font-size: clamp(19px, 1.65vw, 24px);
  font-weight: 650;
  line-height: 1.38;
}

.development-index-message {
  margin-top: 18px;
  padding: 18px 20px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 18px 48px rgba(15, 55, 115, 0.08);
}

.development-index-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 26px);
  margin-top: clamp(34px, 4vw, 52px);
}

.development-index-card {
  min-width: 0;
  display: flex;
}

.development-index-card-link {
  min-width: 0;
  display: flex;
  width: 100%;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 50px rgba(15, 55, 115, 0.1);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.development-index-card-link:hover,
.development-index-card-link:focus-visible {
  transform: translateY(-6px);
  border-color: rgba(31, 123, 255, 0.34);
  box-shadow: 0 24px 68px rgba(15, 55, 115, 0.15);
}

.development-index-card-link:focus-visible {
  outline: 3px solid rgba(31, 123, 255, 0.28);
  outline-offset: 4px;
}

.development-index-media {
  display: block;
  aspect-ratio: 16 / 9;
  background: #eef6ff;
}

.development-index-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.development-index-card-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: clamp(20px, 2vw, 28px);
}

.development-index-card-kicker {
  margin-bottom: 12px;
  color: #0b4cbd;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.development-index-card h2 {
  margin-bottom: 14px;
  color: #071b3a;
  font-size: clamp(25px, 2vw, 32px);
  line-height: 1.08;
}

.development-index-card p,
.development-index-card strong {
  color: #29405f;
  font-size: 15.5px;
  line-height: 1.48;
}

.development-index-card p {
  margin-bottom: 14px;
}

.development-index-card strong {
  margin-top: 4px;
  margin-bottom: 7px;
  color: #102b4c;
}

.development-index-card-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  padding-top: 14px;
  color: #0b4cbd;
  font-weight: 800;
}

.development-index-card-cta span {
  transition: transform 180ms ease;
}

.development-index-card-link:hover .development-index-card-cta span,
.development-index-card-link:focus-visible .development-index-card-cta span {
  transform: translateX(4px);
}

.development-index-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-top: clamp(28px, 4vw, 48px);
  padding: clamp(22px, 2.5vw, 30px);
  border: 1px solid rgba(31, 123, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.84);
  box-shadow: 0 18px 54px rgba(15, 55, 115, 0.1);
}

.development-index-cta p {
  max-width: 820px;
  margin: 0;
  color: #102b4c;
  font-size: clamp(18px, 1.5vw, 22px);
  font-weight: 650;
  line-height: 1.34;
}

@media (max-width: 1100px) {
  .development-index-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .development-index-card:last-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .development-index-section {
    padding: 0;
  }

  .development-index-inner {
    padding-top: 40px;
    padding-bottom: 56px;
  }

  .development-index-head h1 {
    font-size: clamp(33px, 9vw, 44px);
    line-height: 1.04;
  }

  .development-index-head p,
  .development-index-head .development-index-lead {
    font-size: 16px;
    line-height: 1.42;
  }

  .development-index-message {
    padding: 16px;
  }

  .development-index-grid {
    grid-template-columns: 1fr;
    margin-top: 28px;
  }

  .development-index-card:last-child {
    grid-column: auto;
  }

  .development-index-card-body {
    padding: 18px;
  }

  .development-index-card h2 {
    font-size: 26px;
  }

  .development-index-card p,
  .development-index-card strong {
    font-size: 15px;
    line-height: 1.42;
  }

  .development-index-cta {
    align-items: stretch;
    flex-direction: column;
  }

  .development-index-cta .btn {
    width: 100%;
  }
}

/* Development index v2: two-slide structure from approved wireframe */
.development-index-route .development-v2-slide,
.development-index-route .development-v2-slide * {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

.development-index-route .development-v2-slide {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #f7fbff;
  color: #071b3a;
}

.development-index-route .development-v2-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

.development-index-route .development-v2-hero {
  min-height: min(56.25vw, calc(100svh - 78px));
  display: grid;
  align-items: center;
}

.development-index-route .development-v2-hero-inner {
  box-sizing: border-box;
  display: grid;
  min-height: inherit;
  align-items: center;
  grid-template-columns: minmax(0, 0.50fr) minmax(0, 0.50fr);
  padding-top: clamp(44px, 5vw, 82px);
  padding-bottom: clamp(44px, 5vw, 82px);
}

.development-index-route .development-v2-hero-copy {
  max-width: 616px;
}

.development-index-route .development-v2-hero-copy h1 {
  max-width: 616px;
  margin: 0 0 22px;
  color: #071b3a;
  font-size: clamp(42px, 4.6vw, 70px);
  line-height: 1.02;
}

.development-index-route .development-v2-hero-copy p {
  max-width: 583px;
  margin: 0 0 14px;
  color: #29405f;
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.5;
}

.development-index-route .development-v2-hero-copy .development-v2-lead {
  color: #102b4c;
  font-size: clamp(19px, 1.55vw, 24px);
  font-weight: 650;
  line-height: 1.36;
}

.development-index-route .development-v2-message {
  margin-top: 18px !important;
  padding: 18px 20px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 48px rgba(15, 55, 115, 0.08);
}

.development-index-route .development-v2-hero-copy .hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.development-index-route .development-v2-directions {
  overflow: visible;
}

.development-index-route .development-v2-directions-inner {
  position: relative;
  z-index: 1;
  padding-top: clamp(56px, 6vw, 92px);
  padding-bottom: clamp(64px, 7vw, 106px);
}

.development-index-route .development-v2-section-head {
  max-width: 980px;
}

.development-index-route .development-v2-section-head h2 {
  margin: 0 0 16px;
  color: #071b3a;
  font-size: clamp(36px, 4vw, 58px);
  line-height: 1.04;
}

.development-index-route .development-v2-section-head p {
  max-width: 900px;
  margin: 0;
  color: #29405f;
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.5;
}

.development-index-route .development-v2-grid {
  margin-top: clamp(30px, 3.5vw, 46px);
}

.development-index-route .development-v2-cta {
  margin-top: clamp(26px, 3.5vw, 42px);
}

@media (max-width: 1100px) {
  .development-index-route .development-v2-hero-inner {
    grid-template-columns: minmax(0, 0.55fr) minmax(0, 0.45fr);
  }

  .development-index-route .development-v2-hero-copy h1 {
    font-size: clamp(38px, 5.8vw, 60px);
  }
}

@media (max-width: 1500px) and (min-width: 1101px) {
  .development-index-route .development-v2-hero-copy h1 {
    margin-bottom: 16px;
    font-size: clamp(38px, 4.1vw, 58px);
    line-height: 1.03;
  }

  .development-index-route .development-v2-hero-copy p {
    margin-bottom: 11px;
    font-size: 17px;
    line-height: 1.4;
  }

  .development-index-route .development-v2-hero-copy .development-v2-lead {
    font-size: 20px;
    line-height: 1.32;
  }

  .development-index-route .development-v2-message {
    margin-top: 14px !important;
    padding: 14px 16px;
  }

  .development-index-route .development-v2-hero-copy .hero-actions {
    margin-top: 18px;
  }
}

@media (max-height: 820px) and (min-width: 761px) {
  .development-index-route .development-v2-hero-inner {
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .development-index-route .development-v2-hero-copy h1 {
    max-width: 664px;
    margin-bottom: 14px;
    font-size: clamp(36px, 4vw, 52px);
    line-height: 1.03;
  }

  .development-index-route .development-v2-hero-copy p {
    margin-bottom: 10px;
    font-size: 16px;
    line-height: 1.34;
  }

  .development-index-route .development-v2-hero-copy .development-v2-lead {
    font-size: 18px;
    line-height: 1.3;
  }

  .development-index-route .development-v2-message {
    margin-top: 12px !important;
    padding: 12px 14px;
  }

  .development-index-route .development-v2-hero-copy .hero-actions {
    margin-top: 16px;
  }
}

@media (max-width: 760px) {
  .development-index-route .development-v2-hero {
    min-height: min(216vw, calc(100svh - 70px));
  }

  .development-index-route .development-v2-hero-inner {
    display: block;
    padding-top: 40px;
    padding-bottom: 44px;
  }

  .development-index-route .development-v2-hero-copy {
    max-width: none;
  }

  .development-index-route .development-v2-hero-copy h1 {
    margin-bottom: 14px;
    font-size: clamp(30px, 8.4vw, 40px);
    line-height: 1.04;
  }

  .development-index-route .development-v2-hero-copy p,
  .development-index-route .development-v2-hero-copy .development-v2-lead,
  .development-index-route .development-v2-section-head p {
    font-size: 16px;
    line-height: 1.42;
  }

  .development-index-route .development-v2-message {
    padding: 12px 14px;
  }

  .development-index-route .development-v2-hero-copy .hero-actions {
    flex-direction: column;
  }

  .development-index-route .development-v2-hero-copy .btn,
  .development-index-route .development-v2-cta .btn {
    width: 100%;
  }

  .development-index-route .development-v2-directions-inner {
    padding-top: 42px;
    padding-bottom: 56px;
  }

  .development-index-route .development-v2-section-head h2 {
    font-size: clamp(30px, 8vw, 40px);
  }
}

/* Electronics development landing */
.electronics-development-route,
.electronics-development-route .generated-page {
  background: #f7fbff;
  color: #071b3a;
}

.electronics-page :where(h1, h2, h3, p, a, button, span, strong, li) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

.electronics-slide {
  --electronics-aspect: 1.7778958555;
  position: relative;
  isolation: isolate;
  display: grid;
  place-items: center;
  min-height: min(56.25vw, calc(100svh - 1px));
  padding: 0;
  overflow: clip;
  background: #f7fbff;
  color: #071b3a;
  scroll-margin-top: 76px;
}

.electronics-frame {
  position: relative;
  width: 100%;
  min-height: inherit;
  overflow: visible;
}

.electronics-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

.electronics-bg--abstract {
  object-fit: fill;
}

.electronics-hero-copy,
.electronics-thesis-grid,
.electronics-card-layout,
.electronics-process-copy,
.electronics-final-copy {
  position: absolute;
  z-index: 1;
}

.electronics-page .reveal {
  opacity: 1;
  transform: none;
}

.electronics-hero-copy {
  top: 9.5%;
  left: 5.4%;
  display: grid;
  width: 49%;
  gap: clamp(10px, 1.15vw, 16px);
}

.electronics-hero-copy h1,
.electronics-process-copy h2,
.electronics-final-copy h2,
.electronics-section-head h2 {
  margin: 0;
  color: #071b3a;
  font-weight: 820;
  line-height: 1.03;
}

.electronics-hero-copy h1 {
  max-width: 720px;
  font-size: clamp(34px, 3.9vw, 64px);
}

.electronics-hero-copy p,
.electronics-process-copy p,
.electronics-final-copy p,
.electronics-section-head p,
.electronics-card p,
.electronics-thesis p {
  margin: 0;
  color: #29405f;
  font-size: clamp(14px, 1.02vw, 18px);
  line-height: 1.46;
}

.electronics-hero-copy .electronics-lead {
  color: #102b4c;
  font-size: clamp(16px, 1.25vw, 21px);
  font-weight: 650;
  line-height: 1.36;
}

.electronics-hero-copy .hero-actions {
  margin-top: 4px;
}

.electronics-thesis-grid {
  right: 5.3%;
  bottom: 5.4%;
  left: 5.3%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(10px, 1vw, 16px);
}

.electronics-thesis {
  min-width: 0;
  padding: clamp(13px, 1.25vw, 18px);
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 38px rgba(15, 55, 115, 0.08);
}

.electronics-thesis h3 {
  margin: 0 0 6px;
  color: #071b3a;
  font-size: clamp(15px, 1.08vw, 19px);
  line-height: 1.14;
}

.electronics-thesis p {
  font-size: clamp(12px, 0.82vw, 14px);
  line-height: 1.35;
}

.electronics-slide--cards {
  overflow: visible;
}

.electronics-frame--cards {
  width: 100%;
  aspect-ratio: auto;
}

.electronics-slide--cards .electronics-bg {
  object-fit: fill;
}

.electronics-card-layout {
  position: relative;
  inset: auto;
  display: grid;
  width: min(calc(100% - 40px), 1440px);
  margin: 0 auto;
  gap: clamp(18px, 2vw, 28px);
  padding: clamp(44px, 5.3vw, 76px) clamp(28px, 4.9vw, 72px);
}

.electronics-section-head {
  display: grid;
  gap: 10px;
  max-width: 1120px;
}

.electronics-section-head h2,
.electronics-process-copy h2,
.electronics-final-copy h2 {
  font-size: clamp(30px, 3.2vw, 54px);
}

.electronics-section-head p {
  max-width: 920px;
  font-size: clamp(15px, 1.08vw, 19px);
}

.electronics-section-note {
  color: #0b4cbd !important;
  font-weight: 720;
}

.electronics-grid {
  display: grid;
  gap: clamp(14px, 1.45vw, 22px);
  align-items: stretch;
}

.electronics-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.electronics-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.electronics-card {
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(31, 123, 255, 0.13);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 42px rgba(15, 55, 115, 0.09);
}

.electronics-card-media {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #eef7fb;
}

.electronics-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
}

.electronics-card-body {
  display: grid;
  align-content: start;
  gap: 8px;
  padding: clamp(16px, 1.5vw, 22px);
}

.electronics-card h3 {
  margin: 0;
  color: #071b3a;
  font-size: clamp(18px, 1.55vw, 25px);
  line-height: 1.12;
}

.electronics-card p {
  font-size: clamp(13px, 0.96vw, 16px);
  line-height: 1.42;
}

.electronics-process-copy {
  top: 7.2%;
  left: 6.3%;
  display: grid;
  width: 72%;
  gap: 10px;
}

.electronics-process-bottom {
  position: absolute;
  right: 6%;
  bottom: 6%;
  z-index: 1;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.electronics-process-copy p {
  max-width: 980px;
  font-size: clamp(15px, 1.08vw, 19px);
}

.electronics-final-copy {
  top: 17%;
  left: 6%;
  display: grid;
  width: min(640px, 48%);
  gap: clamp(12px, 1.25vw, 18px);
}

.electronics-final-copy p {
  font-size: clamp(15px, 1.08vw, 19px);
}

.electronics-final-helper {
  color: #0b4cbd !important;
  font-weight: 700;
}

@media (max-width: 1180px) {
  .electronics-grid--three,
  .electronics-grid--six {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .electronics-slide {
    display: block;
    padding: 0 14px;
    overflow: visible;
  }

  .electronics-frame {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 0;
    aspect-ratio: auto;
    gap: 12px;
    padding: 34px 0;
  }

  .electronics-bg,
  .electronics-hero-copy,
  .electronics-thesis-grid,
  .electronics-card-layout,
  .electronics-process-copy,
  .electronics-final-copy {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
  }

  .electronics-bg {
    order: 2;
    height: auto;
    aspect-ratio: 1672 / 941;
    object-fit: contain;
  }

  .electronics-hero-copy,
  .electronics-process-copy,
  .electronics-final-copy {
    order: 1;
    gap: 10px;
  }

  .electronics-hero-copy h1 {
    font-size: clamp(34px, 9vw, 48px);
  }

  .electronics-section-head h2,
  .electronics-process-copy h2,
  .electronics-final-copy h2 {
    font-size: clamp(28px, 8vw, 40px);
  }

  .electronics-hero-copy p,
  .electronics-process-copy p,
  .electronics-final-copy p,
  .electronics-section-head p {
    font-size: 16px;
    line-height: 1.42;
  }

  .electronics-thesis-grid {
    order: 3;
    grid-template-columns: 1fr;
  }

  .electronics-frame--cards {
    width: 100%;
  }

  .electronics-slide--cards .electronics-bg {
    position: absolute;
    inset: 0;
    height: 100%;
    aspect-ratio: auto;
    object-fit: fill;
  }

  .electronics-card-layout {
    z-index: 1;
    width: 100%;
    padding: 34px 16px;
  }

  .electronics-grid--three,
  .electronics-grid--six {
    grid-template-columns: 1fr;
  }

  .electronics-card-body {
    padding: 17px;
  }

  .electronics-card h3 {
    font-size: 22px;
  }

  .electronics-final .btn,
  .electronics-hero .btn {
    width: 100%;
  }
}

/* Refrigeration monitoring premium landing */
.refrigeration-route {
  background: #061018;
}

.rf-slide {
  position: relative;
  isolation: isolate;
  min-height: min(56.25vw, 100vh);
  overflow: hidden;
  background: #07111c;
  color: #ecf8ff;
}

.rf-slide,
.rf-slide * {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.rf-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  object-position: center;
  pointer-events: none;
}

.rf-inner,
.rf-card-section {
  min-height: inherit;
  display: grid;
  align-items: center;
  padding-top: clamp(34px, 5vh, 64px);
  padding-bottom: clamp(34px, 5vh, 64px);
}

.rf-inner--left {
  grid-template-columns: minmax(0, 0.46fr) minmax(0, 0.54fr);
}

.rf-inner--right {
  grid-template-columns: minmax(0, 0.52fr) minmax(0, 0.48fr);
}

.rf-inner--right .rf-copy {
  grid-column: 2;
}

.rf-copy {
  max-width: 610px;
}

.rf-copy h1,
.rf-copy h2,
.rf-section-head h2 {
  margin: 0;
  color: #ffffff;
  letter-spacing: 0;
  line-height: 1.04;
}

.rf-copy h1 {
  font-size: clamp(42px, 4.9vw, 76px);
}

.rf-copy h2,
.rf-section-head h2 {
  font-size: clamp(34px, 3.6vw, 56px);
}

.rf-copy p,
.rf-section-head p,
.rf-card-note {
  color: rgba(229, 244, 255, 0.82);
  font-size: clamp(16px, 1.35vw, 19px);
  line-height: 1.45;
}

.rf-copy p {
  margin: 18px 0 0;
}

.rf-copy .hero-actions {
  margin-top: clamp(20px, 3vh, 30px);
}

.rf-accent {
  color: #8be6ff !important;
  font-weight: 700;
}

.rf-card-slide {
  min-height: auto;
  overflow: visible;
}

.rf-card-section {
  align-items: stretch;
  gap: clamp(22px, 3vw, 34px);
}

.rf-section-head {
  max-width: 900px;
}

.rf-section-head p {
  margin: 16px 0 0;
}

.rf-card-grid {
  display: grid;
  gap: clamp(16px, 1.5vw, 22px);
}

.rf-card-grid--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.rf-card-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rf-card-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rf-card {
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: visible;
  border: 1px solid rgba(126, 221, 255, 0.2);
  border-radius: 8px;
  background: rgba(8, 22, 34, 0.82);
  box-shadow: 0 20px 55px rgba(0, 0, 0, 0.24);
}

.rf-card-media {
  aspect-ratio: 16 / 9;
  background: rgba(4, 12, 20, 0.8);
}

.rf-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.rf-card-body {
  padding: clamp(16px, 1.7vw, 22px);
}

.rf-card-body span {
  display: inline-block;
  margin-bottom: 10px;
  color: #8be6ff;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.rf-card-body span:empty {
  display: none;
}

.rf-card h3 {
  margin: 0 0 10px;
  color: #fff;
  font-size: clamp(18px, 1.45vw, 22px);
  line-height: 1.14;
}

.rf-card p {
  margin: 0;
  color: rgba(229, 244, 255, 0.76);
  font-size: 14.5px;
  line-height: 1.42;
}

.rf-card-note {
  max-width: 980px;
  margin: 0;
  color: #8be6ff;
  font-weight: 700;
}

.ventilation-route .rf-inner {
  padding-top: clamp(24px, 3.6vh, 44px);
  padding-bottom: clamp(24px, 3.6vh, 44px);
}

/* Grocery retail monitoring Phase 3 integration */
.grocery-route {
  --gr-ink: #18321e;
  --gr-text: #2f4d35;
  --gr-muted: #5a765f;
  --gr-green: #2f8a3b;
  --gr-green-dark: #176327;
  --gr-line: rgba(47, 138, 59, 0.18);
  --gr-surface: rgba(255, 255, 255, 0.88);
  background: #f7fbf4;
}

.grocery-route .generated-page {
  background: #f7fbf4;
}

.grocery-route .rf-slide {
  min-height: min(56.28vw, 100vh);
  background: #f7fbf4;
  color: var(--gr-ink);
}

.grocery-route .rf-bg {
  object-fit: fill;
  filter: none;
  opacity: 1;
}

.grocery-route .rf-inner,
.grocery-route .rf-card-section {
  position: relative;
  z-index: 1;
  padding-top: clamp(28px, 4.4vh, 56px);
  padding-bottom: clamp(28px, 4.4vh, 56px);
}

.grocery-route .rf-inner--left {
  grid-template-columns: minmax(0, 0.58fr) minmax(0, 0.42fr);
}

.grocery-route .rf-inner--right {
  grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
}

.grocery-route .rf-copy {
  max-width: min(640px, 54vw);
}

.grocery-route .rf-inner--right .rf-copy {
  justify-self: end;
}

.grocery-route .rf-copy h1,
.grocery-route .rf-copy h2,
.grocery-route .rf-section-head h2 {
  color: var(--gr-ink);
}

.grocery-route .rf-copy h1 {
  max-width: 620px;
  font-size: clamp(38px, 4.2vw, 64px);
  line-height: 1.02;
}

.grocery-route .rf-copy h2,
.grocery-route .rf-section-head h2 {
  font-size: clamp(32px, 3.2vw, 50px);
  line-height: 1.06;
}

.grocery-route .rf-copy p,
.grocery-route .rf-section-head p,
.grocery-route .rf-card-note {
  color: var(--gr-text);
  font-size: clamp(16px, 1.22vw, 18px);
  line-height: 1.44;
}

.grocery-route .rf-copy p {
  margin-top: 13px;
}

.grocery-route .eyebrow {
  color: var(--gr-green-dark);
}

.grocery-route .eyebrow::before {
  background: var(--gr-green);
  box-shadow: 0 0 0 8px rgba(47, 138, 59, 0.1);
}

.grocery-route .rf-accent {
  color: var(--gr-green-dark) !important;
}

.grocery-route .btn-primary {
  background: linear-gradient(135deg, #35a346 0%, #176327 100%);
  box-shadow: 0 14px 34px rgba(47, 138, 59, 0.24);
}

.grocery-route .btn-secondary {
  color: var(--gr-green-dark);
  border-color: rgba(47, 138, 59, 0.24);
  background: rgba(255, 255, 255, 0.8);
}

.grocery-route .rf-card-slide {
  min-height: auto;
}

.grocery-route .rf-card-section {
  gap: clamp(22px, 3vw, 34px);
}

.grocery-route .rf-section-head {
  max-width: 1020px;
}

.grocery-route .rf-card-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grocery-route .gr-role-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grocery-route .rf-card {
  overflow: hidden;
  border-color: var(--gr-line);
  background: var(--gr-surface);
  box-shadow: 0 18px 44px rgba(37, 95, 45, 0.09);
}

.grocery-route .rf-card-media {
  aspect-ratio: 3 / 1;
  background: #eef8ea;
}

.grocery-route .rf-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.grocery-route .rf-card-body {
  padding: clamp(15px, 1.45vw, 20px);
}

.grocery-route .rf-card-body span {
  color: var(--gr-green);
}

.grocery-route .rf-card h3 {
  color: var(--gr-ink);
  font-size: clamp(17px, 1.28vw, 21px);
}

.grocery-route .rf-card p {
  color: var(--gr-text);
  font-size: 14px;
  line-height: 1.38;
}

.grocery-route .rf-card p + p {
  margin-top: 8px;
}

.grocery-route .rf-card-note {
  color: var(--gr-green-dark);
}

.grocery-route .gr-pilot-inner {
  min-height: inherit;
  position: relative;
  display: block;
  padding-top: clamp(24px, 3.8vh, 42px);
  padding-bottom: clamp(24px, 3.8vh, 42px);
}

.grocery-route .gr-pilot {
  min-height: max(100vh, 980px);
}

.grocery-route .gr-pilot .rf-copy {
  max-width: min(760px, 60vw);
}

.grocery-route .gr-pilot-top {
  position: absolute;
  top: clamp(24px, 3.8vh, 42px);
  left: 0;
}

.grocery-route .gr-pilot-bottom {
  position: absolute;
  top: 70%;
  left: 0;
  right: 0;
  width: min(900px, 86vw);
  max-width: min(900px, 86vw);
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.grocery-route .gr-pilot-bottom p {
  font-size: clamp(15px, 1.05vw, 16px);
  line-height: 1.28;
  margin-top: 9px;
}

.grocery-route .gr-pilot-bottom .hero-actions {
  margin-top: 14px;
}

.grocery-route .gr-contact {
  background: #f4faf1;
}

.grocery-route .generated-cta-card {
  border-color: var(--gr-line);
  box-shadow: 0 20px 60px rgba(37, 95, 45, 0.1);
}

.grocery-route .contact-form input,
.grocery-route .contact-form textarea {
  border-color: rgba(47, 138, 59, 0.18);
}

.grocery-route .contact-form input:focus,
.grocery-route .contact-form textarea:focus {
  outline-color: rgba(47, 138, 59, 0.35);
  border-color: rgba(47, 138, 59, 0.42);
}

@media (max-width: 1180px) {
  .grocery-route .rf-slide {
    min-height: auto;
  }

  .grocery-route .rf-inner--left {
    grid-template-columns: minmax(0, 0.58fr) minmax(0, 0.42fr);
  }

  .grocery-route .rf-inner--right {
    grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
  }

  .grocery-route .gr-pilot-inner {
    display: block;
  }

  .grocery-route .rf-copy,
  .grocery-route .rf-inner--right .rf-copy {
    max-width: min(620px, 54vw);
  }

  .grocery-route .gr-pilot .rf-copy {
    max-width: min(720px, 62vw);
  }

  .grocery-route .gr-pilot-bottom {
    max-width: min(880px, 86vw);
  }

  .grocery-route .rf-card-grid--six,
  .grocery-route .gr-role-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 761px) and (max-height: 820px) {
  .grocery-route .rf-copy h1 {
    font-size: clamp(35px, 3.6vw, 54px);
  }

  .grocery-route .rf-copy h2,
  .grocery-route .rf-section-head h2 {
    font-size: clamp(29px, 2.75vw, 42px);
  }

  .grocery-route .rf-copy p,
  .grocery-route .rf-section-head p,
  .grocery-route .rf-card-note {
    font-size: 15px;
    line-height: 1.32;
  }
}

@media (max-width: 760px) {
  .grocery-route .rf-bg {
    object-fit: fill;
  }

  .grocery-route .rf-inner,
  .grocery-route .rf-card-section {
    display: block;
    padding-top: 24px;
    padding-bottom: 30px;
  }

  .grocery-route .gr-pilot-inner {
    display: block;
    padding-top: 18px;
    padding-bottom: 18px;
  }

  .grocery-route .gr-pilot-top {
    top: 18px;
  }

  .grocery-route .gr-pilot-bottom {
    top: 70%;
    width: 96%;
    max-width: 96%;
  }

  .grocery-route .gr-pilot-bottom p {
    font-size: 14px;
    line-height: 1.22;
    margin-top: 7px;
  }

  .grocery-route .gr-pilot-bottom .hero-actions {
    gap: 8px;
    margin-top: 10px;
  }

  .grocery-route .gr-pilot-bottom .hero-actions .btn {
    min-height: 38px;
    padding: 9px 12px;
    font-size: 13px;
  }

  .grocery-route .rf-copy,
  .grocery-route .rf-inner--right .rf-copy,
  .grocery-route .gr-pilot .rf-copy,
  .grocery-route .rf-section-head {
    max-width: 58%;
  }

  .grocery-route .rf-inner--right .rf-copy {
    margin-left: auto;
  }

  .grocery-route .gr-pilot .rf-copy {
    max-width: 74%;
  }

  .grocery-route .gr-pilot-bottom {
    max-width: 82%;
  }

  .grocery-route .rf-copy h1 {
    font-size: clamp(30px, 8.5vw, 38px);
  }

  .grocery-route .rf-copy h2,
  .grocery-route .rf-section-head h2 {
    font-size: clamp(27px, 7.3vw, 34px);
  }

  .grocery-route .rf-copy p,
  .grocery-route .rf-section-head p,
  .grocery-route .rf-card-note {
    font-size: 14.5px;
    line-height: 1.32;
  }

  .grocery-route .rf-card-grid--six,
  .grocery-route .gr-role-grid {
    grid-template-columns: 1fr;
  }
}

.ventilation-route .vent-pilot .rf-inner--right {
  grid-template-columns: minmax(0, 0.58fr) minmax(0, 0.42fr);
}

.ventilation-route .vent-pilot .rf-copy {
  max-width: 600px;
}

@media (max-width: 1180px) {
  .rf-slide {
    min-height: auto;
  }

  .rf-inner--left,
  .rf-inner--right {
    grid-template-columns: 1fr;
  }

  .rf-inner--right .rf-copy {
    grid-column: auto;
    margin-left: auto;
  }

  .rf-copy {
    max-width: min(680px, 58vw);
  }

  .rf-pilot .rf-copy {
    max-width: min(720px, 100%);
  }

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

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

@media (min-width: 761px) and (max-height: 820px) {
  .wastewater-route .ww-hero .rf-copy h1 {
    font-size: clamp(30px, 3.3vw, 50px);
  }

  .wastewater-route .ww-hero .rf-copy p {
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.24;
  }

  .rf-inner,
  .rf-card-section {
    padding-top: 22px;
    padding-bottom: 22px;
  }

  .rf-copy h1 {
    font-size: clamp(38px, 4.1vw, 58px);
  }

  .rf-copy h2,
  .rf-section-head h2 {
    font-size: clamp(30px, 3vw, 44px);
  }

  .rf-copy p,
  .rf-section-head p,
  .rf-card-note {
    font-size: 15.5px;
    line-height: 1.34;
  }

  .rf-copy p {
    margin-top: 10px;
  }

  .rf-copy .hero-actions {
    margin-top: 14px;
  }
}

@media (max-width: 760px) {
  .rf-slide {
    min-height: auto;
    overflow: hidden;
  }

  .rf-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: fill;
    opacity: 1;
  }

  .rf-inner,
  .rf-card-section {
    min-height: 0;
    display: block;
    padding-top: 22px;
    padding-bottom: 28px;
  }

  .rf-copy,
  .rf-inner--right .rf-copy,
  .rf-section-head {
    max-width: 100%;
    margin-left: 0;
  }

  .rf-copy h1 {
    font-size: clamp(31px, 8.7vw, 38px);
    line-height: 1.02;
  }

  .rf-copy h2,
  .rf-section-head h2 {
    font-size: clamp(27px, 7.4vw, 34px);
    line-height: 1.05;
  }

  .rf-copy p,
  .rf-section-head p,
  .rf-card-note {
    font-size: 15px;
    line-height: 1.34;
  }

  .rf-copy p {
    margin-top: 10px;
  }

  .rf-card-grid--four,
  .rf-card-grid--six,
  .rf-card-grid--three {
    grid-template-columns: 1fr;
  }

  .rf-card-grid {
    margin-top: 22px;
  }

  .rf-card-body {
    padding: 16px;
  }

  .rf-copy .hero-actions {
    align-items: stretch;
    margin-top: 14px;
    gap: 10px;
  }

  .rf-copy .hero-actions .btn {
    min-height: 44px;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .rf-pilot .rf-copy p {
    font-size: 14.5px;
    line-height: 1.28;
    margin-top: 8px;
  }
}

@media (max-width: 1180px) {
  .grocery-route .rf-inner--left {
    grid-template-columns: minmax(0, 0.58fr) minmax(0, 0.42fr);
  }

  .grocery-route .rf-inner--right {
    grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
  }

  .grocery-route .rf-inner--right .rf-copy {
    grid-column: 2;
    margin-left: 0;
  }

  .grocery-route .gr-pilot-inner {
    display: block;
  }

  .grocery-route .rf-copy,
  .grocery-route .rf-inner--right .rf-copy {
    max-width: min(620px, 54vw);
  }

  .grocery-route .gr-pilot .rf-copy {
    max-width: min(720px, 62vw);
  }

  .grocery-route .gr-pilot-bottom {
    max-width: min(880px, 86vw);
  }
}

@media (max-width: 760px) {
  .grocery-route .rf-inner,
  .grocery-route .rf-card-section {
    display: block;
  }

  .grocery-route .gr-pilot {
    min-height: 1580px;
  }

  .grocery-route .gr-pilot-inner {
    display: block;
  }

  .grocery-route .rf-copy,
  .grocery-route .rf-section-head {
    max-width: 58%;
    margin-left: 0;
  }

  .grocery-route .rf-inner--right .rf-copy {
    max-width: 58%;
    margin-left: auto;
  }

  .grocery-route .gr-pilot .rf-copy {
    max-width: 74%;
  }

  .grocery-route .gr-pilot-bottom {
    max-width: 96%;
  }
}

@media (min-width: 761px) and (max-width: 1180px) {
  .grocery-route .gr-pilot {
    min-height: 1260px;
  }
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: hidden;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, #fff 0%, var(--bg) 38%, #fff 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, a { -webkit-tap-highlight-color: transparent; }

.site-header :where(a, button, span),
.site-footer :where(a, p, h3, span) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.container {
  width: min(calc(100% - 40px), var(--container));
  margin-inline: auto;
}

.section { position: relative; padding: 112px 0; overflow: clip; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  color: var(--blue-dark);
  font-size: 13px;
  font-weight: 750;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.eyebrow::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--blue);
  box-shadow: 0 0 0 8px rgba(31, 123, 255, 0.1);
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  max-width: 900px;
  margin-bottom: 24px;
  font-size: clamp(40px, 5.2vw, 72px);
  line-height: 0.96;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
h2 {
  margin-bottom: 18px;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.02;
  letter-spacing: 0;
}
h3 {
  margin-bottom: 12px;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: 0;
}
p {
  color: var(--text);
  font-size: 17px;
  line-height: 1.62;
}
.muted { color: var(--muted); }
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background: rgba(255, 255, 255, 0.78);
  border-bottom: 1px solid rgba(31, 123, 255, 0.12);
}
.header-inner {
  position: relative;
  height: 76px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: max-content;
}
.brand-logo {
  width: 142px;
  height: auto;
}
.main-nav {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
}
.nav-item {
  position: relative;
}
.nav-item-solutions::after,
.nav-item-products::after,
.nav-item-development::after {
  content: "";
  position: fixed;
  top: 48px;
  left: 0;
  z-index: 119;
  display: none;
  width: 100vw;
  height: 48px;
}
.nav-item-solutions:hover::after,
.nav-item-solutions:focus-within::after,
.nav-item-products:hover::after,
.nav-item-products:focus-within::after,
.nav-item-development:hover::after,
.nav-item-development:focus-within::after {
  display: block;
}
.main-nav > a,
.main-nav .nav-link {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  color: #25415f;
  font-weight: 650;
  font-size: 15px;
  border-radius: 999px;
  transition: background 0.2s ease, color 0.2s ease;
}
.main-nav > a:hover,
.main-nav .nav-link:hover,
.nav-item:focus-within .nav-link,
.nav-item:hover .nav-link {
  background: rgba(31, 123, 255, 0.08);
  color: var(--blue-dark);
}
.mega-menu {
  position: fixed;
  top: 74px;
  left: 50%;
  z-index: 120;
  display: grid;
  width: min(calc(100vw - 40px), 1180px);
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 70px rgba(15, 55, 115, 0.14);
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 10px);
  transition: opacity 180ms ease 80ms, transform 180ms ease 80ms;
}
.mega-menu-development {
  width: min(calc(100vw - 40px), 600px);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.mega-menu-products {
  grid-template-columns: repeat(8, minmax(0, 1fr));
}
.nav-item:hover .mega-menu,
.nav-item:focus-within .mega-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
  transition-delay: 0ms;
}
.mega-card {
  position: relative;
  display: grid;
  min-width: 0;
  grid-template-rows: 92px auto;
  gap: 9px;
  padding: 10px;
  border: 1px solid rgba(31, 123, 255, 0.12);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(246,250,255,0.96), rgba(255,255,255,0.98));
  color: var(--text);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}
.mega-card::after {
  content: "→";
  position: absolute;
  right: 10px;
  top: 10px;
  display: grid;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 999px;
  color: var(--blue-dark);
  background: rgba(255,255,255,0.86);
  box-shadow: 0 8px 18px rgba(31, 123, 255, 0.12);
  opacity: 0;
  transform: translate(4px, -4px);
  transition: opacity 180ms ease, transform 180ms ease, background 180ms ease, color 180ms ease;
}
.mega-card img {
  width: 100%;
  height: 92px;
  object-fit: contain;
  border-radius: 12px;
  background: rgba(244, 248, 255, 0.72);
  transition: transform 180ms ease, filter 180ms ease;
}
.mega-card span {
  display: block;
  min-height: 38px;
  color: #18345a;
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.18;
}
.mega-card:hover,
.mega-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(31, 123, 255, 0.3);
  background: #fff;
  box-shadow: 0 18px 42px rgba(15, 55, 115, 0.12);
  outline: none;
}
.mega-card:hover::after,
.mega-card:focus-visible::after {
  opacity: 1;
  transform: translate(0, 0);
  color: #fff;
  background: var(--blue);
}
.mega-card:hover img,
.mega-card:focus-visible img {
  transform: translateY(-3px) scale(1.04);
  filter: drop-shadow(0 12px 18px rgba(31, 123, 255, 0.12));
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 13px 20px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 760;
  font-size: 15px;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  color: #fff;
  background: linear-gradient(135deg, var(--blue) 0%, #0b55d9 100%);
  box-shadow: 0 14px 34px rgba(31, 123, 255, 0.28);
}
.btn-secondary {
  color: var(--blue-dark);
  background: rgba(255, 255, 255, 0.74);
  border-color: rgba(31, 123, 255, 0.24);
  box-shadow: 0 10px 26px rgba(15, 55, 115, 0.07);
}
.header-cta { margin-left: 6px; }
.menu-toggle { display: none; }

.hero {
  height: min(820px, calc(100svh - 100px));
  min-height: 620px;
  display: flex;
  align-items: center;
  padding: clamp(36px, 5vh, 64px) 0;
  background: #f7fbff;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(246, 250, 255, 0.97) 0%, rgba(246, 250, 255, 0.9) 34%, rgba(246, 250, 255, 0.54) 62%, rgba(246, 250, 255, 0.48) 100%),
    url("../assets/home/hero-digital-contour.webp") center right / cover no-repeat;
  transform: scale(1.015);
}
.hero-grid { position: relative; z-index: 2; }
.hero-copy { max-width: min(900px, 100%); }
.hero-lead {
  max-width: 730px;
  margin-bottom: 16px;
  font-size: clamp(18px, 1.8vw, 23px);
  line-height: 1.56;
}
.hero-note {
  display: inline-flex;
  max-width: 100%;
  padding: 10px 14px;
  margin-bottom: 28px;
  color: var(--blue-dark);
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(31, 123, 255, 0.18);
  border-radius: 999px;
  box-shadow: var(--shadow-soft);
  font-weight: 700;
  white-space: normal;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }

.section-bg-pattern {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(246, 250, 255, 0.86)),
    url("../assets/home/routes-soft-grid-background.webp") center / cover no-repeat;
  opacity: 0.8;
}
.section-head {
  position: relative;
  max-width: 760px;
  margin-bottom: 42px;
}
.route-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.route-card, .why-card, .step-card, .cta-card, .image-panel {
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(31, 123, 255, 0.16);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
.route-card {
  display: flex;
  flex-direction: column;
  min-height: 430px;
  padding: 28px;
  border-radius: var(--radius-md);
  color: inherit;
  text-decoration: none;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.route-card:hover,
.route-card:focus-visible {
  transform: translateY(-7px);
  border-color: rgba(31, 123, 255, 0.35);
  box-shadow: var(--shadow);
}
.route-card:focus-visible {
  outline: 3px solid rgba(31, 123, 255, 0.34);
  outline-offset: 4px;
}
.route-card:hover .route-visual,
.route-card:focus-visible .route-visual {
  transform: translateY(-4px) scale(1.025);
}
.route-visual {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: contain;
  margin-bottom: 22px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  transition: transform 0.25s ease;
}
.mini-asset {
  width: 78px;
  height: 78px;
  object-fit: contain;
  margin-bottom: 22px;
  padding: 8px;
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 22px;
  background: linear-gradient(180deg, #fff, #edf6ff);
  box-shadow: 0 12px 26px rgba(31, 123, 255, 0.1);
}
.route-card p { font-size: 15.5px; line-height: 1.55; }
.card-link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--blue-dark);
  font-weight: 800;
}
.card-link span { transition: transform 0.2s ease; }
.route-card:hover .card-link span,
.route-card:focus-visible .card-link span,
.card-link:hover span { transform: translateX(4px); }

.digital-loop {
  overflow: hidden;
  padding: 68px 0 74px;
  color: #f7fbff;
  background:
    radial-gradient(circle at 16% 10%, rgba(31, 123, 255, 0.28), transparent 28%),
    radial-gradient(circle at 86% 72%, rgba(99, 205, 255, 0.18), transparent 30%),
    linear-gradient(135deg, #061326 0%, #0a1e38 48%, #071a2e 100%);
}
.digital-loop::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
  pointer-events: none;
}
.digital-loop-head {
  position: relative;
  z-index: 1;
}
.digital-loop .eyebrow {
  color: #7ac4ff;
}
.digital-loop h2 {
  color: #fff;
}
.digital-loop .split-copy {
  max-width: 820px;
}
.digital-loop .split-copy p {
  max-width: 760px;
  color: rgba(235, 246, 255, 0.84);
}
.split-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(420px, 1fr);
  gap: 52px;
  align-items: center;
}
.split-copy { max-width: 560px; }
.image-panel {
  padding: 10px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.image-panel img {
  width: 100%;
  border-radius: 27px;
}
.steps-wrap {
  position: relative;
  z-index: 1;
  margin-top: 34px;
}
.step-grid {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 0;
  padding: 0;
}
.step-card {
  position: relative;
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  grid-template-rows: auto auto 1fr;
  column-gap: 18px;
  min-height: 204px;
  padding: 20px;
  overflow: hidden;
  border-radius: 26px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.055));
  border: 1px solid rgba(128, 201, 255, 0.2);
  box-shadow: 0 26px 60px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}
.step-card:hover {
  transform: translateY(-6px);
  border-color: rgba(116, 198, 255, 0.46);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.075));
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.3);
}
.step-card img {
  grid-row: 1 / 4;
  align-self: center;
  width: 150px;
  height: 150px;
  object-fit: contain;
  filter: drop-shadow(0 18px 26px rgba(20, 148, 255, 0.22));
  transition: transform 0.25s ease;
}
.step-card:hover img {
  transform: translateY(-4px) scale(1.035);
}
.step-card span {
  display: inline-flex;
  margin-bottom: 10px;
  color: #69c7ff;
  font-weight: 900;
  font-size: 13px;
}
.step-card h3 {
  color: #fff;
  font-size: 20px;
}
.step-card p {
  color: rgba(232, 245, 255, 0.78);
  font-size: 14.5px;
  line-height: 1.52;
}
.js .digital-loop .step-card.reveal {
  opacity: 1;
  transform: none;
}

.why { background: #f8fbff; }
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.why-card {
  padding: 34px;
  border-radius: var(--radius-md);
}
.why-card p { font-size: 16px; }

.applications {
  background:
    radial-gradient(circle at 20% 20%, rgba(31, 123, 255, 0.12), transparent 30%),
    linear-gradient(180deg, #fff 0%, #f5faff 100%);
}
.application-grid {
  display: grid;
  grid-template-columns: 0.82fr 1fr;
  gap: 56px;
  align-items: center;
}
.application-copy { max-width: 580px; }
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 26px;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid rgba(31, 123, 255, 0.16);
  box-shadow: var(--shadow-soft);
}
.chips span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 15px;
  color: #17406e;
  background: #fff;
  border: 1px solid rgba(31, 123, 255, 0.17);
  border-radius: 999px;
  font-weight: 720;
  box-shadow: 0 8px 24px rgba(15, 55, 115, 0.05);
}

.final-cta {
  padding: 98px 0;
  background: #f6faff;
}
.cta-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(246, 250, 255, 0.93), rgba(246, 250, 255, 0.72)),
    url("../assets/home/hero-digital-contour.webp") center / cover no-repeat;
  opacity: 0.68;
}
.cta-card {
  position: relative;
  display: grid;
  grid-template-columns: 1fr minmax(280px, 360px);
  gap: 38px;
  align-items: center;
  padding: clamp(30px, 5vw, 58px);
  border-radius: 38px;
}
.cta-card h2 { max-width: 640px; }
.cta-card p { max-width: 640px; }
.contact-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 0;
  padding: 24px;
  font-style: normal;
  color: var(--text);
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 24px;
}
.contact-card strong { color: var(--ink); font-size: 20px; }
.contact-card a { color: var(--blue-dark); font-weight: 750; }

.site-footer {
  padding: 62px 0 32px;
  color: #cbd7e8;
  background: #071b3a;
}
.site-footer h3 { color: #fff; }
.site-footer p { color: #a9bad3; font-size: 15px; }
.footer-logo {
  width: 150px;
  height: auto;
  margin-bottom: 16px;
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1.35fr) repeat(4, minmax(140px, 1fr));
  gap: 34px;
}
.footer-grid h3 {
  margin-bottom: 14px;
  font-size: 15px;
  letter-spacing: 0.02em;
}
.footer-grid a {
  display: block;
  margin: 9px 0;
  color: #c8d7ea;
}
.footer-grid a:hover { color: #fff; }
.footer-requisites {
  display: grid;
  gap: 6px;
  margin-top: 18px;
  color: #a9bad3;
  font-size: 14px;
  line-height: 1.45;
}
.footer-requisites span:first-child {
  color: #fff;
  font-weight: 760;
}
.footer-app-link {
  display: block;
  width: fit-content;
  margin: 10px 0;
}
.footer-app-link img {
  display: block;
  width: 146px;
  height: auto;
}
.footer-app-link:hover { opacity: 0.88; }
.footer-bottom {
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  color: #91a7c5;
  font-size: 14px;
}

.legal-utility-page {
  background: #f6f8fb;
}
.legal-utility {
  padding: 72px 0 88px;
}
.legal-utility-wrap {
  max-width: 920px;
}
.legal-utility-head {
  margin-bottom: 24px;
}
.legal-kicker {
  margin-bottom: 10px;
  color: var(--blue-dark);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.legal-utility-head h1 {
  margin-bottom: 12px;
  color: #10233f;
  font-size: 44px;
  line-height: 1.05;
}
.legal-utility-head p {
  margin-bottom: 0;
  color: #66758d;
}
.legal-utility-card {
  padding: clamp(24px, 4vw, 44px);
  border: 1px solid rgba(31, 123, 255, 0.12);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(15, 55, 115, 0.08);
}
.legal-utility-card h2 {
  margin-top: 34px;
  margin-bottom: 12px;
  color: #10233f;
  font-size: 25px;
  line-height: 1.18;
}
.legal-utility-card h3 {
  margin-top: 24px;
  margin-bottom: 10px;
  color: #17345b;
  font-size: 18px;
}
.legal-utility-card p,
.legal-utility-card dd {
  color: #3f4d63;
  font-size: 16px;
  line-height: 1.7;
}
.legal-utility-card a {
  color: var(--blue-dark);
  font-weight: 760;
}
.legal-utility-card dl {
  display: grid;
  gap: 12px;
  margin: 18px 0 0;
}
.legal-utility-card dt {
  color: #10233f;
  font-weight: 800;
}
.legal-utility-card dd {
  margin: -8px 0 0;
}

.reveal {
  opacity: 1;
  transform: none;
}
.js .reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.js .reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.js .route-card.reveal.is-visible:hover,
.js .route-card.reveal.is-visible:focus-visible,
.js .step-card.reveal.is-visible:hover {
  transform: translateY(-7px);
}
.route-card:nth-child(2), .why-card:nth-child(2), .step-card:nth-child(2) { transition-delay: 0.08s; }
.route-card:nth-child(3), .why-card:nth-child(3), .step-card:nth-child(3) { transition-delay: 0.16s; }
.route-card:nth-child(4), .step-card:nth-child(4) { transition-delay: 0.24s; }
.step-card:nth-child(5) { transition-delay: 0.32s; }
.step-card:nth-child(6) { transition-delay: 0.4s; }

@media (max-width: 1100px) {
  .route-grid { grid-template-columns: repeat(2, 1fr); }
  .route-card { min-height: 340px; }
  .split-layout, .application-grid { grid-template-columns: 1fr; }
  .split-copy, .application-copy { max-width: 760px; }
  .step-grid { grid-template-columns: repeat(2, 1fr); }
  .step-card {
    grid-template-columns: 128px minmax(0, 1fr);
    min-height: 220px;
  }
  .step-card img {
    width: 128px;
    height: 128px;
  }
  .footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 780px) {
  .container { width: min(calc(100% - 28px), var(--container)); }
  .section { padding: 72px 0; }
  .header-inner { height: 68px; }
  .brand-logo { width: 132px; }
  .header-cta { display: none; }
  .menu-toggle {
    position: absolute;
    top: 12px;
    right: 0;
    z-index: 3;
    display: inline-flex;
    flex-direction: column;
    gap: 5px;
    justify-content: center;
    align-items: center;
    width: 44px;
    height: 44px;
    margin-left: 0;
    border: 1px solid rgba(31, 123, 255, 0.18);
    border-radius: 14px;
    background: #fff;
  }
  .menu-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: var(--ink);
    transition: transform 0.2s ease, opacity 0.2s ease;
  }
  .main-nav {
    position: fixed;
    top: 68px;
    left: 14px;
    right: 14px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    padding: 12px;
    background: rgba(255, 255, 255, 0.96);
    border: 1px solid rgba(31, 123, 255, 0.16);
    border-radius: 22px;
    box-shadow: var(--shadow);
  }
  .main-nav.is-open { display: flex; }
  .main-nav > a,
  .main-nav .nav-link {
    width: 100%;
    padding: 14px 16px;
  }
  .mega-menu {
    position: static;
    display: grid;
    width: 100%;
    grid-auto-flow: column;
    grid-auto-columns: minmax(150px, 1fr);
    grid-template-columns: none;
    gap: 10px;
    margin-top: 4px;
    padding: 10px 2px 4px;
    overflow-x: auto;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    pointer-events: auto;
    transform: none;
    scroll-snap-type: x proximity;
  }
  .nav-item-solutions::after,
  .nav-item-products::after,
  .nav-item-development::after {
    display: none;
  }
  .nav-item:hover .mega-menu,
  .nav-item:focus-within .mega-menu {
    transform: none;
  }
  .mega-card {
    grid-template-rows: 82px auto;
    scroll-snap-align: start;
  }
  .mega-card img {
    height: 82px;
  }
  .hero {
    height: min(680px, calc(100svh - 84px));
    min-height: 560px;
    padding: 44px 0 36px;
  }
  .hero-bg {
    background:
      linear-gradient(180deg, rgba(246, 250, 255, 0.96) 0%, rgba(246, 250, 255, 0.92) 48%, rgba(246, 250, 255, 0.84) 100%),
      url("../assets/home/hero-digital-contour.webp") center right / cover no-repeat;
    opacity: 0.96;
  }
  h1 {
    font-size: clamp(30px, 8.2vw, 34px);
    line-height: 1.08;
  }
  h2 { font-size: clamp(30px, 8vw, 44px); }
  .hero-lead { font-size: 17px; }
  .hero-copy,
  .hero-copy > * {
    max-width: 100%;
  }
  .hero-note {
    display: block;
    border-radius: 20px;
  }
  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .route-grid, .why-grid, .step-grid, .cta-card, .footer-grid { grid-template-columns: 1fr; }
  .route-card { min-height: auto; padding: 24px; }
  .step-card {
    grid-template-columns: 104px minmax(0, 1fr);
    min-height: auto;
    padding: 18px;
    column-gap: 14px;
  }
  .step-card img {
    width: 104px;
    height: 104px;
  }
  .step-card span { margin-bottom: 10px; }
  .step-card h3 { font-size: 19px; }
  .step-card p { font-size: 14px; }
  .image-panel { border-radius: 24px; }
  .image-panel img { border-radius: 18px; }
  .cta-card { padding: 26px; border-radius: 28px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
  .js .reveal,
  .reveal {
    opacity: 1;
    transform: none;
  }
}

/* Modbus Gateway workflow-correct landing */
.modbus-page {
  --mg-bg: #030812;
  --mg-panel: rgba(6, 18, 32, 0.72);
  --mg-panel-strong: rgba(8, 24, 42, 0.86);
  --mg-line: rgba(91, 196, 255, 0.22);
  --mg-line-strong: rgba(91, 196, 255, 0.4);
  --mg-text: rgba(230, 242, 255, 0.86);
  --mg-muted: rgba(185, 204, 224, 0.72);
  --mg-cyan: #62d6ff;
  --mg-blue: #2f8cff;
  background: #020713;
  color: #f5f9ff;
}

.modbus-page :where(h1, h2, h3, p, a, button, span, strong, li) {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: manual !important;
  letter-spacing: 0;
}

.mg-slide {
  position: relative;
  isolation: isolate;
  height: calc(100vh - 1px);
  min-height: 0;
  padding: clamp(34px, 5vh, 62px) 0;
  display: flex;
  align-items: stretch;
  overflow: clip;
  background: var(--mg-bg);
}

.mg-slide + .mg-slide {
  border-top: 1px solid rgba(91, 196, 255, 0.08);
}

.mg-wf-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  pointer-events: none;
}

.mg-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(2, 7, 19, 0.05), rgba(2, 7, 19, 0.26)),
    radial-gradient(circle at 50% 100%, rgba(47, 140, 255, 0.12), transparent 36%);
}

.mg-slide-inner,
.mg-process-layout,
.mg-cards-wrap {
  position: relative;
  z-index: 1;
  width: min(calc(100% - 40px), var(--container));
  margin: auto;
}

.mg-slide-inner {
  display: grid;
  min-height: 0;
  height: calc(100vh - clamp(68px, 10vh, 124px) - 1px);
  align-items: center;
}

.mg-slide-inner--left {
  grid-template-columns: minmax(0, 0.44fr) minmax(0, 0.56fr);
}

.mg-slide-inner--right {
  grid-template-columns: minmax(0, 0.68fr) minmax(0, 0.32fr);
}

.mg-slide-inner--right .mg-copy {
  grid-column: 2;
}

.mg-slide-inner--left .mg-copy {
  max-width: 470px;
}

.mg-copy,
.mg-section-head,
.mg-process-copy {
  max-width: 600px;
}

.mg-copy {
  padding: 0;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.55);
}

.mg-kicker {
  margin: 0 0 12px;
  color: var(--mg-cyan);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.3;
  text-transform: uppercase;
}

.mg-copy h1,
.mg-copy h2,
.mg-section-head h2,
.mg-process-copy h2 {
  max-width: 100%;
  margin: 0 0 16px;
  color: #fff;
  font-size: clamp(42px, 4.7vw, 72px);
  line-height: 0.98;
}

.mg-copy h2,
.mg-section-head h2,
.mg-process-copy h2 {
  font-size: clamp(34px, 3.5vw, 54px);
  line-height: 1.02;
}

.mg-lead,
.mg-copy p,
.mg-section-head p,
.mg-process-copy p {
  margin: 0;
  color: var(--mg-text);
  font-size: clamp(17px, 1.28vw, 20px);
  line-height: 1.52;
}

.mg-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.mg-chip-list span,
.mg-process-note span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 9px 13px;
  border: 1px solid rgba(98, 214, 255, 0.24);
  border-radius: 8px;
  color: rgba(239, 249, 255, 0.9);
  background: rgba(6, 22, 39, 0.74);
  font-size: 14px;
  line-height: 1.2;
}

.mg-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.modbus-page .btn-secondary {
  border: 1px solid rgba(98, 214, 255, 0.32);
  color: #eaf8ff;
  background: rgba(5, 20, 36, 0.74);
}

.mg-cards-wrap {
  display: grid;
  min-height: 0;
  height: calc(100vh - clamp(68px, 10vh, 124px) - 1px);
  align-content: center;
  gap: clamp(18px, 3vh, 32px);
}

.mg-section-head {
  max-width: 940px;
}

.mg-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(12px, 1.5vw, 18px);
}

.mg-card {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(91, 196, 255, 0.16);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(7, 20, 36, 0.82), rgba(3, 11, 22, 0.88));
  box-shadow: 0 20px 54px rgba(0, 0, 0, 0.24);
}

.mg-card img {
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: contain;
  border-radius: 6px;
  background: #06101d;
}

.mg-card h3 {
  margin: 12px 0 8px;
  color: #fff;
  font-size: clamp(17px, 1.55vw, 21px);
  line-height: 1.14;
}

.mg-card p {
  margin: 0;
  color: var(--mg-muted);
  font-size: 14px;
  line-height: 1.45;
}

.mg-process-layout {
  min-height: 0;
  height: calc(100vh - clamp(68px, 10vh, 124px) - 1px);
  display: grid;
  grid-template-rows: minmax(0, 0.30fr) minmax(0, 0.40fr) minmax(0, 0.30fr);
  align-items: center;
}

.mg-process-copy {
  grid-row: 1;
  align-self: start;
  max-width: 940px;
  padding: 0;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.62);
}

.mg-process-copy h2 {
  margin-bottom: 8px;
  font-size: clamp(34px, 3.2vw, 50px);
}

.mg-process-copy p {
  font-size: clamp(16px, 1.15vw, 18px);
  line-height: 1.46;
}

.mg-process-note {
  grid-row: 3;
  align-self: end;
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  max-width: 860px;
  padding: 16px 0 0;
}

@media (max-width: 1180px) {
  .mg-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mg-card img {
    max-height: 132px;
  }
}

@media (max-width: 900px) {
  .mg-slide {
    padding: 28px 0;
  }

  .mg-slide-inner,
  .mg-process-layout,
  .mg-cards-wrap {
    width: min(calc(100% - 28px), var(--container));
  }

  .mg-slide-inner--left,
  .mg-slide-inner--right {
    grid-template-columns: 1fr;
    align-content: end;
  }

  .mg-slide-inner--right .mg-copy {
    grid-column: 1;
  }

  .mg-copy,
  .mg-process-copy {
    max-width: min(620px, 100%);
    padding: 0;
  }

  .mg-wf-bg {
    object-position: center top;
  }

  .mg-process-layout {
    grid-template-rows: minmax(0, 0.30fr) minmax(0, 0.40fr) minmax(0, 0.30fr);
  }

  .mg-process-copy h2 {
    font-size: clamp(26px, 4vw, 34px);
    line-height: 1;
  }

  .mg-process-copy p {
    font-size: 15px;
    line-height: 1.36;
  }
}

@media (max-width: 560px) {
  .mg-slide {
    padding: 18px 0;
  }

  .mg-slide-inner,
  .mg-process-layout,
  .mg-cards-wrap {
    width: min(calc(100% - 22px), var(--container));
    min-height: 0;
    height: calc(100vh - 36px);
  }

  .mg-slide-inner--left,
  .mg-slide-inner--right {
    align-content: center;
  }

  .mg-copy,
  .mg-process-copy {
    max-width: min(330px, calc(100vw - 24px));
    padding: 0;
  }

  .mg-copy h1 {
    max-width: 300px;
    font-size: clamp(25px, 7.3vw, 30px);
    line-height: 1.04;
  }

  .mg-copy h2,
  .mg-section-head h2,
  .mg-process-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(24px, 6.6vw, 32px);
    line-height: 1.08;
  }

  .mg-lead,
  .mg-copy p,
  .mg-section-head p,
  .mg-process-copy p {
    max-width: min(330px, calc(100vw - 24px));
    font-size: 13.5px;
    line-height: 1.44;
  }

  .mg-kicker {
    margin-bottom: 7px;
    font-size: 10px;
  }

  .mg-chip-list {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    max-width: min(330px, calc(100vw - 24px));
    gap: 6px;
    margin-top: 10px;
  }

  .mg-chip-list span,
  .mg-process-note span {
    max-width: 100%;
    min-height: 26px;
    padding: 6px 7px;
    font-size: 10.5px;
  }

  .mg-actions {
    gap: 8px;
    margin-top: 12px;
  }

  .mg-actions .btn {
    max-width: 100%;
    min-height: 40px;
    padding: 10px 11px;
    font-size: 12.5px;
  }

  .mg-cards-wrap {
    gap: 10px;
  }

  .mg-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .mg-card {
    padding: 8px;
  }

  .mg-card img {
    max-height: 68px;
  }

  .mg-card h3 {
    margin: 7px 0 5px;
    font-size: 13px;
    line-height: 1.12;
  }

  .mg-card p {
    font-size: 11px;
    line-height: 1.25;
  }

  .mg-section-head {
    max-width: 100%;
  }

  .mg-process-copy {
    align-self: start;
  }

  .mg-process-note {
    gap: 6px;
    padding-top: 8px;
  }
}

@media (max-height: 820px) and (min-width: 900px) {
  .mg-copy {
    max-width: 560px;
    padding: 0;
  }

  .mg-copy h1 {
    margin-bottom: 10px;
    font-size: clamp(36px, 3.7vw, 54px);
    line-height: 1.02;
  }

  .mg-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(30px, 3vw, 44px);
    line-height: 1.04;
  }

  .mg-lead,
  .mg-copy p {
    font-size: 16px;
    line-height: 1.42;
  }

  .mg-chip-list {
    gap: 6px;
    margin-top: 10px;
  }

  .mg-chip-list span {
    min-height: 32px;
    padding: 7px 10px;
    font-size: 12px;
  }

  .mg-actions {
    gap: 8px;
    margin-top: 12px;
  }

  .mg-actions .btn {
    min-height: 40px;
    padding: 10px 12px;
    font-size: 13px;
  }

  .mg-process-copy {
    padding: 0;
  }

  .mg-process-copy h2 {
    font-size: clamp(28px, 2.65vw, 38px);
  }
}

body :where(a, p, h1, h2, h3, h4, span, strong, li, button) {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: manual !important;
}


.modbus-page {
  background: #06101d;
}

.modbus-hero,
.modbus-scene {
  position: relative;
  min-height: min(820px, calc(100svh - 76px));
  display: flex;
  align-items: center;
  overflow: hidden;
  color: #fff;
  background: #06101d;
}

.modbus-hero {
  min-height: min(840px, calc(100svh - 76px));
}

.modbus-bg,
.modbus-shade {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.modbus-bg {
  object-fit: cover;
  object-position: center right;
}

.modbus-shade {
  background:
    radial-gradient(circle at 72% 58%, rgba(31, 123, 255, 0.1), transparent 28rem),
    linear-gradient(90deg, rgba(4, 10, 20, 0.98) 0%, rgba(4, 10, 20, 0.9) 34%, rgba(4, 10, 20, 0.44) 62%, rgba(4, 10, 20, 0.08) 100%),
    linear-gradient(180deg, rgba(4, 10, 20, 0.06), rgba(4, 10, 20, 0.7));
}

.modbus-hero-inner,
.modbus-scene-inner {
  position: relative;
  z-index: 1;
  padding: clamp(76px, 10vw, 136px) 0;
}

.modbus-copy {
  width: min(680px, 100%);
}

.modbus-copy h1,
.modbus-copy h2 {
  max-width: 680px;
  margin-bottom: 24px;
  color: #fff;
  font-size: clamp(44px, 6.2vw, 84px);
  line-height: 0.98;
}

.modbus-copy h2 {
  font-size: clamp(38px, 4.6vw, 66px);
  line-height: 1;
}

.modbus-lead {
  max-width: 660px;
  margin-bottom: 18px;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(20px, 2vw, 27px);
  line-height: 1.34;
}

.modbus-text,
.modbus-copy p,
.modbus-list {
  max-width: 640px;
  color: rgba(219, 235, 250, 0.84);
  font-size: 17px;
  line-height: 1.72;
}

.modbus-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.modbus-ghost {
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
}

.modbus-strip,
.modbus-benefits,
.modbus-economy,
.modbus-mail {
  background: #f5f8fc;
}

.modbus-strip {
  padding: 28px 0;
}

.modbus-strip-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.modbus-chip,
.modbus-card,
.modbus-price-grid > div {
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 18px 50px rgba(11, 45, 76, 0.1);
}

.modbus-chip {
  padding: 20px;
}

.modbus-chip strong,
.modbus-chip span {
  display: block;
}

.modbus-chip strong {
  margin-bottom: 6px;
  color: #071b3a;
  font-size: 20px;
}

.modbus-chip span {
  color: #5a6f8c;
  font-size: 14px;
  line-height: 1.45;
}

.modbus-scene-right .modbus-scene-inner {
  display: flex;
  justify-content: flex-start;
}

.modbus-scene-right .modbus-shade {
  background:
    radial-gradient(circle at 72% 58%, rgba(31, 123, 255, 0.1), transparent 28rem),
    linear-gradient(90deg, rgba(4, 10, 20, 0.98) 0%, rgba(4, 10, 20, 0.9) 34%, rgba(4, 10, 20, 0.44) 62%, rgba(4, 10, 20, 0.08) 100%),
    linear-gradient(180deg, rgba(4, 10, 20, 0.06), rgba(4, 10, 20, 0.7));
}

.modbus-scene-light {
  color: #071b3a;
  background: #f5f8fc;
}

.modbus-scene-light .modbus-bg {
  opacity: 0.94;
}

.modbus-scene-light .modbus-shade {
  background:
    linear-gradient(90deg, rgba(245, 248, 252, 0.98) 0%, rgba(245, 248, 252, 0.92) 35%, rgba(245, 248, 252, 0.56) 64%, rgba(245, 248, 252, 0.16) 100%),
    linear-gradient(180deg, rgba(245, 248, 252, 0.1), rgba(245, 248, 252, 0.72));
}

.modbus-scene-light .modbus-copy h2 {
  color: #071b3a;
}

.modbus-scene-light .modbus-copy p {
  color: #29405f;
}

.modbus-scene-light .modbus-list li,
.modbus-scene-light .modbus-specs span {
  color: #0c315c;
  background: rgba(255, 255, 255, 0.74);
  border-color: rgba(31, 123, 255, 0.2);
  box-shadow: 0 12px 34px rgba(15, 55, 115, 0.08);
}

.modbus-list {
  display: grid;
  gap: 10px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.modbus-list li {
  padding: 13px 16px;
  border: 1px solid rgba(119, 213, 255, 0.2);
  border-radius: 16px;
  background: rgba(6, 22, 38, 0.62);
}

.modbus-specs,
.modbus-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.modbus-specs span,
.modbus-flow span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid rgba(119, 213, 255, 0.24);
  border-radius: 999px;
  color: #dff7ff;
  background: rgba(6, 22, 38, 0.62);
  font-weight: 780;
}

.modbus-section-head {
  max-width: 780px;
  margin-bottom: 34px;
}

.modbus-section-head h2 {
  color: #071b3a;
}

.modbus-section-head p {
  max-width: 700px;
  color: #5a6f8c;
  font-size: 18px;
}

.modbus-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.modbus-card {
  min-width: 0;
  padding: 24px;
}

.modbus-card h3 {
  color: #071b3a;
}

.modbus-card p {
  color: #5a6f8c;
  font-size: 15.5px;
}

.modbus-card-visual {
  display: block;
  width: min(156px, 74%);
  height: 132px;
  margin: -2px 0 18px;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 18px 28px rgba(31, 123, 255, 0.16));
}

.modbus-economy-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 30px;
  align-items: center;
}

.modbus-price-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.modbus-price-grid > div {
  padding: 24px;
}

.modbus-price-grid span {
  color: #0b4cbd;
  font-size: 12px;
  font-weight: 840;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.modbus-price-grid strong {
  display: block;
  margin: 12px 0;
  color: #071b3a;
  font-size: clamp(34px, 3.4vw, 48px);
  line-height: 1;
}

.modbus-price-grid p {
  margin: 0;
  color: #5a6f8c;
  font-size: 15px;
}

.modbus-page .generated-band,
.modbus-page .generated-cta {
  background: #f5f8fc;
}

.modbus-mail-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 28px;
  align-items: center;
  padding: clamp(28px, 5vw, 52px);
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(237, 246, 255, 0.92));
  box-shadow: 0 24px 70px rgba(15, 55, 115, 0.12);
}

.modbus-mail-card h2 {
  max-width: 720px;
  color: #071b3a;
}

.modbus-mail-card p {
  max-width: 760px;
  margin: 0;
  color: #29405f;
}

@media (max-width: 1100px) {
  .modbus-strip-grid,
  .modbus-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .modbus-economy-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px) {
  .modbus-hero,
  .modbus-scene {
    min-height: auto;
  }
  .modbus-bg {
    object-position: 68% center;
  }
  .modbus-shade,
  .modbus-scene-right .modbus-shade {
    background:
      linear-gradient(180deg, rgba(4, 10, 20, 0.98) 0%, rgba(4, 10, 20, 0.9) 58%, rgba(4, 10, 20, 0.58) 100%);
  }
  .modbus-scene-light .modbus-shade {
    background:
      linear-gradient(180deg, rgba(245, 248, 252, 0.98) 0%, rgba(245, 248, 252, 0.9) 58%, rgba(245, 248, 252, 0.62) 100%);
  }
  .modbus-hero-inner,
  .modbus-scene-inner {
    padding: 82px 0 70px;
  }
  .modbus-copy,
  .modbus-copy h1,
  .modbus-copy h2,
  .modbus-lead,
  .modbus-text,
  .modbus-copy p,
  .modbus-list {
    max-width: min(340px, calc(100vw - 34px));
  }
  .modbus-copy h1 {
    font-size: clamp(38px, 10vw, 48px);
  }
  .modbus-copy h2 {
    font-size: clamp(31px, 8.3vw, 40px);
  }
  .modbus-lead {
    font-size: 19px;
  }
  .modbus-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .modbus-actions .btn {
    width: 100%;
  }
  .modbus-mail-card {
    grid-template-columns: 1fr;
    padding: 24px;
    border-radius: 24px;
  }
  .modbus-mail-card .btn {
    width: 100%;
  }
  .modbus-strip-grid,
  .modbus-card-grid,
  .modbus-price-grid {
    grid-template-columns: 1fr;
  }
  .modbus-card {
    padding: 20px;
  }
}

.solutions-page {
  background: #f7fbff;
}

.solutions-hero {
  position: relative;
  height: min(820px, calc(100svh - 96px));
  min-height: 640px;
  display: flex;
  align-items: center;
  overflow: clip;
}

.solutions-hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(247, 251, 255, 0.08) 0%, rgba(247, 251, 255, 0.12) 42%, rgba(247, 251, 255, 0.02) 100%),
    url("../assets/solutions/hero-solutions-map.webp") center / cover no-repeat;
}

.solutions-hero-grid {
  position: relative;
  z-index: 1;
  display: block;
}

.solutions-hero h1 {
  max-width: 620px;
  margin-bottom: 24px;
  font-size: clamp(38px, 4.4vw, 62px);
  line-height: 1;
}

.solutions-hero-copy {
  width: min(620px, 100%);
  padding: clamp(28px, 4vw, 46px);
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 24px 74px rgba(15, 55, 115, 0.13);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.solutions-hero-copy p {
  max-width: 690px;
  margin-bottom: 28px;
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.55;
}

.solutions-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.solutions-map {
  display: none;
}

.solutions-map img {
  display: none;
}

.solutions-section-head {
  position: relative;
  max-width: 760px;
  margin-bottom: 34px;
}

.solutions-section-head h2,
.matrix-copy h2,
.implementation-copy h2 {
  margin-bottom: 16px;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.02;
}

.solutions-section-head p,
.matrix-copy p {
  font-size: 18px;
}

.solution-selector {
  background: linear-gradient(180deg, #fff 0%, #f4f9ff 100%);
}

.selector-bg {
  position: absolute;
  inset: 0;
  background: url("../assets/solutions/bg-solutions-cards.webp") center / cover no-repeat;
  opacity: 0.34;
  pointer-events: none;
}

.selector-layout {
  position: relative;
  display: grid;
  grid-template-columns: minmax(300px, 0.38fr) minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
}

.solution-rail {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 18px;
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-soft);
}

.solution-rail a {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 12px;
  align-items: center;
  min-height: 54px;
  padding: 10px 12px;
  border-radius: 18px;
  color: #183456;
  font-weight: 760;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.solution-rail a:hover {
  color: var(--blue-dark);
  background: #eef6ff;
  transform: translateX(3px);
}

.solution-rail span {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  color: var(--blue-dark);
  background: #fff;
  border: 1px solid rgba(31, 123, 255, 0.16);
  font-size: 12px;
  font-weight: 900;
}

.solution-preview {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding: 28px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: var(--shadow-soft);
}

.preview-media {
  align-self: stretch;
  min-width: 0;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  border-radius: 24px;
  background: #fff;
}

.preview-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 10px;
}

.preview-copy {
  align-self: center;
  min-width: 0;
  max-width: 780px;
}

.preview-copy h3 {
  max-width: 520px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.04;
}

.preview-copy p {
  font-size: 17px;
}

.preview-copy ul {
  display: grid;
  gap: 12px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

.preview-copy li {
  padding: 14px 16px;
  border-left: 3px solid var(--blue);
  border-radius: 14px;
  color: #29405f;
  background: rgba(238, 246, 255, 0.8);
}

.solutions-matrix {
  background: #fff;
}

.matrix-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.62fr) minmax(0, 1fr);
  gap: 46px;
  align-items: start;
}

.matrix-copy {
  position: sticky;
  top: 110px;
}

.matrix-table {
  display: grid;
  gap: 14px;
}

.matrix-table > div {
  display: grid;
  grid-template-columns: 74px 48px minmax(150px, 0.32fr) minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 104px;
  padding: 22px;
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 22px;
  background: linear-gradient(180deg, #fff, #f6faff);
  box-shadow: 0 14px 38px rgba(15, 55, 115, 0.06);
}

.matrix-icon {
  display: block;
  width: 66px;
  height: 66px;
  object-fit: contain;
}

.matrix-table span {
  display: inline-grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border-radius: 16px;
  color: var(--blue-dark);
  background: #edf6ff;
  font-weight: 900;
}

.matrix-table strong {
  color: var(--ink);
  font-size: 20px;
}

.matrix-table p {
  margin: 0;
  font-size: 15.5px;
}

.implementation-strip {
  background: #f5faff;
}

.implementation-bg {
  position: absolute;
  inset: 0;
  background: url("../assets/solutions/bg-solutions-map-lines.webp") center / cover no-repeat;
  opacity: 0.24;
}

.implementation-flow {
  position: relative;
  display: grid;
  gap: 34px;
}

.implementation-copy {
  max-width: 960px;
}

.implementation-copy p {
  max-width: 680px;
  font-size: 18px;
}

.implementation-cards {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.implementation-cards article {
  min-height: 100%;
  padding: 0 4px;
}

.implementation-cards img {
  display: block;
  width: 100%;
  aspect-ratio: 0.7;
  object-fit: contain;
  margin-bottom: 18px;
}

.implementation-cards h3 {
  font-size: 19px;
  margin: 0 8px 10px;
}

.implementation-cards p {
  margin: 0 8px;
  font-size: 15.5px;
}

.generated-page {
  background: linear-gradient(180deg, #fff 0%, #f4f9ff 44%, #fff 100%);
}

.js .generated-page .reveal,
.generated-page .reveal {
  opacity: 1;
  transform: none;
}

.generated-hero {
  min-height: min(760px, calc(100svh - 76px));
  display: flex;
  align-items: center;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.9) 46%, rgba(238,246,255,0.72) 100%),
    url("../assets/solutions/bg-solutions-map-lines.webp") center / cover no-repeat;
}

.generated-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.8fr);
  gap: 44px;
  align-items: center;
}

.generated-hero-copy {
  max-width: 760px;
  min-width: 0;
}

.generated-hero-copy h1 {
  font-size: clamp(42px, 5vw, 70px);
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.generated-hero-copy p {
  max-width: 680px;
  color: var(--text);
  font-size: clamp(18px, 1.7vw, 22px);
  line-height: 1.55;
}

.generated-hero-visual {
  width: min(520px, 100%);
  justify-self: center;
  filter: drop-shadow(0 24px 40px rgba(15,55,115,0.13));
}

.generated-list,
.generated-detail {
  background: #fff;
}

.generated-band {
  background:
    linear-gradient(180deg, rgba(245,250,255,0.96), rgba(238,246,255,0.9)),
    url("../assets/solutions/bg-solutions-cards.webp") center / cover no-repeat;
}

.generated-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.generated-card {
  min-width: 0;
  min-height: 100%;
  padding: 22px;
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 24px;
  background: rgba(255,255,255,0.86);
  box-shadow: var(--shadow-soft);
}

.generated-card img {
  width: 100%;
  aspect-ratio: 1.35;
  object-fit: contain;
  margin-bottom: 12px;
}

.generated-card h3 {
  font-size: 22px;
  line-height: 1.12;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.generated-card p {
  color: var(--text);
  font-size: 15.5px;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.cases-overview {
  background: #fff;
}

.cases-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(360px, 0.55fr);
  gap: 34px;
  align-items: end;
}

.cases-proof-grid {
  display: grid;
  gap: 14px;
}

.cases-proof-grid div {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  min-height: 86px;
  padding: 18px 20px;
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 22px;
  background: rgba(255,255,255,0.86);
  box-shadow: var(--shadow-soft);
}

.cases-proof-grid strong {
  color: var(--blue-dark);
  font-size: 42px;
  line-height: 1;
}

.cases-proof-grid span {
  color: var(--text);
  font-weight: 740;
  line-height: 1.32;
}

.cases-study-list {
  background:
    linear-gradient(180deg, rgba(245,250,255,0.96), rgba(255,255,255,0.96)),
    url("../assets/solutions/bg-solutions-cards.webp") center / cover no-repeat;
}

.case-study-grid {
  display: grid;
  gap: 24px;
}

.case-study-card {
  display: grid;
  grid-template-columns: minmax(360px, 0.92fr) minmax(0, 1fr);
  gap: 28px;
  align-items: stretch;
  min-width: 0;
  padding: 18px;
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: var(--shadow-soft);
}

.case-study-media {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 20px;
  background: linear-gradient(135deg, #eaf5ff, #fff);
}

.case-study-media img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  border-radius: 18px;
}

.case-study-content {
  display: flex;
  min-width: 0;
  flex-direction: column;
  padding: 6px 8px 6px 0;
}

.case-study-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}

.case-study-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 999px;
  color: var(--blue-dark);
  background: rgba(255,255,255,0.84);
  font-size: 12px;
  font-weight: 820;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.case-study-card h3 {
  margin-bottom: 18px;
  font-size: clamp(24px, 2.4vw, 36px);
  line-height: 1.08;
}

.case-study-facts {
  display: grid;
  gap: 12px;
  margin: 0;
}

.case-study-facts div {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 14px;
}

.case-study-facts dt {
  color: var(--blue-dark);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.case-study-facts dd {
  margin: 0;
  color: var(--text);
  font-size: 15.5px;
  line-height: 1.52;
}

.case-study-products {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 18px;
}

.case-study-products span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid rgba(31,123,255,0.14);
  border-radius: 999px;
  color: #17406e;
  background: #fff;
  font-size: 12px;
  font-weight: 760;
}

.cases-method {
  background: #fff;
}

/* Cases workflow-correct landing */
.cases-page {
  --cases-bg: #05080d;
  --cases-panel: rgba(7, 18, 28, 0.72);
  --cases-panel-strong: rgba(9, 23, 36, 0.9);
  --cases-line: rgba(91, 213, 255, 0.2);
  --cases-line-strong: rgba(139, 224, 199, 0.34);
  --cases-text: rgba(238, 246, 252, 0.88);
  --cases-muted: rgba(196, 211, 224, 0.76);
  --cases-cyan: #5bd5ff;
  --cases-mint: #8be0c7;
  --cases-amber: #f1b85b;
  background: var(--cases-bg);
  color: #f7fbff;
}

.cases-page :where(h1, h2, h3, p, a, button, span, strong, li, dt, dd, label, input, textarea) {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: manual !important;
  letter-spacing: 0;
}

.cases-slide {
  position: relative;
  isolation: isolate;
  display: flex;
  align-items: stretch;
  min-height: calc(100svh - 1px);
  padding: clamp(34px, 5vh, 62px) 0;
  overflow: clip;
  background:
    radial-gradient(circle at 10% 0%, rgba(139, 224, 199, 0.08), transparent 24%),
    var(--cases-bg);
}

.cases-slide + .cases-slide {
  border-top: 1px solid rgba(91, 213, 255, 0.08);
}

.cases-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  pointer-events: none;
}

.cases-slide-inner,
.cases-process-layout,
.cases-catalog-wrap {
  position: relative;
  z-index: 1;
  width: min(calc(100% - 40px), var(--container));
  margin: auto;
}

.cases-slide-inner {
  display: grid;
  min-height: 0;
  height: calc(100svh - clamp(68px, 10vh, 124px) - 1px);
  align-items: center;
}

.cases-slide-inner--left {
  grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
}

.cases-copy {
  max-width: 460px;
  color: #fff;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.64);
}

.cases-kicker {
  margin: 0 0 12px;
  color: var(--cases-mint);
  font-size: 12px;
  font-weight: 840;
  line-height: 1.25;
  text-transform: uppercase;
}

.cases-copy h1,
.cases-copy h2,
.cases-section-head h2,
.cases-process-copy h2 {
  max-width: 100%;
  margin: 0 0 16px;
  color: #fff;
  font-size: clamp(40px, 4.2vw, 68px);
  line-height: 1.02;
}

.cases-copy h2,
.cases-section-head h2,
.cases-process-copy h2 {
  font-size: clamp(34px, 3.4vw, 54px);
  line-height: 1.04;
}

.cases-lead,
.cases-copy p,
.cases-section-head p,
.cases-process-copy p {
  margin: 0;
  color: var(--cases-text);
  font-size: clamp(17px, 1.25vw, 20px);
  line-height: 1.52;
}

.cases-hero-list {
  display: grid;
  gap: 8px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.cases-hero-list li {
  position: relative;
  padding-left: 20px;
  color: var(--cases-text);
  font-size: 15px;
  line-height: 1.42;
}

.cases-hero-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--cases-amber);
}

.cases-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.cases-page .btn-secondary {
  border: 1px solid rgba(91, 213, 255, 0.28);
  color: #eef9ff;
  background: rgba(7, 22, 35, 0.74);
}

.cases-process-layout {
  display: grid;
  grid-template-rows: minmax(0, 0.30fr) minmax(0, 0.40fr) minmax(0, 0.30fr);
  min-height: 0;
  height: calc(100svh - clamp(68px, 10vh, 124px) - 1px);
  align-items: center;
}

.cases-process-copy {
  grid-row: 1;
  align-self: start;
  max-width: 940px;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.64);
}

.cases-process-copy h2 {
  margin-bottom: 8px;
  font-size: clamp(32px, 3vw, 50px);
}

.cases-process-copy p {
  max-width: 920px;
  font-size: clamp(16px, 1.12vw, 18px);
  line-height: 1.45;
}

.cases-process-note {
  grid-row: 3;
  align-self: end;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 980px;
  padding: 12px 0 0;
}

.cases-process-note span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 9px 12px;
  border: 1px solid var(--cases-line-strong);
  border-radius: 8px;
  color: rgba(241, 250, 255, 0.92);
  background: rgba(6, 20, 32, 0.76);
  font-size: 14px;
  line-height: 1.28;
}

.cases-process-note b {
  margin-right: 6px;
  color: var(--cases-mint);
}

.cases-method-note {
  align-items: center;
}

.cases-method-note .btn {
  min-height: 42px;
}

.cases-catalog {
  display: block;
  min-height: auto;
  height: auto;
  padding: clamp(72px, 8vw, 112px) 0;
  overflow: visible;
  background:
    linear-gradient(180deg, rgba(5, 8, 13, 0.94), rgba(8, 13, 20, 0.98)),
    var(--cases-bg);
}

.cases-bg--catalog {
  object-position: center top;
}

.cases-catalog-wrap {
  display: grid;
  gap: clamp(28px, 4vw, 42px);
}

.cases-section-head {
  max-width: 980px;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.58);
}

.cases-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 1.6vw, 22px);
}

.cases-card {
  display: flex;
  min-width: 0;
  flex-direction: column;
  padding: 12px;
  border: 1px solid rgba(91, 213, 255, 0.16);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(9, 23, 36, 0.9), rgba(5, 12, 21, 0.96));
  box-shadow: 0 24px 62px rgba(0, 0, 0, 0.24);
}

.cases-card-media {
  min-width: 0;
  border-radius: 7px;
  background: #071420;
}

.cases-card-media img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  border-radius: 7px;
}

.cases-card-content {
  display: flex;
  flex: 1 1 auto;
  min-width: 0;
  flex-direction: column;
  padding: 14px 2px 2px;
}

.cases-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.cases-card-meta span,
.cases-card-products span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 6px 8px;
  border: 1px solid rgba(91, 213, 255, 0.18);
  border-radius: 8px;
  color: rgba(230, 248, 255, 0.9);
  background: rgba(8, 24, 38, 0.76);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.2;
}

.cases-card h3 {
  margin: 0 0 14px;
  color: #fff;
  font-size: clamp(19px, 1.65vw, 24px);
  line-height: 1.14;
}

.cases-card-facts {
  display: grid;
  gap: 10px;
  margin: 0;
}

.cases-card-facts div {
  display: grid;
  gap: 4px;
}

.cases-card-facts dt {
  color: var(--cases-mint);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.2;
  text-transform: uppercase;
}

.cases-card-facts dd {
  margin: 0;
  color: var(--cases-muted);
  font-size: 13.5px;
  line-height: 1.48;
}

.cases-card-products {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: auto;
  padding-top: 14px;
}

.cases-card-products span {
  color: rgba(251, 239, 202, 0.92);
  border-color: rgba(241, 184, 91, 0.2);
}

.cases-cta-copy {
  max-width: 460px;
}

.cases-contact-form {
  margin-top: 20px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.cases-contact-form label {
  color: rgba(238, 246, 252, 0.9);
}

.cases-contact-form input,
.cases-contact-form textarea {
  color: #f7fbff;
  border-color: rgba(91, 213, 255, 0.22);
  background: rgba(5, 16, 26, 0.76);
}

.cases-contact-form input:focus,
.cases-contact-form textarea:focus {
  border-color: rgba(139, 224, 199, 0.7);
  box-shadow: 0 0 0 3px rgba(139, 224, 199, 0.14);
}

@media (max-width: 1180px) {
  .cases-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .cases-slide {
    padding: 28px 0;
  }

  .cases-slide-inner,
  .cases-process-layout,
  .cases-catalog-wrap {
    width: min(calc(100% - 28px), var(--container));
  }

  .cases-slide-inner--left {
    grid-template-columns: 1fr;
    align-content: center;
  }

  .cases-copy,
  .cases-process-copy,
  .cases-section-head {
    max-width: min(620px, 100%);
  }

  .cases-process-copy h2 {
    font-size: clamp(28px, 3.5vw, 34px);
  }

  .cases-process-copy p {
    font-size: 14.5px;
    line-height: 1.34;
  }

  .cases-bg {
    object-position: center top;
  }

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

  .cases-contact-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .cases-slide {
    padding: 18px 0;
  }

  .cases-slide-inner,
  .cases-process-layout {
    width: min(calc(100% - 22px), var(--container));
    height: calc(100svh - 36px);
  }

  .cases-copy,
  .cases-process-copy,
  .cases-section-head {
    max-width: min(330px, calc(100vw - 24px));
  }

  .cases-copy h1 {
    max-width: 326px;
    font-size: clamp(27px, 7.4vw, 34px);
    line-height: 1.06;
  }

  .cases-copy h2,
  .cases-section-head h2,
  .cases-process-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(24px, 6.6vw, 32px);
    line-height: 1.08;
  }

  .cases-lead,
  .cases-copy p,
  .cases-section-head p,
  .cases-process-copy p {
    max-width: min(330px, calc(100vw - 24px));
    font-size: 13.5px;
    line-height: 1.42;
  }

  .cases-kicker {
    margin-bottom: 7px;
    font-size: 10px;
  }

  .cases-hero-list {
    gap: 6px;
    margin-top: 10px;
  }

  .cases-hero-list li {
    padding-left: 15px;
    font-size: 12.5px;
    line-height: 1.28;
  }

  .cases-hero-list li::before {
    width: 6px;
    height: 6px;
  }

  .cases-actions {
    display: grid;
    gap: 8px;
    margin-top: 12px;
  }

  .cases-actions .btn,
  .cases-method-note .btn,
  .cases-contact-form .btn {
    width: 100%;
    min-height: 40px;
    padding: 10px 11px;
    font-size: 12.5px;
  }

  .cases-process-layout {
    grid-template-rows: minmax(0, 0.34fr) minmax(0, 0.34fr) minmax(0, 0.32fr);
  }

  .cases-process-note {
    gap: 6px;
    padding-top: 8px;
  }

  .cases-process-note span {
    min-height: 28px;
    padding: 6px 7px;
    font-size: 10.5px;
  }

  .cases-method-note {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: min(330px, calc(100vw - 24px));
  }

  .cases-method-note .btn {
    grid-column: 1 / -1;
  }

  .cases-catalog {
    padding: 46px 0;
  }

  .cases-catalog-wrap {
    width: min(calc(100% - 22px), var(--container));
    gap: 22px;
  }

  .cases-card-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .cases-card {
    padding: 10px;
  }

  .cases-card h3 {
    font-size: clamp(19px, 5.2vw, 23px);
  }

  .cases-card-facts dd {
    font-size: 13px;
    line-height: 1.45;
  }

  .cases-card-meta span,
  .cases-card-products span {
    font-size: 10.5px;
  }

  .cases-contact-form {
    gap: 8px;
    margin-top: 12px;
  }

  .cases-contact-form label {
    gap: 4px;
    font-size: 11.5px;
  }

  .cases-contact-form input,
  .cases-contact-form textarea {
    min-height: 36px;
    padding: 8px 9px;
    font-size: 13px;
  }

  .cases-contact-form textarea {
    min-height: 74px;
  }

  .cases-contact-form .form-consent {
    font-size: 10.5px;
    line-height: 1.25;
  }
}

@media (max-height: 820px) and (min-width: 900px) {
  .cases-copy {
    max-width: 520px;
  }

  .cases-copy h1 {
    margin-bottom: 10px;
    font-size: clamp(36px, 3.4vw, 54px);
    line-height: 1.03;
  }

  .cases-copy h2 {
    margin-bottom: 8px;
    font-size: clamp(30px, 2.9vw, 44px);
  }

  .cases-lead,
  .cases-copy p {
    font-size: 15.5px;
    line-height: 1.4;
  }

  .cases-hero-list {
    gap: 6px;
    margin-top: 10px;
  }

  .cases-hero-list li {
    font-size: 13px;
  }

  .cases-actions {
    gap: 8px;
    margin-top: 12px;
  }

  .cases-actions .btn {
    min-height: 40px;
    padding: 10px 12px;
    font-size: 13px;
  }

  .cases-process-copy h2 {
    font-size: clamp(28px, 2.5vw, 38px);
  }

  .cases-process-copy p {
    font-size: 15px;
    line-height: 1.36;
  }

  .cases-process-note span {
    min-height: 34px;
    padding: 7px 9px;
    font-size: 12px;
  }

  .cases-contact-form {
    gap: 8px;
    margin-top: 12px;
  }

  .cases-contact-form input,
  .cases-contact-form textarea {
    min-height: 36px;
    padding: 8px 9px;
  }

  .cases-contact-form textarea {
    min-height: 72px;
  }
}

.generated-page :where(.case-study-card h3, .case-study-card p, .case-study-card span, .case-study-card dt, .case-study-card dd, .cases-overview h2, .cases-overview p, .cases-proof-grid span) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.generated-two-col {
  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.generated-three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.generated-text,
.generated-panel,
.generated-link-block,
.generated-legal-card,
.generated-legacy-card {
  min-width: 0;
  padding: 28px;
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 24px;
  background: rgba(255,255,255,0.86);
  box-shadow: var(--shadow-soft);
}

.generated-panel ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding-left: 20px;
  color: var(--text);
}

.generated-link-cloud,
.generated-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.generated-link-cloud a,
.generated-chip-grid span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 10px 14px;
  border: 1px solid rgba(31,123,255,0.18);
  border-radius: 999px;
  color: var(--blue-dark);
  background: rgba(255,255,255,0.84);
  font-weight: 760;
}

.generated-actions {
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.generated-actions .btn {
  min-width: 0;
  white-space: normal;
  text-align: center;
}

.solutions-ready-page {
  overflow: hidden;
  background: linear-gradient(180deg, #f9fbff 0%, #f2f7ff 54%, #fff 100%);
}

.ready-hero {
  position: relative;
  min-height: min(820px, calc(100svh - 84px));
  display: grid;
  align-items: center;
  overflow: hidden;
  padding: 92px 0 78px;
}

.ready-hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(249,251,255,0.99) 0%, rgba(249,251,255,0.97) 28%, rgba(249,251,255,0.72) 48%, rgba(249,251,255,0.22) 72%, rgba(249,251,255,0.08) 100%),
    url("../assets/solutions/hero-solutions-map.webp") center right / cover no-repeat;
}

.ready-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 760px);
  gap: 0;
  align-items: center;
}

.ready-hero-copy {
  max-width: 760px;
}

.ready-hero-copy h1 {
  margin: 0;
  max-width: 760px;
  color: var(--text);
  font-size: clamp(42px, 3.75vw, 60px);
  line-height: 1.07;
}

.ready-hero-lead,
.ready-hero-sublead,
.ready-intro-box p,
.ready-solution-body p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.66;
}

.ready-hero-lead {
  max-width: 700px;
  margin-top: 30px;
}

.ready-hero-sublead {
  max-width: 700px;
  margin-top: 20px;
}

.ready-hero .hero-actions {
  gap: 16px;
  margin-top: 26px;
}

.ready-hero-visual {
  display: none;
}

.ready-hero-visual img {
  width: min(620px, 100%);
  margin-left: auto;
  filter: drop-shadow(0 28px 60px rgba(31, 87, 219, 0.12));
}

.ready-intro {
  padding: 30px 0 12px;
}

.ready-intro-box {
  padding: clamp(28px, 4vw, 42px);
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 28px;
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-soft);
}

.ready-intro-box h2 {
  margin: 0;
  max-width: 780px;
  color: var(--text);
  font-size: clamp(32px, 3.2vw, 48px);
  line-height: 1.1;
}

.ready-intro-box p {
  max-width: 980px;
  margin-top: 14px;
}

.ready-solutions {
  padding-top: 72px;
}

.ready-solutions-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.ready-solution-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 100%;
  overflow: hidden;
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 24px;
  background: rgba(255,255,255,0.84);
  box-shadow: var(--shadow-soft);
  cursor: pointer;
  outline: none;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background 220ms ease;
}

.ready-solution-card::after {
  content: "→";
  position: absolute;
  right: 20px;
  bottom: 18px;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid rgba(31, 123, 255, 0.22);
  border-radius: 999px;
  color: var(--blue-dark);
  background: rgba(255,255,255,0.9);
  box-shadow: 0 12px 28px rgba(31, 123, 255, 0.12);
  font-size: 22px;
  font-weight: 800;
  opacity: 0;
  transform: translate(8px, 8px);
  transition: opacity 220ms ease, transform 220ms ease, background 220ms ease, color 220ms ease;
}

.ready-solution-card:hover,
.ready-solution-card:focus-visible {
  transform: translateY(-8px);
  border-color: rgba(31, 123, 255, 0.34);
  background: rgba(255,255,255,0.96);
  box-shadow: 0 28px 70px rgba(15, 55, 115, 0.16);
}

.ready-solution-card:hover::after,
.ready-solution-card:focus-visible::after {
  opacity: 1;
  transform: translate(0, 0);
  color: #fff;
  background: var(--blue);
}

.ready-solution-media {
  padding: 18px 18px 0;
}

.ready-solution-media img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: contain;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(244,248,255,0.86), rgba(255,255,255,0.96));
  transition: transform 220ms ease, filter 220ms ease;
}

.ready-solution-card:hover .ready-solution-media img,
.ready-solution-card:focus-visible .ready-solution-media img {
  transform: translateY(-5px) scale(1.035);
  filter: drop-shadow(0 18px 26px rgba(31, 123, 255, 0.14));
}

.ready-solution-body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-width: 0;
  padding: 18px 20px 70px;
}

.ready-solution-body h3 {
  margin: 0 0 12px;
  color: var(--text);
  font-size: 22px;
  line-height: 1.16;
}

.ready-solution-body p {
  font-size: 15px;
  line-height: 1.62;
}

@media (max-width: 1220px) {
  .ready-solutions-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .ready-hero {
    min-height: auto;
    padding: 64px 0 48px;
  }
  .ready-hero-bg {
    background:
      linear-gradient(180deg, rgba(249,251,255,0.98) 0%, rgba(249,251,255,0.9) 52%, rgba(249,251,255,0.44) 100%),
      url("../assets/solutions/hero-solutions-map.webp") center right / cover no-repeat;
  }
  .ready-hero-grid {
    grid-template-columns: 1fr;
  }
  .ready-hero-copy h1 {
    max-width: 720px;
    font-size: clamp(38px, 6vw, 58px);
  }
  .ready-hero-visual img {
    display: block;
    width: min(560px, 100%);
    margin: 8px auto 0;
  }
  .ready-solutions-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .ready-hero {
    padding: 44px 0 36px;
  }
  .ready-hero-copy h1 {
    max-width: min(360px, calc(100vw - 30px));
    font-size: clamp(31px, 8vw, 36px);
    overflow-wrap: normal;
    word-break: normal;
  }
  .ready-hero-lead,
  .ready-hero-sublead {
    max-width: min(320px, calc(100vw - 40px));
    font-size: 16px;
    line-height: 1.55;
  }
  .ready-hero .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .ready-hero .hero-actions .btn {
    width: 100%;
  }
  .ready-intro {
    padding-top: 18px;
  }
  .ready-intro-box {
    padding: 24px;
    border-radius: 22px;
  }
  .ready-intro-box h2,
  .ready-solutions .solutions-section-head h2 {
    max-width: min(310px, calc(100vw - 48px));
    font-size: clamp(27px, 7.5vw, 34px);
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .ready-intro-box p,
  .ready-solutions .solutions-section-head p {
    max-width: min(315px, calc(100vw - 48px));
    font-size: 16px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .ready-solutions {
    padding-top: 36px;
  }
  .ready-solutions-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .ready-solution-body {
    padding: 16px 16px 64px;
  }
  .ready-solution-body h3 {
    max-width: min(300px, calc(100vw - 72px));
    font-size: 20px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .ready-solution-body p {
    max-width: min(300px, calc(100vw - 72px));
    font-size: 14.5px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
}

.products-ready-hero {
  position: relative;
  min-height: min(780px, calc(100svh - 76px));
  overflow: hidden;
  display: flex;
  align-items: center;
  background: #061a2d;
}

.products-ready-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center right;
  opacity: 0.96;
}

.products-ready-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(4,17,30,0.98) 0%, rgba(4,17,30,0.9) 34%, rgba(4,17,30,0.54) 58%, rgba(4,17,30,0.08) 100%),
    linear-gradient(180deg, rgba(2,12,22,0.12), rgba(2,12,22,0.62));
}

.products-ready-hero-inner {
  position: relative;
  z-index: 1;
  padding: 126px 0 92px;
}

.products-ready-hero-copy {
  max-width: 650px;
  color: #fff;
}

.products-ready-hero-copy .eyebrow {
  color: #77d5ff;
}

.products-ready-hero-copy h1 {
  max-width: 610px;
  color: #fff;
  font-size: clamp(48px, 6.2vw, 82px);
  line-height: 0.96;
  overflow-wrap: normal;
  word-break: normal;
}

.products-ready-lead {
  max-width: 620px;
  margin-bottom: 24px;
  color: rgba(255,255,255,0.93);
  font-size: clamp(20px, 2vw, 27px);
  line-height: 1.32;
}

.products-ready-text {
  max-width: 570px;
  margin-bottom: 34px;
  color: rgba(255,255,255,0.74);
  font-size: 17px;
  line-height: 1.7;
}

.products-ready-ghost {
  color: #fff;
  border-color: rgba(255,255,255,0.24);
  background: rgba(255,255,255,0.08);
  box-shadow: 0 10px 26px rgba(0,0,0,0.12);
}

.product-ready-section {
  padding: 74px 0 8px;
  background: #f4f8fc;
}

.product-ready-section + .product-ready-section {
  padding-top: 52px;
}

.product-ready-category {
  width: fit-content;
  margin: 0 0 24px;
  padding: 8px 13px;
  border: 1px solid rgba(31,123,255,0.16);
  border-radius: 999px;
  color: var(--blue-dark);
  background: rgba(255,255,255,0.72);
  font-size: 13px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.product-ready-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

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

.product-ready-card {
  display: flex;
  min-width: 0;
  min-height: 100%;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(31,123,255,0.15);
  border-radius: 26px;
  background: rgba(255,255,255,0.86);
  box-shadow: 0 20px 52px rgba(11,45,76,0.1);
  outline: none;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background 220ms ease;
}

.product-ready-card:hover,
.product-ready-card:focus-visible {
  transform: translateY(-6px);
  border-color: rgba(31,123,255,0.3);
  background: #fff;
  box-shadow: 0 28px 70px rgba(11,45,76,0.18);
}

.product-ready-media {
  display: grid;
  min-height: 260px;
  place-items: center;
  padding: 20px;
  background: linear-gradient(135deg, #eaf5ff, #fff);
}

.product-ready-media img {
  width: 100%;
  height: 240px;
  object-fit: contain;
  transition: transform 240ms ease, filter 240ms ease;
}

.product-ready-card:hover .product-ready-media img,
.product-ready-card:focus-visible .product-ready-media img {
  transform: translateY(-4px) scale(1.025);
  filter: drop-shadow(0 16px 24px rgba(31, 123, 255, 0.12));
}

.product-ready-content {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-width: 0;
  padding: 26px;
}

.product-ready-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  color: var(--blue-dark);
  font-size: 12px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.product-ready-meta span:last-child {
  min-width: 0;
  color: #5d7890;
  text-align: right;
  letter-spacing: 0;
  text-transform: none;
  overflow-wrap: anywhere;
}

.product-ready-card h3 {
  margin-bottom: 16px;
  color: var(--ink);
  font-size: 24px;
  line-height: 1.1;
}

.product-ready-card p {
  margin-bottom: 14px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.64;
}

/* Products premium workflow. Source of truth:
   .artifacts/product-plans/products-light-theme/products-light-theme-section-contracts-2026-06-02.json */
.products-wf-slide {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background: #f7fbff;
  color: #102033;
}

body:has(.products-wf-slide) :where(h1,h2,h3,p,li,a,button,span,label) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  object-fit: fill;
  object-position: center;
  pointer-events: none;
}

.products-wf-hero,
.products-wf-system {
  min-height: min(780px, calc(100svh - 76px));
}

.products-wf-hero-inner,
.products-wf-system-inner {
  position: relative;
  min-height: inherit;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 86px 0 56px;
}

.products-wf-copy {
  max-width: 620px;
}

.products-wf-hero-copy {
  max-width: 558px;
}

.products-wf-kicker {
  margin-bottom: 18px;
  color: #1f7bff;
  font-size: 13px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-copy h1,
.products-wf-copy h2,
.products-wf-section-head h2,
.products-wf-card h3 {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-hero-copy h1 {
  max-width: 580px;
  margin-bottom: 24px;
  color: #102033;
  font-size: clamp(48px, 6.1vw, 82px);
  line-height: 0.98;
}

.products-wf-hero-copy .products-wf-lead,
.products-wf-hero-copy .products-wf-text {
  color: #344f66;
}

.products-wf-hero-copy .products-wf-lead {
  max-width: 600px;
  margin-bottom: 24px;
  font-size: clamp(20px, 2vw, 27px);
  line-height: 1.32;
}

.products-wf-hero-copy .products-wf-text {
  max-width: 560px;
  margin-bottom: 34px;
  font-size: 17px;
  line-height: 1.7;
}

.products-wf-ghost {
  color: #123b63;
  border-color: rgba(31, 123, 255, 0.26);
  background: rgba(255, 255, 255, 0.82);
}

.products-wf-catalog-inner {
  position: relative;
  padding-top: 84px;
  padding-bottom: 98px;
}

.products-wf-section-head {
  max-width: 860px;
  margin-bottom: 36px;
}

.products-wf-section-head h2 {
  margin-bottom: 16px;
  color: #102033;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.04;
}

.products-wf-section-head p {
  max-width: 820px;
  color: #52687a;
  font-size: 18px;
  line-height: 1.62;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-group + .products-wf-group {
  margin-top: 44px;
}

.products-wf-group > h3 {
  width: fit-content;
  margin: 0 0 20px;
  padding: 8px 13px;
  border: 1px solid rgba(31, 123, 255, 0.2);
  border-radius: 999px;
  color: #1f7bff;
  background: rgba(255, 255, 255, 0.86);
  font-size: 13px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.products-wf-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

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

.products-wf-card {
  display: flex;
  min-width: 0;
  min-height: 100%;
  flex-direction: column;
  border: 1px solid rgba(156, 184, 210, 0.55);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  color: #102033;
  box-shadow: 0 18px 44px rgba(31, 80, 130, 0.12);
  outline: none;
  transition: transform 220ms ease, border-color 220ms ease, background 220ms ease;
}

.products-wf-card:hover,
.products-wf-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(31, 123, 255, 0.36);
  background: #fff;
}

.products-wf-card-media {
  width: 100%;
  aspect-ratio: 1586 / 992;
  background: #eef6ff;
}

.products-wf-card-media img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1586 / 992;
  object-fit: contain;
}

.products-wf-card-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 22px;
}

.products-wf-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  color: #1f7bff;
  font-size: 12px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.products-wf-card-meta span:last-child {
  min-width: 0;
  color: #60788d;
  text-align: right;
  letter-spacing: 0;
  text-transform: none;
}

.products-wf-card h3 {
  margin-bottom: 14px;
  color: #102033;
  font-size: 23px;
  line-height: 1.12;
}

.products-wf-card p {
  margin-bottom: 13px;
  color: #52687a;
  font-size: 15px;
  line-height: 1.58;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-system-copy {
  max-width: 760px;
}

.products-wf-system-copy h2 {
  max-width: 740px;
  margin-bottom: 18px;
  color: #102033;
  font-size: clamp(32px, 3.3vw, 48px);
  line-height: 1.04;
}

.products-wf-system-bottom {
  display: grid;
  gap: 18px;
  margin-top: auto;
  margin-bottom: 0;
}

.products-wf-system-note {
  max-width: 920px;
  margin: 0;
  color: #52687a;
  font-size: 17px;
  line-height: 1.54;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-steps {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.products-wf-steps li {
  min-width: 0;
  padding: 14px 16px;
  border: 1px solid rgba(31, 123, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  color: #344f66;
  font-size: 14px;
  font-weight: 760;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.products-wf-cta-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(380px, 1fr);
  gap: 36px;
  align-items: start;
  padding-top: 88px;
  padding-bottom: 88px;
}

.products-wf-cta-copy h2 {
  max-width: 560px;
  margin-bottom: 18px;
  color: #102033;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.06;
}

.products-wf-cta-copy p {
  max-width: 560px;
  color: #52687a;
  font-size: 18px;
  line-height: 1.62;
}

.products-wf-form {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.contact-form.products-wf-form label {
  color: #52687a;
}

@media (max-width: 1100px) {
  .products-wf-grid,
  .products-wf-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .products-wf-hero-copy {
    max-width: 486px;
  }
  .products-wf-hero-copy h1 {
    max-width: 520px;
  }
}

@media (max-width: 780px) {
  .products-wf-hero,
  .products-wf-system {
    min-height: auto;
  }
  .products-wf-hero-inner,
  .products-wf-system-inner {
    min-height: auto;
    padding: 88px 0 72px;
  }
  .products-wf-bg {
    object-fit: fill;
  }
  .products-wf-hero-copy h1 {
    max-width: min(340px, calc(100vw - 34px));
    font-size: clamp(40px, 10vw, 52px);
  }
  .products-wf-hero-copy .products-wf-lead,
  .products-wf-hero-copy .products-wf-text,
  .products-wf-section-head p,
  .products-wf-system-note,
  .products-wf-cta-copy p {
    max-width: min(340px, calc(100vw - 34px));
    font-size: 16px;
  }
  .products-wf-hero .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .products-wf-hero .btn {
    width: 100%;
  }
  .products-wf-catalog-inner {
    padding-top: 62px;
    padding-bottom: 72px;
  }
  .products-wf-section-head h2,
  .products-wf-system-copy h2,
  .products-wf-cta-copy h2 {
    max-width: min(340px, calc(100vw - 34px));
    font-size: clamp(31px, 8.6vw, 42px);
  }
  .products-wf-grid,
  .products-wf-grid--two {
    grid-template-columns: 1fr;
  }
  .products-wf-card-body {
    padding: 20px;
  }
  .products-wf-card-meta {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: start;
    gap: 10px;
  }
  .products-wf-card-meta span:last-child {
    text-align: left;
  }
  .products-wf-card h3 {
    max-width: min(320px, calc(100vw - 72px));
    font-size: 21px;
  }
  .products-wf-card p {
    max-width: min(320px, calc(100vw - 72px));
  }
  .products-wf-system-inner {
    padding-top: 52px;
    padding-bottom: 44px;
    justify-content: flex-start;
  }
  .products-wf-steps {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
  }
  .products-wf-cta-inner {
    grid-template-columns: 1fr;
    padding-top: 56px;
    padding-bottom: 56px;
  }
}

@media (max-width: 1100px) {
  .product-ready-grid,
  .product-ready-grid-wide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 780px) {
  .products-ready-hero {
    min-height: auto;
  }
  .products-ready-hero-bg {
    object-position: 68% center;
  }
  .products-ready-hero-overlay {
    background: linear-gradient(90deg, rgba(4,17,30,0.98) 0%, rgba(4,17,30,0.84) 60%, rgba(4,17,30,0.48) 100%);
  }
  .products-ready-hero-inner {
    padding: 90px 0 76px;
  }
  .products-ready-hero-copy h1 {
    max-width: min(340px, calc(100vw - 34px));
    font-size: clamp(40px, 11vw, 52px);
  }
  .products-ready-lead {
    max-width: min(340px, calc(100vw - 34px));
    font-size: 19px;
  }
  .products-ready-text {
    max-width: min(340px, calc(100vw - 34px));
    font-size: 16px;
  }
  .products-ready-hero .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .products-ready-hero .btn {
    width: 100%;
  }
  .product-ready-grid,
  .product-ready-grid-wide {
    grid-template-columns: 1fr;
  }
  .product-ready-section {
    padding: 54px 0 0;
  }
  .product-ready-media {
    min-height: 220px;
  }
  .product-ready-media img {
    height: 210px;
  }
  .product-ready-content {
    padding: 22px;
  }
  .product-ready-meta {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: start;
    gap: 10px;
  }
  .product-ready-meta span:last-child {
    text-align: left;
  }
  .product-ready-card h3 {
    max-width: min(310px, calc(100vw - 72px));
    font-size: 22px;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .product-ready-card p {
    max-width: min(310px, calc(100vw - 72px));
    overflow-wrap: anywhere;
    word-break: break-word;
  }
}

/* UMEC Space IoT Platform product landing, Phase 3.
   Approved raster backgrounds are immutable: no crop, mask, filter, wash or CSS recomposition. */
body.iot-platform-route {
  --iot-page-max: var(--container);
  --iot-page-pad: 20px;
  --iot-text-left: max(var(--iot-page-pad), calc((100% - var(--iot-page-max)) / 2));
  --iot-text-width: min(50vw, 720px);
  --iot-process-text-width: min(50vw, 720px);
  --iot-section-head-width: min(100%, 720px);
  background: #f7fbfa;
}

body.iot-platform-route .iot-platform-page {
  background: #f7fbfa;
  color: #14312f;
}

body.iot-platform-route .iot-platform-page :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.iot-platform-route .iot-platform-page .reveal {
  opacity: 1;
  transform: none;
}

.iot-platform-slide {
  --iot-frame-aspect: 1672 / 941;
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  padding: 0;
  overflow: visible;
  isolation: isolate;
  background: #f7fbfa;
  scroll-margin-top: 78px;
}

.iot-platform-frame {
  position: relative;
  width: 100%;
  max-width: none;
  aspect-ratio: var(--iot-frame-aspect);
  min-height: 0;
  height: auto;
  overflow: visible;
}

.iot-platform-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 1;
  filter: none;
  transform: none;
  pointer-events: none;
}

.iot-platform-copy,
.iot-platform-process-copy,
.iot-platform-process-note,
.iot-platform-final-copy {
  position: absolute;
  z-index: 1;
}

.iot-platform-copy {
  top: 13%;
  display: grid;
  gap: clamp(10px, 1.08vw, 16px);
  width: var(--iot-text-width);
  max-width: var(--iot-text-width);
}

.iot-platform-copy--left {
  left: var(--iot-text-left);
}

.iot-platform-copy--right {
  right: var(--iot-text-left);
}

.iot-platform-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: #0f8e84;
  font-size: clamp(12px, 0.9vw, 14px);
  font-weight: 820;
  line-height: 1.1;
  text-transform: uppercase;
}

.iot-platform-kicker::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #18b6a8;
  box-shadow: 0 0 0 7px rgba(24, 182, 168, 0.14);
}

.iot-platform-copy h1,
.iot-platform-copy h2,
.iot-platform-process-copy h2,
.iot-platform-section-head h2 {
  margin: 0;
  color: #102a28;
  font-weight: 840;
  line-height: 1.02;
}

.iot-platform-copy h1 {
  max-width: 100%;
  font-size: clamp(48px, 5.5vw, 86px);
}

.iot-platform-copy h2,
.iot-platform-process-copy h2,
.iot-platform-section-head h2 {
  font-size: clamp(30px, 3.1vw, 54px);
}

.iot-platform-copy p,
.iot-platform-copy li,
.iot-platform-process-copy p,
.iot-platform-process-note,
.iot-platform-final-copy,
.iot-platform-section-head p,
.iot-platform-card p {
  margin: 0;
  color: rgba(20, 49, 47, 0.78);
  font-size: clamp(15px, 1.05vw, 19px);
  line-height: 1.48;
}

.iot-platform-lead {
  max-width: 100%;
  color: #14312f;
  font-size: clamp(20px, 1.55vw, 27px) !important;
  line-height: 1.28 !important;
  font-weight: 680;
}

.iot-platform-audience,
.iot-platform-emphasis {
  color: #0f615b !important;
  font-weight: 720;
}

.iot-platform-list {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.iot-platform-list li {
  position: relative;
  padding-left: 18px;
}

.iot-platform-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #18b6a8;
}

.iot-platform-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 4px;
}

.iot-platform-actions .btn {
  position: relative;
  z-index: 2;
}

.iot-platform-actions .btn-secondary {
  color: #0f615b;
  border-color: rgba(15, 97, 91, 0.24);
  background: rgba(255, 255, 255, 0.74);
}

body.iot-platform-route .iot-platform-actions .btn-primary {
  color: #fff;
  background: #0b5f59;
  border-color: #0b5f59;
}

.iot-platform-process-copy {
  top: 4%;
  left: var(--iot-text-left);
  width: var(--iot-process-text-width);
  max-width: var(--iot-process-text-width);
  display: grid;
  gap: 8px;
}

.iot-platform-process-copy h2 {
  max-width: 100%;
  font-size: clamp(28px, 2.35vw, 40px);
  line-height: 1.03;
}

.iot-platform-process-copy p {
  display: none;
}

.iot-platform-process-note {
  left: var(--iot-text-left);
  right: auto;
  bottom: 2.2%;
  width: var(--iot-process-text-width);
  max-width: var(--iot-process-text-width);
  font-weight: 640;
}

.iot-platform-final-copy {
  left: var(--iot-text-left);
  right: auto;
  bottom: 1.5%;
  width: var(--iot-process-text-width);
  display: grid;
  gap: 16px;
  max-width: var(--iot-process-text-width);
}

.iot-platform-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: #f7fbfa;
  color: #14312f;
  scroll-margin-top: 78px;
}

.iot-platform-section-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 1;
  filter: none;
  pointer-events: none;
}

.iot-platform-card-wrap {
  position: relative;
  z-index: 1;
  width: min(calc(100% - (var(--iot-page-pad) * 2)), var(--iot-page-max));
  max-width: var(--iot-page-max);
  margin: 0 auto;
  padding-right: 0;
  padding-left: 0;
  padding-top: clamp(72px, 7vw, 104px);
  padding-bottom: clamp(82px, 8vw, 118px);
}

.iot-platform-section-head {
  display: grid;
  gap: 14px;
  width: var(--iot-section-head-width);
  max-width: var(--iot-section-head-width);
  margin-bottom: 34px;
}

.iot-platform-section-head p {
  max-width: 880px;
}

.iot-platform-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.iot-platform-card {
  display: flex;
  min-width: 0;
  min-height: 100%;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(18, 138, 128, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 48px rgba(21, 68, 65, 0.09);
}

.iot-platform-card-media {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #eef8f6;
}

.iot-platform-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  filter: none;
}

.iot-platform-card-body {
  display: grid;
  gap: 11px;
  padding: 22px;
}

.iot-platform-card h3 {
  margin: 0;
  color: #102a28;
  font-size: clamp(19px, 1.55vw, 26px);
  line-height: 1.1;
}

.iot-platform-card p {
  font-size: clamp(14px, 0.95vw, 16px);
  line-height: 1.5;
}

@media (max-width: 1180px) {
  body.iot-platform-route {
    --iot-text-width: min(58vw, 680px);
    --iot-process-text-width: min(58vw, 680px);
    --iot-section-head-width: min(100%, 680px);
  }

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

  .iot-platform-copy {
    gap: 10px;
  }

  .iot-platform-copy h1 {
    font-size: clamp(43px, 5.2vw, 66px);
  }

  .iot-platform-copy h2,
  .iot-platform-process-copy h2,
  .iot-platform-section-head h2 {
    font-size: clamp(28px, 3.2vw, 42px);
  }

  .iot-platform-copy p,
  .iot-platform-copy li,
  .iot-platform-process-copy p,
  .iot-platform-process-note,
  .iot-platform-final-copy {
    font-size: 15px;
    line-height: 1.42;
  }
}

@media (max-width: 780px) {
  body.iot-platform-route {
    --iot-page-pad: 14px;
    --iot-text-width: 100%;
    --iot-process-text-width: 100%;
    --iot-section-head-width: 100%;
  }

  .iot-platform-slide {
    min-height: auto;
    padding: 0;
  }

  .iot-platform-frame {
    display: block;
    width: 100%;
    min-height: 0;
    aspect-ratio: auto;
    padding: 18px var(--container-padding, 16px);
  }

  .iot-platform-copy,
  .iot-platform-process-copy,
  .iot-platform-process-note,
  .iot-platform-final-copy {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
  }

  .iot-platform-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .iot-platform-copy,
  .iot-platform-process-copy {
    padding: 0 2px;
  }

  .iot-platform-process-note,
  .iot-platform-final-copy {
    margin-top: 14px;
  }

  .iot-platform-copy h1 {
    font-size: clamp(38px, 11vw, 54px);
  }

  .iot-platform-copy h2,
  .iot-platform-process-copy h2,
  .iot-platform-section-head h2 {
    font-size: clamp(27px, 8.2vw, 38px);
  }

  .iot-platform-lead {
    font-size: 18px !important;
  }

  .iot-platform-copy p,
  .iot-platform-copy li,
  .iot-platform-process-copy p,
  .iot-platform-process-note,
  .iot-platform-final-copy,
  .iot-platform-section-head p {
    font-size: 16px;
    line-height: 1.42;
  }

  .iot-platform-actions,
  .iot-platform-actions .btn {
    width: 100%;
  }

  .iot-platform-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .iot-platform-card-wrap {
    padding-top: 54px;
    padding-bottom: 64px;
  }

  .iot-platform-card-grid {
    grid-template-columns: 1fr;
  }

  .iot-platform-card-body {
    padding: 20px;
  }
}

.generated-cta {
  background:
    linear-gradient(180deg, rgba(238,246,255,0.82), rgba(255,255,255,0.96)),
    url("../assets/solutions/bg-solutions-map-lines.webp") center / cover no-repeat;
}

.generated-cta-card {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(360px, 1fr);
  gap: 34px;
  padding: 42px;
  border: 1px solid rgba(31,123,255,0.15);
  border-radius: 28px;
  background: rgba(255,255,255,0.9);
  box-shadow: var(--shadow-soft);
}

.mailto-cta {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.mailto-cta .btn {
  width: fit-content;
}

.contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.contact-form label {
  display: grid;
  gap: 7px;
  color: #29405f;
  font-size: 13px;
  font-weight: 760;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  min-height: 46px;
  padding: 12px 14px;
  border: 1px solid rgba(31,123,255,0.18);
  border-radius: 14px;
  color: var(--ink);
  background: #fff;
  font: inherit;
}

.contact-form textarea {
  min-height: 116px;
  resize: vertical;
}

.form-wide {
  grid-column: 1 / -1;
}

.form-consent {
  grid-template-columns: 20px 1fr !important;
  align-items: start;
}

.form-consent input {
  min-height: auto;
  margin-top: 2px;
}

.form-status {
  min-height: 22px;
  margin: 0;
  color: var(--blue-dark);
  font-weight: 760;
}

.contact-form.is-invalid .form-status {
  color: #bd1b3a;
}

.generated-legal,
.generated-legacy {
  min-height: 62svh;
  background: #fff;
}

.generated-legal-card,
.generated-legacy-card {
  max-width: 920px;
}

.generated-legal-card h1,
.generated-legacy-card h1 {
  font-size: clamp(38px, 5vw, 62px);
}

@media (max-width: 1100px) {
  .solutions-hero {
    height: auto;
    min-height: auto;
    padding: 80px 0 86px;
  }
  .solutions-hero-grid,
  .selector-layout,
  .solution-preview,
  .matrix-grid,
  .implementation-flow,
  .cases-overview-grid,
  .case-study-card,
  .generated-hero-grid,
  .generated-two-col,
  .generated-cta-card {
    grid-template-columns: 1fr;
  }
  .generated-card-grid,
  .generated-three {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .implementation-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .solutions-map {
    min-height: 430px;
  }
  .solutions-map img {
    width: min(760px, 102vw);
    right: -18vw;
  }
  .matrix-copy {
    position: static;
  }
}

@media (max-width: 780px) {
  .solutions-hero {
    height: min(680px, calc(100svh - 84px));
    min-height: 560px;
    padding: 44px 0 38px;
  }
  .solutions-hero h1 {
    font-size: clamp(31px, 8.4vw, 38px);
    line-height: 1.06;
  }
  .solutions-hero-copy p {
    font-size: 17px;
  }
  .solutions-hero-actions,
  .implementation-cards {
    display: grid;
    grid-template-columns: 1fr;
  }
  .solutions-map {
    display: none;
  }
  .solution-rail,
  .solution-preview {
    padding: 18px;
    border-radius: 24px;
  }
  .preview-media {
    border-radius: 18px;
  }
  .preview-copy h3,
  .solutions-section-head h2,
  .matrix-copy h2,
  .implementation-copy h2 {
    max-width: calc(100vw - 36px);
    font-size: clamp(25px, 7vw, 30px);
    line-height: 1.08;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .matrix-table > div {
    grid-template-columns: 66px minmax(0, 1fr);
    gap: 10px;
  }
  .matrix-table span {
    grid-column: 1;
  }
  .matrix-table strong,
  .matrix-table p {
    grid-column: 2;
  }
  .matrix-icon {
    grid-row: 1 / 4;
  }
  .implementation-flow {
    gap: 28px;
  }
  .implementation-cards img {
    aspect-ratio: 1.25;
    max-height: 330px;
  }
  .generated-hero {
    min-height: auto;
    padding: 56px 0 64px;
  }
  .generated-hero-copy h1,
  .generated-legal-card h1,
  .generated-legacy-card h1 {
    max-width: min(310px, calc(100vw - 42px));
    font-size: clamp(31px, 8vw, 38px);
    line-height: 1.08;
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .generated-hero-copy p {
    max-width: min(320px, calc(100vw - 42px));
    font-size: 17px;
  }
  .generated-hero-visual {
    width: min(320px, 92%);
  }
  .generated-card-grid,
  .generated-three,
  .contact-form {
    grid-template-columns: 1fr;
  }
  .cases-proof-grid div {
    grid-template-columns: 72px minmax(0, 1fr);
    min-height: 74px;
    padding: 16px;
    border-radius: 18px;
  }
  .cases-proof-grid strong {
    font-size: 34px;
  }
  .case-study-card {
    gap: 16px;
    padding: 14px;
    border-radius: 22px;
  }
  .case-study-media {
    border-radius: 18px;
  }
  .case-study-media img {
    border-radius: 16px;
  }
  .case-study-content {
    padding: 0;
  }
  .case-study-card h3 {
    max-width: min(310px, calc(100vw - 58px));
    font-size: clamp(22px, 6.2vw, 28px);
  }
  .case-study-facts div {
    grid-template-columns: 1fr;
    gap: 5px;
  }
  .case-study-facts dd,
  .case-study-products {
    max-width: min(310px, calc(100vw - 58px));
  }
  .generated-card,
  .generated-text,
  .generated-panel,
  .generated-link-block,
  .generated-legal-card,
  .generated-legacy-card,
  .generated-cta-card {
    padding: 20px;
    border-radius: 20px;
  }
  .generated-card h3 {
    font-size: 20px;
    max-width: min(300px, calc(100vw - 70px));
  }
  .generated-page h2 {
    max-width: min(310px, calc(100vw - 54px));
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .generated-card p,
  .generated-text p,
  .generated-panel li,
  .generated-link-block a,
  .generated-cta-card p,
  .form-consent,
  .site-footer p,
  .site-footer a {
    max-width: min(300px, calc(100vw - 70px));
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .generated-page .section-head p {
    max-width: min(320px, calc(100vw - 42px));
    overflow-wrap: anywhere;
    word-break: break-word;
  }
  .generated-page *,
  .generated-page *::before,
  .generated-page *::after {
    min-width: 0;
  }
  .contact-form .btn,
  .contact-form input,
  .contact-form textarea {
    max-width: 100%;
  }
}



/* PowerMaster wireframe landing assembly, 2026-05-31.
   Meaningful images are rendered full-frame: no crop, mask, filter or overlay wash. */
body.powermaster-route .pm-wf-page {
  background: #05070c;
  color: #f4f8ff;
}

body.powermaster-route .pm-wf-page :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.powermaster-route .pm-wf-slide {
  --pm-frame-aspect: 1.7778958555;
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  padding: 0;
  background: #05070c;
  overflow: visible;
  isolation: isolate;
  scroll-margin-top: 78px;
}

body.powermaster-route .pm-wf-page .reveal {
  opacity: 1;
  transform: none;
}

body.powermaster-route .pm-wf-frame {
  position: relative;
  width: min(100vw, calc((100svh - 78px) * var(--pm-frame-aspect)));
  aspect-ratio: 1672 / 941;
  overflow: visible;
}

body.powermaster-route .pm-wf-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  opacity: 1;
  filter: none;
  transform: none;
  pointer-events: none;
}

body.powermaster-route .pm-wf-copy,
body.powermaster-route .pm-wf-process-copy,
body.powermaster-route .pm-wf-process-note,
body.powermaster-route .pm-wf-card-layout {
  position: absolute;
  z-index: 1;
}

body.powermaster-route .pm-wf-copy {
  top: 16%;
  display: grid;
  gap: clamp(14px, 1.6vw, 22px);
  max-width: 42%;
}

body.powermaster-route .pm-wf-copy--left {
  left: 5.4%;
  width: 37%;
}

body.powermaster-route .pm-wf-copy--right {
  right: 4.2%;
  width: 30.5%;
}

body.powermaster-route .pm-wf-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: #58a8ff;
  font-size: clamp(12px, 0.95vw, 14px);
  font-weight: 780;
  line-height: 1.1;
  text-transform: uppercase;
}

body.powermaster-route .pm-wf-kicker::before {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #1f7bff;
  box-shadow: 0 0 0 7px rgba(31, 123, 255, 0.14);
}

body.powermaster-route .pm-wf-copy h1,
body.powermaster-route .pm-wf-copy h2,
body.powermaster-route .pm-wf-process-copy h2,
body.powermaster-route .pm-wf-section-head h2 {
  margin: 0;
  color: #f7fbff;
  font-weight: 820;
  line-height: 1.03;
}

body.powermaster-route .pm-wf-copy h1 {
  font-size: clamp(48px, 5vw, 86px);
}

body.powermaster-route .pm-wf-copy h2,
body.powermaster-route .pm-wf-process-copy h2,
body.powermaster-route .pm-wf-section-head h2 {
  font-size: clamp(28px, 3.6vw, 58px);
}

body.powermaster-route .pm-wf-copy p,
body.powermaster-route .pm-wf-process-copy p,
body.powermaster-route .pm-wf-process-note,
body.powermaster-route .pm-wf-section-head p,
body.powermaster-route .pm-wf-card p {
  margin: 0;
  color: rgba(232, 242, 255, 0.88);
  font-size: clamp(15px, 1.22vw, 21px);
  line-height: 1.48;
}

body.powermaster-route .pm-wf-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 4px;
}

body.powermaster-route .pm-wf-actions .btn {
  position: relative;
  z-index: 2;
}

body.powermaster-route .pm-wf-actions .btn-secondary {
  color: #eef8ff;
  border-color: rgba(151, 214, 255, 0.34);
  background: rgba(8, 18, 34, 0.74);
}

body.powermaster-route .pm-wf-process-copy {
  top: 5.6%;
  left: 8.2%;
  width: 82%;
  display: grid;
  gap: 12px;
}

body.powermaster-route .pm-wf-process-copy h2 {
  font-size: clamp(30px, 2.65vw, 50px);
}

body.powermaster-route .pm-wf-process-note {
  left: 8.2%;
  bottom: 13%;
  max-width: 940px;
  color: rgba(226, 239, 255, 0.82);
}

body.powermaster-route .pm-wf-card-layout {
  inset: 7% 5.4%;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: clamp(14px, 1.7vw, 24px);
}

body.powermaster-route .pm-wf-section-head {
  display: grid;
  gap: 10px;
  max-width: min(1260px, 86%);
}

@media (min-width: 1024px) {
  body.powermaster-route .pm-wf-singleline {
    white-space: nowrap;
  }
}

body.powermaster-route .pm-wf-card-grid {
  display: grid;
  gap: clamp(14px, 1.6vw, 22px);
  align-items: stretch;
}

body.powermaster-route .pm-wf-card-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.powermaster-route .pm-wf-card-grid--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.powermaster-route .pm-wf-card {
  min-width: 0;
  border: 1px solid rgba(134, 199, 255, 0.2);
  border-radius: 18px;
  background: rgba(10, 18, 32, 0.82);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.24);
}

body.powermaster-route .pm-wf-card--media-left {
  display: grid;
  grid-template-columns: clamp(86px, 11vw, 138px) minmax(0, 1fr);
  gap: clamp(12px, 1.4vw, 20px);
  align-items: center;
  padding: clamp(14px, 1.7vw, 24px);
}

body.powermaster-route .pm-wf-card--media-top {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 12px;
  padding: clamp(12px, 1.35vw, 20px);
}

body.powermaster-route .pm-wf-card img {
  display: block;
  width: 100%;
  height: auto;
  max-height: clamp(82px, 12vw, 164px);
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
}

body.powermaster-route .pm-wf-card--media-left img {
  max-height: clamp(92px, 11vw, 142px);
}

body.powermaster-route .pm-wf-card h3 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(18px, 1.55vw, 28px);
  line-height: 1.1;
}

body.powermaster-route .pm-wf-card p {
  font-size: clamp(14px, 1vw, 17px);
  color: rgba(222, 235, 252, 0.82);
}

@media (max-width: 1180px) {
  body.powermaster-route .pm-wf-card-grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.powermaster-route .pm-wf-card--media-top {
    grid-template-columns: clamp(96px, 18vw, 160px) minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: center;
  }

  body.powermaster-route .pm-wf-card--media-top img {
    grid-row: 1 / span 2;
  }
}

@media (max-width: 780px) {
  body.powermaster-route .pm-wf-slide {
    min-height: auto;
    padding: 18px var(--container-padding, 16px) 18px;
  }

  body.powermaster-route .pm-wf-frame {
    display: flex;
    flex-direction: column;
    width: min(100%, 560px);
    aspect-ratio: auto;
    gap: 12px;
  }

  body.powermaster-route .pm-wf-bg,
  body.powermaster-route .pm-wf-copy,
  body.powermaster-route .pm-wf-process-copy,
  body.powermaster-route .pm-wf-process-note,
  body.powermaster-route .pm-wf-card-layout {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
  }

  body.powermaster-route .pm-wf-copy,
  body.powermaster-route .pm-wf-process-copy {
    order: -1;
    padding: 0 2px;
  }

  body.powermaster-route .pm-wf-bg {
    height: auto;
    object-fit: contain;
    border-radius: 0;
  }

  body.powermaster-route .pm-wf-copy h1 {
    font-size: clamp(42px, 13vw, 70px);
  }

  body.powermaster-route .pm-wf-copy h2,
  body.powermaster-route .pm-wf-process-copy h2,
  body.powermaster-route .pm-wf-section-head h2 {
    font-size: clamp(27px, 8.4vw, 40px);
  }

  body.powermaster-route .pm-wf-slide--d .pm-wf-process-copy {
    gap: 8px;
  }

  body.powermaster-route .pm-wf-slide--d .pm-wf-process-copy h2 {
    font-size: clamp(25px, 7.5vw, 34px);
  }

  body.powermaster-route .pm-wf-copy p,
  body.powermaster-route .pm-wf-process-copy p,
  body.powermaster-route .pm-wf-process-note,
  body.powermaster-route .pm-wf-section-head p {
    font-size: 16px;
    line-height: 1.38;
  }

  body.powermaster-route .pm-wf-card-layout {
    display: grid;
    gap: 18px;
  }

  body.powermaster-route .pm-wf-section-head {
    max-width: none;
  }

  body.powermaster-route .pm-wf-card-grid--two,
  body.powermaster-route .pm-wf-card-grid--four {
    grid-template-columns: 1fr;
  }

  body.powermaster-route .pm-wf-card--media-left,
  body.powermaster-route .pm-wf-card--media-top {
    grid-template-columns: 96px minmax(0, 1fr);
    grid-template-rows: auto auto;
    padding: 16px;
  }

  body.powermaster-route .pm-wf-card--media-left img,
  body.powermaster-route .pm-wf-card--media-top img {
    grid-row: 1 / span 2;
    max-height: 92px;
  }

  body.powermaster-route .pm-wf-actions {
    flex-direction: column;
    align-items: stretch;
  }

  body.powermaster-route .pm-wf-actions .btn {
    justify-content: center;
    width: 100%;
  }
}

@media (max-width: 780px) {
  body.powermaster-route .pm-wf-slide--cards {
    padding-top: 12px;
    padding-bottom: 12px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-frame {
    position: relative;
    min-height: 0;
    justify-content: flex-start;
    gap: 0;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-bg {
    position: absolute;
    inset: 0;
    order: 0;
    height: 100%;
    margin-top: 0;
    object-fit: fill;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-card-layout {
    order: 1;
    position: relative;
    z-index: 1;
    align-self: stretch;
    gap: 10px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-section-head {
    gap: 7px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-section-head h2 {
    font-size: clamp(23px, 6.7vw, 30px);
    line-height: 1.04;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-section-head p {
    font-size: 13px;
    line-height: 1.25;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-card-grid--two,
  body.powermaster-route .pm-wf-slide--cards .pm-wf-card-grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-card--media-left,
  body.powermaster-route .pm-wf-slide--cards .pm-wf-card--media-top {
    display: grid;
    grid-template-columns: 46px minmax(0, 1fr);
    grid-template-rows: auto auto;
    gap: 6px 7px;
    align-items: center;
    padding: 9px;
    border-radius: 14px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-card--media-left img,
  body.powermaster-route .pm-wf-slide--cards .pm-wf-card--media-top img {
    grid-row: 1 / span 2;
    max-height: 48px;
  }

  body.powermaster-route .pm-wf-slide--cards .pm-wf-card h3 {
    font-size: 14px;
    line-height: 1.08;
  }

body.powermaster-route .pm-wf-slide--cards .pm-wf-card p {
    font-size: 11px;
    line-height: 1.18;
  }
}

/* Development automation landing, Phase 3 integration.
   Source of truth: specs/product-plans/development-automation-landing-plan.md */
body.development-automation-route .dev-auto-page {
  background: #f3f8fe;
  color: #071b3a;
}

body.development-automation-route .dev-auto-page :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

.dev-auto-slide {
  --dev-auto-aspect: 1.7778958555;
  --dev-auto-frame-width: min(calc(100vw - 40px), 1440px, calc((100svh - 76px) * var(--dev-auto-aspect)));
  position: relative;
  display: grid;
  place-items: center;
  min-height: auto;
  padding: 0;
  overflow: clip;
  isolation: isolate;
  background: #f3f8fe;
  scroll-margin-top: 76px;
}

.dev-auto-page .reveal {
  opacity: 1;
  transform: none;
}

.dev-auto-frame {
  position: relative;
  width: var(--dev-auto-frame-width);
  aspect-ratio: 1672 / 941;
  overflow: visible;
}

.dev-auto-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

.dev-auto-bg--abstract {
  object-fit: fill;
}

.dev-auto-copy,
.dev-auto-process-copy,
.dev-auto-process-note,
.dev-auto-card-layout {
  position: absolute;
  z-index: 1;
}

.dev-auto-copy {
  top: 15%;
  display: grid;
  gap: clamp(13px, 1.35vw, 20px);
}

.dev-auto-copy--left {
  left: 5.2%;
  width: 38%;
  max-width: 620px;
}

.dev-auto-hero .dev-auto-copy--left {
  width: 34.5%;
  max-width: none;
}

.dev-auto-problem .dev-auto-copy--left {
  top: 12.8%;
  width: 34.5%;
  max-width: none;
}

.dev-auto-problem .dev-auto-copy p,
.dev-auto-problem .dev-auto-list {
  max-width: 100%;
}

.dev-auto-problem .dev-auto-copy > * {
  min-width: 0;
  max-width: 100%;
}

.dev-auto-copy h1,
.dev-auto-copy h2,
.dev-auto-process-copy h2,
.dev-auto-section-head h2 {
  margin: 0;
  color: #071b3a;
  font-weight: 820;
  line-height: 1.03;
}

.dev-auto-copy h1 {
  font-size: clamp(44px, 4.8vw, 82px);
}

.dev-auto-hero .dev-auto-copy h1 {
  font-size: clamp(34px, 3.3vw, 58px);
}

.dev-auto-hero .dev-auto-lead {
  font-size: clamp(15px, 1.08vw, 19px) !important;
}

.dev-auto-copy h2,
.dev-auto-process-copy h2,
.dev-auto-section-head h2 {
  font-size: clamp(30px, 3.25vw, 56px);
}

.dev-auto-copy p,
.dev-auto-process-copy p,
.dev-auto-process-note,
.dev-auto-section-head p,
.dev-auto-card p,
.dev-auto-list {
  margin: 0;
  color: #29405f;
  font-size: clamp(15px, 1.1vw, 20px);
  line-height: 1.48;
}

.dev-auto-lead {
  max-width: 620px;
  font-size: clamp(17px, 1.35vw, 22px) !important;
}

.dev-auto-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dev-auto-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 11px;
  border: 1px solid rgba(31, 123, 255, 0.16);
  border-radius: 999px;
  color: #0b4cbd;
  background: rgba(255, 255, 255, 0.78);
  font-size: clamp(12px, 0.9vw, 14px);
  font-weight: 760;
}

.dev-auto-actions,
.dev-auto-final-note {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.dev-auto-list {
  display: grid;
  gap: 8px;
  padding: 0;
  list-style: none;
}

.dev-auto-list li {
  position: relative;
  padding-left: 18px;
}

.dev-auto-list li::before {
  content: "";
  position: absolute;
  top: 0.68em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #1f7bff;
  box-shadow: 0 0 0 6px rgba(31, 123, 255, 0.11);
}

.dev-auto-process-copy {
  top: 6.2%;
  left: 7.2%;
  width: 84%;
  display: grid;
  gap: 10px;
}

.dev-auto-process-copy p {
  max-width: 980px;
}

.dev-auto-process-note {
  left: 7.2%;
  bottom: 8.8%;
  max-width: 1050px;
  color: #38526d;
}

.dev-auto-final-note {
  right: 7.2%;
  bottom: 7.2%;
  left: 7.2%;
  justify-content: space-between;
  padding: 18px 20px;
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 50px rgba(35, 88, 155, 0.1);
}

.dev-auto-final-note p {
  max-width: 760px;
  margin: 0;
  color: #29405f;
}

.dev-auto-card-layout {
  inset: 6.2% 4.9%;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: clamp(13px, 1.35vw, 20px);
}

.dev-auto-slide--cards {
  min-height: auto;
  padding: 0;
  overflow: visible;
}

.dev-auto-slide--cards .dev-auto-frame {
  width: var(--dev-auto-frame-width);
  aspect-ratio: auto;
  min-height: 0;
}

.dev-auto-slide--cards .dev-auto-bg {
  object-fit: fill;
}

.dev-auto-slide--cards .dev-auto-card-layout {
  position: relative;
  inset: auto;
  padding: 6.2% 5.2%;
}

.dev-auto-section-head {
  display: grid;
  gap: 8px;
  max-width: 1120px;
}

.dev-auto-section-head p {
  max-width: 930px;
}

.dev-auto-card-grid {
  display: grid;
  gap: clamp(10px, 1.1vw, 16px);
  align-items: stretch;
}

.dev-auto-card-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.dev-auto-card-grid--ten {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.dev-auto-card {
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto;
  gap: 0;
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(31, 123, 255, 0.12);
  border-radius: 16px;
  background: #f7fbff;
  box-shadow: 0 14px 38px rgba(35, 88, 155, 0.09);
}

.dev-auto-card img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  max-height: none;
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
  background: #f7fbff;
}

.dev-auto-card > div {
  display: grid;
  align-content: start;
  padding: clamp(10px, 1.05vw, 16px);
}

.dev-auto-card h3 {
  margin: 0 0 5px;
  color: #071b3a;
  font-size: clamp(16px, 1.18vw, 22px);
  line-height: 1.12;
}

.dev-auto-card p {
  font-size: clamp(12px, 0.83vw, 15px);
  line-height: 1.33;
}

.dev-auto-card--compact {
  padding: 0;
  gap: 0;
}

.dev-auto-card--compact img {
  aspect-ratio: 4 / 3;
  max-height: none;
}

.dev-auto-card--overlay {
  position: relative;
  display: block;
  min-height: 0;
  color: #ffffff;
}

.dev-auto-card--overlay img {
  display: block;
  aspect-ratio: 4 / 3;
  object-fit: contain;
}

.dev-auto-card--overlay > div {
  position: absolute;
  inset: auto 0 0;
  display: grid;
  align-content: end;
  min-height: 46%;
  padding: clamp(9px, 0.85vw, 14px);
  color: #ffffff;
  background: linear-gradient(180deg, rgba(7, 27, 58, 0), rgba(7, 27, 58, 0.82) 44%, rgba(7, 27, 58, 0.94));
  transform: translateY(calc(100% - 3.35em));
  transition: transform 180ms ease;
}

.dev-auto-card--overlay h3 {
  color: #ffffff;
}

.dev-auto-card--overlay p {
  color: rgba(255, 255, 255, 0.92);
  opacity: 0;
  transition: opacity 180ms ease;
}

.dev-auto-card--overlay:hover > div,
.dev-auto-card--overlay:focus > div,
.dev-auto-card--overlay:focus-within > div {
  transform: translateY(0);
}

.dev-auto-card--overlay:hover p,
.dev-auto-card--overlay:focus p,
.dev-auto-card--overlay:focus-within p {
  opacity: 1;
}

.dev-auto-card--compact > div {
  padding: clamp(7px, 0.72vw, 11px);
}

.dev-auto-card--compact h3 {
  font-size: clamp(13px, 0.92vw, 17px);
  line-height: 1.08;
}

.dev-auto-card--compact p {
  font-size: clamp(10px, 0.69vw, 13px);
  line-height: 1.22;
}

body.development-automation-route .generated-cta {
  background:
    linear-gradient(180deg, rgba(243, 248, 254, 0.86), rgba(255, 255, 255, 0.96)),
    url("../assets/development-automation/asset-dev-examples-bg-01.webp") center / cover no-repeat;
}

@media (max-width: 1180px) {
  .dev-auto-card-grid--ten {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dev-auto-card-grid--six {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 780px) {
  .dev-auto-slide {
    --dev-auto-frame-width: min(100%, 560px);
    min-height: auto;
    padding: 0 14px;
    overflow: visible;
  }

  .dev-auto-frame {
    display: flex;
    flex-direction: column;
    width: var(--dev-auto-frame-width);
    aspect-ratio: auto;
    gap: 12px;
  }

  .dev-auto-bg,
  .dev-auto-copy,
  .dev-auto-process-copy,
  .dev-auto-process-note,
  .dev-auto-card-layout {
    position: relative;
    inset: auto;
    width: 100%;
    max-width: none;
  }

  .dev-auto-copy,
  .dev-auto-process-copy {
    order: -1;
    gap: 10px;
  }

  .dev-auto-bg {
    height: auto;
    object-fit: contain;
  }

  .dev-auto-copy h1 {
    font-size: clamp(34px, 10vw, 48px);
  }

  .dev-auto-hero .dev-auto-copy {
    gap: 6px;
  }

  .dev-auto-hero .dev-auto-copy h1 {
    font-size: clamp(27px, 7.5vw, 36px);
  }

  .dev-auto-hero .dev-auto-lead {
    font-size: 13px !important;
    line-height: 1.2;
  }

  .dev-auto-hero .dev-auto-bg {
    width: 64%;
    margin-inline: auto;
    object-fit: contain;
  }

  .dev-auto-hero .dev-auto-tags {
    gap: 5px;
  }

  .dev-auto-hero .dev-auto-tags span {
    min-height: 24px;
    padding: 4px 7px;
    font-size: 11px;
  }

  .dev-auto-hero .dev-auto-actions {
    gap: 8px;
  }

  .dev-auto-hero .dev-auto-actions .btn {
    min-height: 42px;
    padding-block: 10px;
  }

  .dev-auto-copy h2,
  .dev-auto-process-copy h2,
  .dev-auto-section-head h2 {
    font-size: clamp(24px, 7.2vw, 34px);
  }

  .dev-auto-copy p,
  .dev-auto-process-copy p,
  .dev-auto-process-note,
  .dev-auto-section-head p,
  .dev-auto-list {
    font-size: 15px;
    line-height: 1.34;
  }

  .dev-auto-tags span {
    min-height: 28px;
    padding: 6px 9px;
    font-size: 12px;
  }

  .dev-auto-actions,
  .dev-auto-final-note {
    display: grid;
    grid-template-columns: 1fr;
  }

  .dev-auto-actions .btn,
  .dev-auto-final-note .btn {
    justify-content: center;
    width: 100%;
  }

  .dev-auto-final-note {
    padding: 14px;
    border-radius: 16px;
  }

  .dev-auto-slide--cards {
    padding: 0 14px;
  }

  .dev-auto-slide--cards .dev-auto-frame {
    position: relative;
    width: var(--dev-auto-frame-width);
    gap: 0;
  }

  .dev-auto-slide--cards .dev-auto-bg {
    position: absolute;
    inset: 0;
    height: 100%;
    object-fit: fill;
  }

  .dev-auto-slide--cards .dev-auto-card-layout {
    position: relative;
    z-index: 1;
    gap: 9px;
    padding: 6.2% 5.2%;
  }

  .dev-auto-slide--cards .dev-auto-section-head {
    gap: 5px;
  }

  .dev-auto-slide--cards .dev-auto-section-head h2 {
    font-size: clamp(22px, 6.4vw, 29px);
    line-height: 1.04;
  }

  .dev-auto-slide--cards .dev-auto-section-head p {
    font-size: 12px;
    line-height: 1.24;
  }

  .dev-auto-card-grid--six,
  .dev-auto-card-grid--ten {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .dev-auto-card,
  .dev-auto-card--compact {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    gap: 0;
    align-items: stretch;
    padding: 0;
    border-radius: 13px;
  }

  .dev-auto-card img,
  .dev-auto-card--compact img {
    grid-row: auto;
    width: 100%;
    max-height: none;
    aspect-ratio: 4 / 3;
    object-fit: contain;
  }

  .dev-auto-card > div,
  .dev-auto-card--compact > div {
    padding: 7px 8px 8px;
  }

  .dev-auto-card h3,
  .dev-auto-card--compact h3 {
    margin-bottom: 2px;
    font-size: 13px;
    line-height: 1.08;
  }

  .dev-auto-card p,
  .dev-auto-card--compact p {
    font-size: 10.5px;
    line-height: 1.15;
  }

  .dev-auto-slide--examples .dev-auto-card-layout {
    gap: 4px;
    padding: 6.2% 5.2%;
  }

  .dev-auto-slide--examples .dev-auto-section-head h2 {
    font-size: clamp(19px, 5.4vw, 25px);
    line-height: 1.02;
  }

  .dev-auto-slide--examples .dev-auto-section-head p {
    font-size: 10.4px;
    line-height: 1.12;
  }

  .dev-auto-slide--examples .dev-auto-card-grid--ten {
    gap: 4px;
  }

  .dev-auto-slide--examples .dev-auto-card--compact img {
    aspect-ratio: 4 / 3;
  }

  .dev-auto-slide--examples .dev-auto-card--compact > div {
    padding: 7px 8px 8px;
  }

  .dev-auto-slide--examples .dev-auto-card--compact h3 {
    margin-bottom: 1px;
    font-size: 13px;
    line-height: 1.08;
  }

  .dev-auto-slide--examples .dev-auto-card--compact p {
    font-size: 10.5px;
    line-height: 1.15;
  }
}

/* Leak control solution landing. Source of truth: specs/product-plans/leak-control-landing-plan.md */
body.leak-control-route .generated-page {
  background: #f3f8fd;
}

body.leak-control-route :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

.leak-hero {
  position: relative;
  min-height: calc(100svh - 76px);
  overflow: clip;
  color: #f8fbff;
  background: #061422;
  isolation: isolate;
}

.leak-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.leak-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  opacity: 1;
  filter: none;
}

.leak-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(3, 13, 25, 0.96) 0%, rgba(3, 13, 25, 0.86) 48%, rgba(3, 13, 25, 0.46) 100%),
    radial-gradient(circle at 82% 26%, rgba(44, 169, 255, 0.26), transparent 30%);
}

.leak-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.62fr);
  gap: clamp(28px, 6vw, 74px);
  align-items: center;
  min-height: calc(100svh - 76px);
  padding: clamp(64px, 10vh, 116px) 0;
}

.leak-hero-copy {
  max-width: 780px;
}

.leak-hero-copy .eyebrow {
  color: #77c8ff;
}

.leak-hero-copy h1 {
  max-width: 760px;
  margin-bottom: 22px;
  color: #fff;
  font-size: clamp(40px, 4.4vw, 64px);
  line-height: 1;
}

.leak-hero-copy p {
  max-width: 690px;
  color: rgba(236, 246, 255, 0.84);
}

.leak-lead {
  font-size: clamp(18px, 1.55vw, 23px);
  line-height: 1.44;
}

.leak-cable {
  position: absolute;
  right: 7%;
  top: 50%;
  width: min(310px, 24vw);
  height: auto;
  transform: translateY(-28%);
  filter: drop-shadow(0 28px 42px rgba(0, 0, 0, 0.36));
}

.leak-problem,
.leak-pilot,
.leak-benefits {
  background: #f4f8fc;
}

.leak-split,
.leak-visual-grid,
.leak-scope-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(360px, 1fr);
  gap: clamp(28px, 5vw, 62px);
  align-items: center;
}

.leak-visual-grid-reverse {
  grid-template-columns: minmax(360px, 1fr) minmax(0, 0.85fr);
}

.leak-copy h2,
.leak-section-head h2 {
  max-width: 860px;
}

.leak-copy p,
.leak-section-head p {
  max-width: 720px;
}

.leak-risk-grid,
.leak-metrics,
.leak-flow-grid,
.leak-benefit-grid {
  display: grid;
  gap: 16px;
}

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

.leak-risk-grid article,
.leak-metrics article,
.leak-flow-grid article,
.leak-benefit-grid article,
.leak-products {
  min-width: 0;
  padding: clamp(20px, 2.8vw, 30px);
  border: 1px solid rgba(31, 123, 255, 0.15);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: var(--shadow-soft);
}

.leak-risk-grid strong,
.leak-metrics strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.05;
}

.leak-risk-grid span,
.leak-metrics span {
  display: block;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.45;
}

.leak-visual-section,
.leak-flow,
.leak-scope {
  background:
    radial-gradient(circle at 18% 16%, rgba(31, 123, 255, 0.11), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #eef6ff 100%);
}

.leak-visual,
.leak-wide-visual,
.leak-scope-visual {
  margin: 0;
  padding: 10px;
  border: 1px solid rgba(31, 123, 255, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: var(--shadow-soft);
}

.leak-visual img,
.leak-wide-visual img,
.leak-scope-visual img {
  width: 100%;
  height: auto;
  border-radius: 20px;
  object-fit: contain;
}

.leak-list,
.leak-steps {
  display: grid;
  gap: 10px;
  margin: 22px 0 0;
  padding-left: 20px;
  color: var(--text);
  font-size: 16px;
  line-height: 1.55;
}

.leak-section-head {
  max-width: 860px;
  margin-bottom: 34px;
}

.leak-flow-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.leak-flow-grid article span {
  display: inline-flex;
  margin-bottom: 18px;
  color: var(--blue-dark);
  font-size: 13px;
  font-weight: 840;
}

.leak-flow-grid article h3,
.leak-benefit-grid article h3,
.leak-products h3 {
  color: var(--ink);
}

.leak-flow-grid article p,
.leak-benefit-grid article p {
  margin-bottom: 0;
  font-size: 15.5px;
}

.leak-wide-visual {
  margin-top: 26px;
}

.leak-scope {
  color: #f5faff;
  background:
    radial-gradient(circle at 80% 18%, rgba(62, 186, 255, 0.18), transparent 32%),
    linear-gradient(135deg, #061326 0%, #0b223d 58%, #071a2e 100%);
}

.leak-scope .leak-copy {
  grid-row: 1 / span 2;
}

.leak-scope-visual,
.leak-metrics {
  grid-column: 2;
}

.leak-scope-visual {
  border-color: rgba(122, 196, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
}

.leak-scope .eyebrow {
  color: #7ac4ff;
}

.leak-scope h2 {
  color: #fff;
}

.leak-scope p {
  color: rgba(233, 244, 255, 0.82);
}

.leak-note {
  padding: 14px 16px;
  border: 1px solid rgba(122, 196, 255, 0.22);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
}

.leak-metrics article {
  border-color: rgba(122, 196, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
}

.leak-metrics strong {
  color: #fff;
  font-size: clamp(30px, 4vw, 52px);
}

.leak-metrics span {
  color: rgba(231, 243, 255, 0.8);
}

.leak-benefit-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.leak-products {
  margin-top: 22px;
}

.leak-products h3 {
  margin-bottom: 18px;
}

@media (max-width: 1100px) {
  .leak-hero-inner,
  .leak-split,
  .leak-visual-grid,
  .leak-visual-grid-reverse,
  .leak-scope-grid {
    grid-template-columns: 1fr;
  }

  .leak-hero-inner {
    min-height: auto;
  }

  .leak-cable {
    width: min(360px, 64vw);
    right: 4%;
  }

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

  .leak-scope .leak-copy,
  .leak-scope-visual,
  .leak-metrics {
    grid-column: auto;
    grid-row: auto;
  }
}

@media (max-width: 780px) {
  .leak-hero {
    min-height: auto;
  }

  .leak-hero::after {
    background:
      linear-gradient(180deg, rgba(3, 13, 25, 0.98) 0%, rgba(3, 13, 25, 0.9) 70%, rgba(3, 13, 25, 0.7) 100%),
      radial-gradient(circle at 78% 20%, rgba(44, 169, 255, 0.2), transparent 28%);
  }

  .leak-hero-inner {
    padding: 64px 0 54px;
    gap: 28px;
  }

  .leak-hero-copy h1 {
    max-width: min(340px, calc(100vw - 34px));
    font-size: clamp(32px, 9vw, 40px);
    line-height: 1.05;
  }

  .leak-hero-copy p,
  .leak-copy p,
  .leak-section-head p {
    max-width: min(340px, calc(100vw - 34px));
    font-size: 16px;
  }

  .leak-copy h2,
  .leak-section-head h2 {
    max-width: min(340px, calc(100vw - 34px));
    font-size: clamp(28px, 8vw, 36px);
    line-height: 1.08;
  }

  .leak-risk-grid,
  .leak-metrics,
  .leak-flow-grid,
  .leak-benefit-grid {
    grid-template-columns: 1fr;
  }

  .leak-risk-grid article,
  .leak-metrics article,
  .leak-flow-grid article,
  .leak-benefit-grid article,
  .leak-products {
    padding: 20px;
    border-radius: 20px;
  }

  .leak-visual,
  .leak-wide-visual,
  .leak-scope-visual {
    padding: 6px;
    border-radius: 20px;
  }

  .leak-visual img,
  .leak-wide-visual img,
  .leak-scope-visual img {
    border-radius: 15px;
  }

  .leak-cable {
    top: auto;
    right: -52px;
    bottom: -78px;
    width: min(280px, 82vw);
    transform: none;
    opacity: 0.9;
  }
}

/* ASKUE premium landing */
body.askue-route {
  background: #f4f9ff;
}

body.askue-route h1,
body.askue-route h2,
body.askue-route h3,
body.askue-route p,
body.askue-route li,
body.askue-route a,
body.askue-route span,
body.askue-route button {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.askue-slide {
  position: relative;
  min-height: calc(100svh - 76px);
  isolation: isolate;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0;
  color: #071b3a;
  background: #eef6ff;
}

.askue-slide:not(.askue-card-slide) {
  height: auto;
  min-height: 0;
  aspect-ratio: 1672 / 941;
}

.askue-card-slide {
  height: auto;
  min-height: calc(100svh - 76px);
  overflow: visible;
  padding: clamp(44px, 6vw, 82px) 0;
}

.askue-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  width: 100%;
  height: 100%;
}

.askue-bg img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  object-fit: contain;
  object-position: center;
}

.askue-wf-a .askue-bg {
  inset: 0;
}

.askue-wf-b .askue-bg {
  inset: 0;
}

.askue-card-slide .askue-bg {
  inset: 0;
  width: 100%;
  display: block;
  background-position: top center;
  background-repeat: repeat-y;
  background-size: 100% auto;
}

.askue-card-slide .askue-bg img {
  width: 100%;
  height: auto;
  max-height: none;
  opacity: 0;
}

#askue-objects .askue-bg {
  background-image: url("../assets/solutions/askue/phase2_20260531/asset-askue-objects-bg-01.webp");
}

.askue-data .askue-bg {
  background-image: url("../assets/solutions/askue/phase2_20260531/asset-askue-data-bg-01.webp");
}

.askue-economics .askue-bg {
  background-image: url("../assets/solutions/askue/phase2_20260531/asset-askue-economics-bg-01.webp");
}

.askue-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(238, 246, 255, 0.12), rgba(238, 246, 255, 0.12));
}

.askue-slide-inner {
  display: grid;
  min-height: 0;
  height: 100%;
  align-items: center;
}

.askue-left-safe {
  grid-template-columns: minmax(0, 0.40fr) minmax(0, 0.60fr);
}

.askue-right-safe {
  grid-template-columns: minmax(0, 0.60fr) minmax(0, 0.40fr);
}

.askue-left-safe .askue-copy {
  grid-column: 1;
}

.askue-right-safe .askue-copy {
  grid-column: 2;
}

.askue-copy {
  max-width: 470px;
  padding: clamp(16px, 1.8vw, 24px);
}

.askue-copy h1 {
  max-width: 500px;
  margin-bottom: 12px;
  font-size: clamp(32px, 3.25vw, 48px);
  line-height: 1.03;
}

.askue-copy h2,
.askue-section-head h2,
.askue-process-copy h2 {
  max-width: 720px;
  color: #061630;
  font-size: clamp(34px, 3vw, 48px);
  font-weight: 840;
  line-height: 1.08;
}

.askue-copy p,
.askue-section-head p,
.askue-process-copy p,
.askue-legal {
  max-width: 680px;
  color: #071b3a;
  font-size: clamp(16px, 1.12vw, 18px);
  line-height: 1.44;
}

.askue-lead {
  color: #061630;
  font-weight: 760;
}

.askue-chip-list,
.askue-note-row,
.askue-pilot-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.askue-chip-list span,
.askue-note-row span,
.askue-pilot-grid span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 7px 11px;
  border: 1px solid rgba(31, 123, 255, 0.18);
  border-radius: 999px;
  color: #123a68;
  background: rgba(255, 255, 255, 0.72);
  font-size: 12.5px;
  font-weight: 760;
  box-shadow: 0 10px 26px rgba(15, 55, 115, 0.07);
}

.askue-list {
  display: grid;
  gap: 10px;
  margin: 16px 0 0;
  padding-left: 20px;
  color: #071b3a;
  font-size: clamp(16px, 1.05vw, 17.5px);
  line-height: 1.42;
}

.askue-card-section {
  display: grid;
  min-height: 0;
  align-content: center;
  gap: clamp(20px, 2.4vw, 30px);
}

.askue-section-head {
  max-width: 880px;
  padding: clamp(18px, 2vw, 26px);
}

.askue-card-slide .askue-section-head {
  max-width: 980px;
}

.askue-card-slide .eyebrow {
  color: #004dcb;
  font-size: 15px;
  font-weight: 900;
}

.askue-data .askue-section-head h2,
.askue-economics .askue-section-head h2 {
  color: #f7fbff;
}

.askue-data .askue-section-head p,
.askue-economics .askue-section-head p {
  color: #dcecff;
  font-weight: 620;
}

.askue-data .askue-section-head .eyebrow,
.askue-economics .askue-section-head .eyebrow {
  color: #5db1ff;
}

.askue-card-grid {
  display: grid;
  gap: clamp(14px, 1.5vw, 20px);
}

.askue-card-grid--eight {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.askue-card-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.askue-card {
  display: flex;
  overflow: hidden;
  min-width: 0;
  border: 1px solid rgba(31, 123, 255, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 34px rgba(15, 55, 115, 0.1);
}

.askue-card--image-top {
  flex-direction: column;
}

.askue-card-media {
  flex: 0 0 auto;
  min-width: 0;
  background: #06172a;
}

.askue-card--image-top .askue-card-media {
  aspect-ratio: 16 / 9;
}

.askue-card--image-top img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.askue-card--image-left {
  display: grid;
  grid-template-columns: minmax(170px, 0.38fr) minmax(0, 0.62fr);
  align-items: stretch;
}

.askue-card--image-left .askue-card-media {
  min-height: 170px;
}

.askue-card--image-left img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.askue-card-body {
  padding: 14px 14px 16px;
}

.askue-card h3 {
  margin-bottom: 6px;
  color: #071b3a;
  font-size: clamp(19px, 1.45vw, 23px);
  font-weight: 840;
  line-height: 1.14;
}

.askue-card p {
  margin-bottom: 0;
  color: #233f62;
  font-size: clamp(14.5px, 0.95vw, 16px);
  line-height: 1.42;
}

.askue-process {
  display: grid;
  align-items: stretch;
}

.askue-bg--process {
  inset: 0;
  width: 100%;
  height: 100%;
  align-items: center;
}

.askue-bg--process img {
  width: 100%;
  height: 100%;
  max-height: none;
}

.askue-process-inner {
  display: grid;
  min-height: 0;
  height: 100%;
  grid-template-rows: minmax(0, 0.30fr) minmax(0, 0.42fr) minmax(0, 0.28fr);
  align-content: stretch;
  gap: 18px;
  padding: clamp(28px, 4vh, 44px) 0;
}

.askue-process-copy {
  align-self: start;
  max-width: 820px;
  padding: 14px 18px;
}

.askue-process-copy h2 {
  font-size: clamp(26px, 2.2vw, 34px);
}

.askue-note-row {
  grid-row: 3;
  align-self: end;
  justify-content: center;
}

.askue-process-detail {
  grid-row: 3;
  align-self: start;
  justify-self: center;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(22px, 3vw, 44px);
  width: min(100%, 1120px);
  margin: 0 auto;
  padding: 0 clamp(12px, 2vw, 24px);
}

.askue-process-detail p {
  margin: 0;
  color: #071b3a;
  font-size: clamp(15px, 1vw, 17px);
  font-weight: 620;
  line-height: 1.42;
}

.askue-process-detail--pilot {
  align-self: center;
  grid-template-columns: minmax(0, 760px);
  justify-content: center;
  width: min(100%, 820px);
}

.askue-pilot .askue-process-inner {
  grid-template-rows: minmax(0, 0.30fr) minmax(0, 0.47fr) minmax(0, 0.23fr);
}

.askue-pilot-grid {
  grid-row: 3;
  align-self: end;
  justify-content: center;
  margin-top: 0;
}

.askue-legal {
  grid-row: 3;
  align-self: end;
  justify-self: center;
  max-width: 900px;
  margin: 0;
  padding: 0 18px;
  color: #071b3a;
  font-weight: 650;
}

.askue-products {
  background: linear-gradient(180deg, #ffffff 0%, #eef6ff 100%);
}

.askue-products-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.62fr) minmax(320px, 0.38fr);
  gap: 28px;
  align-items: center;
}

.askue-gateway-strip {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 10px;
}

.askue-gateway-strip img {
  width: min(31%, 150px);
  height: auto;
  object-fit: contain;
}

@media (max-width: 1180px) {
  .askue-slide {
    height: auto;
    min-height: calc(100svh - 68px);
    padding: 32px 0;
    overflow: hidden;
  }

  .askue-slide:not(.askue-card-slide) {
    min-height: 0;
    aspect-ratio: 1672 / 941;
    padding: 0;
  }

  .askue-slide-inner,
  .askue-left-safe,
  .askue-right-safe {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .askue-left-safe .askue-copy,
  .askue-right-safe .askue-copy {
    grid-column: 1;
  }

  .askue-copy {
    max-width: 620px;
  }

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

  .askue-bg img,
  .askue-bg--process img {
    width: 100%;
    height: 100%;
    max-height: none;
    object-fit: contain;
  }

  .askue-process-inner {
    height: 100%;
    grid-template-rows: minmax(0, 0.34fr) minmax(0, 0.36fr) minmax(0, 0.30fr);
  }

  .askue-pilot .askue-process-inner {
    grid-template-rows: minmax(0, 0.28fr) minmax(0, 0.30fr) minmax(0, 0.32fr) minmax(0, 0.10fr);
  }

  .askue-process-detail {
    gap: 18px;
  }

  .askue-card-slide {
    height: auto;
    min-height: calc(100svh - 68px);
    overflow: visible;
  }

  .askue-card-grid--eight,
  .askue-card-grid--six {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .askue-card-grid--economics {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px) {
  .askue-slide {
    padding: 18px 0;
  }

  .askue-slide:not(.askue-card-slide) {
    padding: 0;
  }

  .askue-bg {
    margin-bottom: 0;
  }

  .askue-bg img {
    width: 100%;
    height: 100%;
    max-height: none;
  }

  .askue-copy h1 {
    margin-bottom: 14px;
    font-size: clamp(28px, 8vw, 36px);
    line-height: 1.04;
  }

  .askue-copy h2,
  .askue-section-head h2,
  .askue-process-copy h2 {
    margin-bottom: 10px;
    font-size: clamp(24px, 7vw, 32px);
    line-height: 1.08;
  }

  .askue-copy p,
  .askue-section-head p,
  .askue-process-copy p,
  .askue-process-detail p,
  .askue-legal {
    margin-bottom: 10px;
    font-size: 13.5px;
    line-height: 1.34;
  }

  .askue-process-detail {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 0 14px;
  }

  .askue-card-grid--eight,
  .askue-card-grid--six {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .askue-card-grid--economics {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .askue-card--image-top img {
    min-height: 96px;
    aspect-ratio: auto;
  }

  .askue-card--image-left {
    grid-template-columns: minmax(120px, 0.38fr) minmax(0, 0.62fr);
  }

  .askue-card--image-left .askue-card-media {
    min-height: 128px;
  }

  .askue-card-body {
    padding: 10px;
  }

  .askue-card h3 {
    margin-bottom: 5px;
    font-size: 15px;
  }

  .askue-card p {
    font-size: 12px;
    line-height: 1.28;
  }

  .askue-chip-list span,
  .askue-note-row span,
  .askue-pilot-grid span {
    min-height: 28px;
    padding: 6px 9px;
    font-size: 11.5px;
  }

  .askue-chip-list {
    gap: 7px;
    margin-top: 12px;
  }

  .askue-route .hero-actions {
    gap: 8px;
  }

  .askue-route .hero-actions .btn {
    min-height: 42px;
    padding: 10px 14px;
    font-size: 13px;
  }

  .askue-products-inner {
    grid-template-columns: 1fr;
  }

  .askue-gateway-strip img {
    width: min(30%, 110px);
  }
}

@media (max-width: 480px) {
  .askue-hero {
    padding: 16px 0;
  }

  .askue-hero .askue-bg {
    margin-bottom: 0;
  }

  .askue-hero .askue-bg img {
    max-height: none;
  }

  .askue-hero .askue-copy {
    padding: 14px;
  }

  .askue-hero .askue-copy h1 {
    margin-bottom: 10px;
    font-size: 28px;
    line-height: 1.02;
  }

  .askue-hero .askue-copy p {
    margin-bottom: 8px;
    font-size: 12.5px;
    line-height: 1.28;
  }

  .askue-hero .askue-chip-list {
    gap: 6px;
    margin-top: 8px;
  }

  .askue-hero .askue-chip-list span {
    min-height: 24px;
    padding: 4px 8px;
    font-size: 10.5px;
  }

  .askue-hero .hero-actions {
    gap: 6px;
    margin-top: 8px;
  }

  .askue-hero .hero-actions .btn {
    min-height: 34px;
    padding: 7px 10px;
    font-size: 11.5px;
  }

  .askue-card-grid--eight,
  .askue-card-grid--six {
    grid-template-columns: 1fr;
  }

  .askue-card--image-left {
    grid-template-columns: 1fr;
  }

  .askue-card--image-left .askue-card-media {
    min-height: 160px;
  }
}

/* Leak control Phase 3 integration. Source of truth:
   specs/product-plans/leak-control-asset-batch-2026-05-31.md */
body.leak-control-route .generated-page {
  background: #07101b;
}

body.leak-control-route .generated-cta {
  margin-top: 0;
}

/* HVAC climate monitoring Phase 3 integration */
.hvac-route {
  --gr-ink: #123421;
  --gr-text: #294a35;
  --gr-muted: #5b765f;
  --gr-green: #208a4b;
  --gr-green-dark: #12663a;
  --gr-line: rgba(32, 138, 75, 0.2);
  --gr-surface: rgba(255, 255, 255, 0.9);
  background: #f4fbef;
}

.hvac-route .generated-page {
  background: #f4fbef;
}

.hvac-route .rf-slide {
  background: #f4fbef;
}

.hvac-route .rf-bg {
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
}

.hvac-route .rf-slide:not(.rf-card-slide) {
  min-height: min(calc(100vw * 941 / 1672), 100vh);
}

.hvac-route .rf-inner--left {
  grid-template-columns: minmax(0, 0.62fr) minmax(0, 0.38fr);
}

.hvac-route .rf-inner--right {
  grid-template-columns: minmax(0, 0.38fr) minmax(0, 0.62fr);
}

.hvac-route .rf-copy {
  max-width: min(790px, 58vw);
}

.hvac-route .rf-inner--right .rf-copy {
  max-width: min(790px, 58vw);
  justify-self: end;
}

.hvac-route .rf-copy h1 {
  max-width: 760px;
  font-size: clamp(34px, 3.85vw, 60px);
  line-height: 1.03;
}

.hvac-route .rf-copy h2,
.hvac-route .rf-section-head h2 {
  font-size: clamp(30px, 3.05vw, 48px);
  line-height: 1.06;
}

.hvac-route .rf-copy p,
.hvac-route .rf-section-head p,
.hvac-route .rf-card-note {
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.38;
}

.hvac-route .rf-copy p {
  margin-top: 11px;
}

.hvac-route .rf-card-media {
  aspect-ratio: 16 / 9;
  background: #edf8ea;
}

.hvac-route .rf-card-body {
  padding: clamp(14px, 1.3vw, 18px);
}

.hvac-route .rf-card h3 {
  font-size: clamp(17px, 1.15vw, 20px);
}

.hvac-route .rf-card p {
  font-size: 14px;
  line-height: 1.34;
}

.hvac-route .hvac-audience-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hvac-route .hvac-audience-grid .rf-card:nth-child(4) {
  grid-column: 1 / 2;
}

.hvac-route .hvac-audience-grid .rf-card:nth-child(5) {
  grid-column: 2 / 4;
}

.hvac-route .hvac-final-inner {
  position: relative;
  z-index: 1;
  min-height: inherit;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(10px, 1.2vw, 16px);
  align-items: stretch;
  padding-top: clamp(22px, 3.4vh, 42px);
  padding-bottom: clamp(22px, 3.4vh, 42px);
}

.hvac-route .hvac-final-copy {
  grid-row: 1;
  max-width: min(900px, 64vw);
  align-self: start;
}

.hvac-route .hvac-start-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  max-width: min(960px, 72vw);
  margin-top: clamp(12px, 1.7vw, 20px);
}

.hvac-route .hvac-start-list span {
  min-height: 58px;
  display: flex;
  align-items: center;
  padding: 9px 10px;
  border: 1px solid rgba(32, 138, 75, 0.22);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--gr-green-dark);
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.22;
}

.hvac-route .hvac-final-bottom {
  grid-row: 3;
  max-width: min(980px, 74vw);
  align-self: end;
}

.hvac-route .hvac-contact {
  background: #f1faed;
}

.hvac-route .hvac-contact .generated-cta-card {
  border-color: var(--gr-line);
  box-shadow: 0 20px 60px rgba(37, 95, 45, 0.1);
}

@media (max-width: 1180px) {
  .hvac-route .rf-copy,
  .hvac-route .rf-inner--right .rf-copy {
    max-width: min(720px, 60vw);
  }

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

  .hvac-route .hvac-audience-grid .rf-card:nth-child(4),
  .hvac-route .hvac-audience-grid .rf-card:nth-child(5) {
    grid-column: auto;
  }

  .hvac-route .hvac-start-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: min(820px, 66vw);
  }
}

@media (max-width: 860px) {
  .hvac-route .rf-inner {
    display: block;
  }

  .hvac-route .rf-copy,
  .hvac-route .rf-inner--right .rf-copy,
  .hvac-route .rf-section-head {
    max-width: 62%;
  }

  .hvac-route .rf-inner--right .rf-copy {
    margin-left: auto;
  }

  .hvac-route .rf-copy h1 {
    font-size: clamp(28px, 7.4vw, 36px);
  }

  .hvac-route .rf-copy h2,
  .hvac-route .rf-section-head h2 {
    font-size: clamp(25px, 6.5vw, 33px);
  }

  .hvac-route .rf-copy p,
  .hvac-route .rf-section-head p,
  .hvac-route .rf-card-note {
    font-size: 14px;
    line-height: 1.3;
  }

  .hvac-route .rf-card-grid--six,
  .hvac-route .hvac-audience-grid {
    grid-template-columns: 1fr;
  }

  .hvac-route .hvac-final-inner {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(180px, 1fr) auto;
    gap: 14px;
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .hvac-route .hvac-final-copy,
  .hvac-route .hvac-start-list,
  .hvac-route .hvac-final-bottom {
    max-width: 100%;
  }

  .hvac-route .hvac-start-list {
    grid-template-columns: 1fr;
  }

  .hvac-route .hvac-final-bottom {
    margin-top: 0;
  }
}

@media (max-width: 520px) {
  .hvac-route .rf-copy,
  .hvac-route .rf-inner--right .rf-copy,
  .hvac-route .rf-section-head {
    max-width: 68%;
  }

  .hvac-route .hvac-hero .rf-copy,
  .hvac-route .hvac-dispatch .rf-copy {
    max-width: 70%;
  }

  .hvac-route .hvac-managed .rf-copy {
    max-width: 66%;
    margin-left: auto;
  }

  .hvac-route .hero-actions {
    gap: 8px;
  }

  .hvac-route .hero-actions .btn {
    min-height: 38px;
    padding: 10px 13px;
    font-size: 13px;
  }
}

/* Wastewater monitoring Phase 3 integration */
.wastewater-route {
  --ww-ink: #071f13;
  --ww-text: #021008;
  --ww-muted: #60796b;
  --ww-green: #176a40;
  --ww-green-dark: #073d24;
  --ww-blue: #0d547c;
  --ww-line: rgba(43, 138, 85, 0.22);
  --ww-surface: rgba(255, 255, 255, 0.88);
  background: #f4f9ef;
}

.wastewater-route .generated-page {
  background: #f4f9ef;
}

.wastewater-route .rf-slide {
  background: #f4f9ef;
  color: var(--ww-ink);
}

.wastewater-route .rf-slide:not(.rf-card-slide) {
  min-height: calc(100vw * 941 / 1672);
}

.wastewater-route .rf-bg {
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
}

.wastewater-route .ww-hero::after,
.wastewater-route .ww-quiet-normal::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  z-index: 0;
  width: min(62vw, 880px);
  pointer-events: none;
}

.wastewater-route .ww-hero::after {
  background: linear-gradient(90deg, rgba(244, 249, 239, 0.92) 0%, rgba(244, 249, 239, 0.72) 54%, rgba(244, 249, 239, 0) 100%);
}

.wastewater-route .ww-quiet-normal::after {
  inset: 0 0 0 auto;
  background: linear-gradient(270deg, rgba(244, 249, 239, 0.94) 0%, rgba(244, 249, 239, 0.78) 58%, rgba(244, 249, 239, 0) 100%);
}

.wastewater-route .rf-inner,
.wastewater-route .rf-card-section {
  position: relative;
  z-index: 1;
  padding-top: clamp(24px, 4vh, 50px);
  padding-bottom: clamp(24px, 4vh, 50px);
}

.wastewater-route .rf-inner--left {
  grid-template-columns: minmax(0, 0.58fr) minmax(0, 0.42fr);
}

.wastewater-route .rf-inner--right {
  grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
}

.wastewater-route .rf-copy {
  max-width: min(760px, 58vw);
}

.wastewater-route .rf-inner--right .rf-copy {
  max-width: min(720px, 54vw);
  justify-self: end;
}

.wastewater-route .rf-copy h1,
.wastewater-route .rf-copy h2,
.wastewater-route .rf-section-head h2 {
  color: var(--ww-ink);
}

.wastewater-route .rf-copy h1 {
  max-width: 760px;
  font-size: clamp(34px, 3.8vw, 60px);
  line-height: 1.03;
}

.wastewater-route .rf-copy h2,
.wastewater-route .rf-section-head h2 {
  font-size: clamp(30px, 3vw, 48px);
  line-height: 1.06;
}

.wastewater-route .rf-copy p,
.wastewater-route .rf-section-head p,
.wastewater-route .rf-card-note {
  color: var(--ww-text);
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.38;
}

.wastewater-route .rf-copy p {
  margin-top: 11px;
}

.wastewater-route .eyebrow {
  color: var(--ww-green-dark);
}

.wastewater-route .eyebrow::before {
  background: var(--ww-green);
  box-shadow: 0 0 0 8px rgba(43, 138, 85, 0.12);
}

.wastewater-route .rf-accent {
  color: #021008 !important;
  font-weight: 800;
}

.wastewater-route .ww-offer {
  max-width: 680px;
  color: #021008;
  font-weight: 700;
}

.wastewater-route .ww-quiet-normal .rf-copy h2,
.wastewater-route .ww-quiet-normal .rf-copy p,
.wastewater-route .ww-quiet-normal .rf-accent {
  color: #021008 !important;
}

.wastewater-route .btn-primary {
  background: linear-gradient(135deg, #187a49 0%, #073d24 100%);
  box-shadow: 0 14px 34px rgba(43, 138, 85, 0.24);
}

.wastewater-route .btn-secondary {
  color: var(--ww-green-dark);
  border-color: rgba(43, 138, 85, 0.25);
  background: rgba(255, 255, 255, 0.78);
}

.wastewater-route .rf-section-head {
  max-width: 1040px;
}

.wastewater-route .rf-card {
  overflow: hidden;
  border-color: var(--ww-line);
  background: var(--ww-surface);
  box-shadow: 0 18px 44px rgba(38, 88, 50, 0.11);
}

.wastewater-route .rf-card-media {
  aspect-ratio: 16 / 9;
  background: #edf7ea;
}

.wastewater-route .rf-card-media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.wastewater-route .rf-card-body {
  padding: clamp(14px, 1.3vw, 18px);
}

.wastewater-route .rf-card-body span {
  color: #0b5d36;
}

.wastewater-route .rf-card h3 {
  color: var(--ww-ink);
  font-size: clamp(17px, 1.14vw, 20px);
}

.wastewater-route .rf-card p {
  color: var(--ww-text);
  font-size: 14px;
  line-height: 1.34;
}

.wastewater-route .rf-card p + p {
  margin-top: 8px;
}

.wastewater-route .rf-card-note {
  color: #062f1d;
}

.wastewater-route .ww-status-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.wastewater-route .ww-status-strip span,
.wastewater-route .ww-start-list span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px;
  border: 1px solid rgba(43, 138, 85, 0.22);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ww-green-dark);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
}

.wastewater-route .ww-final-cta {
  min-height: min(56.28vw, 100vh);
}

.wastewater-route .ww-final-inner {
  position: relative;
  z-index: 1;
  min-height: inherit;
  display: grid;
  grid-template-rows: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  align-items: stretch;
  padding-top: clamp(22px, 3.4vh, 42px);
  padding-bottom: clamp(22px, 3.4vh, 42px);
}

.wastewater-route .ww-final-copy {
  max-width: min(760px, 55vw);
}

.wastewater-route .ww-final-copy p {
  margin-top: 8px;
  line-height: 1.26;
}

.wastewater-route .ww-final-copy h2 {
  font-size: clamp(28px, 2.7vw, 44px);
}

.wastewater-route .ww-final-top {
  grid-row: 1;
  align-self: start;
}

.wastewater-route .ww-final-bottom {
  grid-row: 3;
  align-self: end;
  position: relative;
  top: 10px;
}

.wastewater-route .ww-start-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
  max-width: min(860px, 62vw);
}

.wastewater-route .ww-start-list span {
  min-height: 56px;
}

.wastewater-route .ww-contact {
  background: #f4f9ef;
}

.wastewater-route .generated-cta-card {
  border-color: var(--ww-line);
  box-shadow: 0 20px 60px rgba(38, 88, 50, 0.11);
}

.wastewater-route .ww-contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.wastewater-route .ww-contact-form label {
  gap: 4px;
  color: var(--ww-text);
  font-size: 12.5px;
}

.wastewater-route .ww-contact-form input,
.wastewater-route .ww-contact-form select,
.wastewater-route .ww-contact-form textarea {
  width: 100%;
  min-height: 37px;
  padding: 9px 10px;
  border: 1px solid rgba(43, 138, 85, 0.22);
  border-radius: 8px;
  background: #fff;
  color: var(--ww-ink);
  font: inherit;
}

.wastewater-route .ww-contact-form textarea {
  min-height: 62px;
}

.wastewater-route .ww-contact-form .form-consent {
  font-size: 12px;
  line-height: 1.25;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

.wastewater-route .ww-contact-form button {
  justify-self: start;
}

@media (max-width: 1180px) {
  .wastewater-route .rf-copy,
  .wastewater-route .rf-inner--right .rf-copy {
    max-width: min(700px, 58vw);
  }

  .wastewater-route .rf-card-grid--six,
  .wastewater-route .rf-card-grid--four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .wastewater-route .ww-start-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: min(720px, 58vw);
  }
}

@media (min-width: 761px) and (max-height: 820px) {
  .wastewater-route .ww-hero .rf-copy h1 {
    font-size: clamp(30px, 3.3vw, 50px);
  }

  .wastewater-route .ww-hero .rf-copy p {
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.24;
  }
}

@media (max-width: 860px) {
  .wastewater-route .rf-slide:not(.rf-card-slide) {
    min-height: min(56.28vw, 100vh);
  }

  .wastewater-route .rf-bg {
    object-fit: contain;
  }

  .wastewater-route .rf-inner {
    display: block;
  }

  .wastewater-route .rf-copy,
  .wastewater-route .rf-section-head {
    max-width: 64%;
  }

  .wastewater-route .rf-inner--right .rf-copy {
    max-width: 62%;
    margin-left: auto;
  }

  .wastewater-route .rf-copy h1 {
    font-size: clamp(28px, 7.4vw, 36px);
  }

  .wastewater-route .rf-copy h2,
  .wastewater-route .rf-section-head h2 {
    font-size: clamp(25px, 6.5vw, 33px);
  }

  .wastewater-route .rf-copy p,
  .wastewater-route .rf-section-head p,
  .wastewater-route .rf-card-note {
    font-size: 14px;
    line-height: 1.3;
  }

  .wastewater-route .rf-card-grid--six,
  .wastewater-route .rf-card-grid--four {
    grid-template-columns: 1fr;
  }

  .wastewater-route .ww-final-cta {
    min-height: 100vh;
  }

  .wastewater-route .ww-final-inner {
    display: grid;
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .wastewater-route .ww-final-copy {
    max-width: 64%;
  }

  .wastewater-route .ww-start-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: 100%;
  }

  .wastewater-route .ww-contact-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .wastewater-route .rf-copy,
  .wastewater-route .rf-section-head {
    max-width: 64%;
  }

  .wastewater-route .rf-inner--right .rf-copy {
    max-width: 64%;
  }

  .wastewater-route .ww-hero .rf-copy,
  .wastewater-route .ww-service-dashboard .rf-copy {
    max-width: 58%;
  }

  .wastewater-route .ww-final-copy {
    max-width: 74%;
  }

  .wastewater-route .ww-final-top p:not(.eyebrow),
  .wastewater-route .ww-final-bottom p {
    font-size: 13px;
    line-height: 1.22;
  }

  .wastewater-route .ww-start-list span {
    min-height: 42px;
    padding: 6px 8px;
    font-size: 11.5px;
  }

  .wastewater-route .ww-hero .rf-copy h1 {
    font-size: clamp(24px, 6.4vw, 30px);
    line-height: 1.02;
  }

  .wastewater-route .ww-hero .rf-copy p {
    margin-top: 7px;
    color: #021008;
    font-size: 12.5px;
    font-weight: 600;
    line-height: 1.2;
  }

  .wastewater-route .ww-hero .rf-accent,
  .wastewater-route .ww-hero .ww-offer {
    color: #021008 !important;
    font-weight: 800;
  }

  .wastewater-route .hero-actions {
    gap: 8px;
  }

  .wastewater-route .hero-actions .btn {
    min-height: 38px;
    padding: 10px 13px;
    font-size: 13px;
  }
}

.leak-slide {
  position: relative;
  display: grid;
  align-items: start;
  width: 100%;
  min-height: auto;
  padding: 0;
  color: #edf7ff;
  background: #07101b;
  isolation: isolate;
}

.leak-slide-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  display: flex;
  align-items: stretch;
  justify-content: center;
  pointer-events: none;
}

.leak-slide-bg img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: contain;
  object-position: center center;
  opacity: 1;
  filter: none;
}

.leak-slide[data-background-mode="full-width"] {
  aspect-ratio: var(--leak-bg-aspect);
}

.leak-slide[data-background-mode="full-width"] > .container {
  min-height: 100%;
}

.leak-slide-bg--abstract {
  background:
    radial-gradient(circle at 16% 14%, rgba(31, 123, 255, 0.14), transparent 28%),
    radial-gradient(circle at 88% 20%, rgba(139, 214, 255, 0.11), transparent 32%),
    linear-gradient(135deg, #07101b 0%, #0c1b2b 100%);
}

.leak-slide--a .leak-slide-bg img {
  object-position: left center;
}

.leak-slide--b .leak-slide-bg img {
  object-position: center center;
}

.leak-slide--d .leak-slide-bg img {
  object-position: center center;
}

.leak-hero,
.leak-problem,
.leak-pilot,
.leak-benefits,
.leak-requirements,
.leak-zones,
.leak-flow,
.leak-scope {
  overflow: visible;
}

.leak-hero {
  --leak-bg-aspect: 1774 / 887;
}

.leak-zones,
.leak-flow,
.leak-pilot,
.leak-scope {
  --leak-bg-aspect: 1672 / 941;
}

.leak-hero::after {
  display: none;
}

.leak-hero-inner,
.leak-zones-inner,
.leak-pilot-inner,
.leak-flow-inner,
.leak-card-section {
  position: relative;
  z-index: 1;
  padding-top: clamp(42px, 5.8vh, 68px);
  padding-bottom: clamp(42px, 5.8vh, 68px);
}

.leak-hero-inner {
  min-height: auto;
  grid-template-columns: minmax(0, 0.92fr) minmax(280px, 0.78fr);
}

.leak-zones-inner {
  display: block;
}

.leak-zones-inner,
.leak-pilot-inner {
  display: grid;
  align-items: center;
}

.leak-zones-visual {
  margin: 0;
  display: none;
}

.leak-zones-visual img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 560px;
  object-fit: contain;
}

.leak-hero-copy,
.leak-safe-left {
  max-width: min(650px, 48vw);
}

.leak-safe-right {
  width: min(560px, 42vw);
  margin-left: auto;
}

.leak-zones .leak-copy h2,
.leak-pilot .leak-copy h2 {
  font-size: clamp(40px, 4.1vw, 64px);
}

.leak-zones .leak-copy p,
.leak-zones .leak-copy li,
.leak-pilot .leak-copy p,
.leak-pilot .leak-copy li {
  font-size: clamp(17px, 1.25vw, 21px);
  line-height: 1.48;
}

.leak-copy .eyebrow,
.leak-section-head .eyebrow {
  color: #8bd6ff;
}

.leak-copy h1,
.leak-copy h2,
.leak-section-head h2 {
  color: #fff;
}

.leak-copy h1 {
  max-width: 720px;
  font-size: clamp(42px, 4.2vw, 64px);
  line-height: 1.02;
}

.leak-copy h2,
.leak-section-head h2 {
  max-width: 860px;
  font-size: clamp(34px, 3.5vw, 54px);
  line-height: 1.03;
}

.leak-copy p,
.leak-copy li,
.leak-section-head p {
  color: rgba(234, 246, 255, 0.82);
}

.leak-lead {
  font-size: clamp(18px, 1.55vw, 23px);
}

.leak-card-section {
  width: min(1180px, calc(100vw - 40px));
}

.leak-problem,
.leak-benefits,
.leak-requirements {
  background: #07101b;
}

.leak-section-head {
  max-width: 860px;
  margin: 0 0 clamp(22px, 4vh, 34px);
}

.leak-card-grid {
  display: grid;
  gap: clamp(14px, 1.5vw, 18px);
}

.leak-card-grid--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.leak-card {
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: visible;
  border: 1px solid rgba(139, 214, 255, 0.2);
  border-radius: 8px;
  background: rgba(8, 22, 36, 0.78);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
}

.leak-card-media {
  min-width: 0;
  aspect-ratio: 1.12 / 1;
  background: rgba(5, 13, 24, 0.82);
}

.leak-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.leak-card-body {
  min-width: 0;
  padding: clamp(15px, 1.5vw, 20px);
}

.leak-card h3 {
  margin: 0 0 8px;
  color: #fff;
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.12;
}

.leak-card p {
  margin: 0;
  color: rgba(232, 244, 255, 0.78);
  font-size: 14.5px;
  line-height: 1.36;
}

.leak-list,
.leak-steps {
  color: rgba(234, 246, 255, 0.82);
}

.leak-flow-inner {
  display: grid;
  min-height: 100%;
  grid-template-rows: auto 1fr auto;
  align-content: stretch;
  gap: clamp(14px, 2.2vh, 24px);
  padding-top: clamp(30px, 4vh, 44px);
  padding-bottom: clamp(30px, 4vh, 44px);
}

.leak-flow-visual {
  margin: 0;
  border: 1px solid rgba(139, 214, 255, 0.16);
  border-radius: 8px;
  background: rgba(5, 13, 24, 0.72);
}

.leak-flow-visual img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 230px;
  object-fit: contain;
}

.leak-flow-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-self: end;
}

.leak-flow-grid article,
.leak-metrics article,
.leak-products {
  border: 1px solid rgba(139, 214, 255, 0.2);
  border-radius: 8px;
  background: rgba(8, 22, 36, 0.74);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.18);
}

.leak-flow-grid article {
  padding: 14px;
}

.leak-flow-grid article h3,
.leak-products h3 {
  color: #fff;
}

.leak-flow-grid article p {
  color: rgba(232, 244, 255, 0.78);
  font-size: 14px;
  line-height: 1.36;
}

.leak-scope {
  background: #07101b;
}

.leak-scope-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr auto;
  min-height: 100%;
  gap: clamp(12px, 1.6vw, 20px);
  padding-top: clamp(24px, 3.2vh, 36px);
  padding-bottom: clamp(24px, 3.2vh, 36px);
}

.leak-scope-copy {
  grid-column: 1;
  grid-row: auto;
  max-width: 1180px;
  align-self: start;
}

.leak-scope h2 {
  max-width: none;
  white-space: nowrap;
}

.leak-scope-visual {
  display: none;
  grid-column: 1;
  height: clamp(170px, 16vw, 200px);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.leak-scope-visual img {
  display: block;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  border-radius: 0;
  object-fit: contain;
}

.leak-metrics {
  grid-column: 1;
  align-self: end;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.leak-metrics article {
  padding: clamp(16px, 2vw, 22px);
}

.leak-scope .leak-metrics article {
  padding: clamp(14px, 1.4vw, 18px);
}

.leak-metrics strong {
  color: #fff;
  font-size: clamp(27px, 3vw, 42px);
}

.leak-scope .leak-metrics strong {
  font-size: clamp(25px, 2.5vw, 36px);
}

.leak-metrics span {
  color: rgba(231, 243, 255, 0.8);
}

.leak-note {
  border-radius: 8px;
}

.leak-products {
  margin-top: clamp(14px, 2.2vh, 22px);
  padding: clamp(14px, 1.6vw, 20px);
}

.leak-products .generated-link-cloud a {
  color: #dff4ff;
  border-color: rgba(139, 214, 255, 0.22);
  background: rgba(255, 255, 255, 0.08);
}

@media (max-width: 1180px) {
  .leak-slide {
    min-height: auto;
  }

  .leak-hero-inner,
  .leak-zones-inner,
  .leak-scope-grid {
    grid-template-columns: 1fr;
  }

  .leak-hero-copy,
  .leak-safe-left,
  .leak-safe-right {
    width: auto;
    max-width: 680px;
    margin-left: 0;
  }

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

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

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

@media (max-width: 900px) {
  .leak-slide[data-background-mode="full-width"] {
    aspect-ratio: auto;
  }

  .leak-scope h2 {
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .leak-hero-inner,
  .leak-zones-inner,
  .leak-pilot-inner,
  .leak-flow-inner,
  .leak-card-section {
    padding-top: 44px;
    padding-bottom: 44px;
  }

  .leak-card-section {
    width: calc(100vw - 28px);
  }

  .leak-scope-visual img {
    max-height: none;
    margin-left: 0;
  }

  .leak-slide-bg {
    position: absolute;
    inset: 0;
    order: initial;
    margin-bottom: 0;
  }

  .leak-slide-bg img {
    width: 100%;
    height: 100%;
    object-position: right bottom;
  }

  .leak-hero-copy,
  .leak-safe-left,
  .leak-safe-right,
  .leak-copy h1,
  .leak-copy h2,
  .leak-section-head h2,
  .leak-copy p,
  .leak-section-head p {
    max-width: min(100%, 350px);
  }

  .leak-copy h1 {
    font-size: clamp(34px, 10vw, 43px);
  }

  .leak-copy h2,
  .leak-section-head h2 {
    font-size: clamp(29px, 8.5vw, 38px);
  }

  .leak-card-grid--four,
  .leak-flow-grid,
  .leak-metrics {
    grid-template-columns: 1fr;
  }

  .leak-flow-inner {
    gap: 12px;
    padding-top: 18px;
    padding-bottom: 18px;
  }

  .leak-flow-visual img {
    max-height: 120px;
  }

  .leak-flow-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .leak-flow-grid article {
    padding: 10px;
  }

  .leak-flow-grid article span {
    font-size: 13px;
  }

  .leak-flow-grid article h3 {
    font-size: 16px;
    line-height: 1.15;
  }

  .leak-flow-grid article p {
    font-size: 14px;
    line-height: 1.35;
  }

  .leak-card {
    display: flex;
  }

  .leak-card-media {
    min-height: 0;
  }

  .leak-card-body {
    padding: 14px;
  }

  .leak-card-media img {
    width: 100%;
  }

  .leak-card h3 {
    align-self: end;
  }

  .leak-card p {
    align-self: start;
  }

}
/* Electronics development landing
   Source of truth: specs/product-plans/electronics-development-section-contracts-2026-06-01.json */
body.electronics-development-route .electronics-development-page {
  background: #f5f8fb;
  color: var(--ink);
}

body.electronics-development-route .electronics-development-page :where(h1, h2, h3, p, li, a, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.electronics-development-route .electronics-slide {
  position: relative;
  display: grid;
  place-items: center;
  padding: 0 var(--container-padding, 24px);
  background: #f5f8fb;
  isolation: isolate;
}

body.electronics-development-route .electronics-frame {
  position: relative;
  width: min(100%, 1392px);
  aspect-ratio: 1672 / 941;
  min-height: 0;
  overflow: hidden;
  isolation: isolate;
}

body.electronics-development-route .electronics-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  opacity: 1;
  filter: none;
  transform: none;
  pointer-events: none;
}

body.electronics-development-route .electronics-bg--abstract {
  object-fit: fill;
}

body.electronics-development-route .electronics-hero-copy,
body.electronics-development-route .electronics-process-copy,
body.electronics-development-route .electronics-final-copy,
body.electronics-development-route .electronics-card-layout {
  position: absolute;
  z-index: 1;
}

body.electronics-development-route .electronics-hero-copy {
  left: 5.5%;
  top: 8%;
  width: 52%;
  display: grid;
  gap: clamp(10px, 1.15vw, 16px);
}

body.electronics-development-route .eyebrow {
  color: #187d83;
}

body.electronics-development-route .electronics-hero-copy h1 {
  max-width: 760px;
  color: #0d2630;
  font-size: clamp(42px, 4vw, 70px);
  line-height: 0.98;
  letter-spacing: 0;
}

body.electronics-development-route .electronics-hero-copy p,
body.electronics-development-route .electronics-section-head p,
body.electronics-development-route .electronics-process-copy p,
body.electronics-development-route .electronics-final-copy p {
  max-width: 790px;
  color: #3f5965;
}

body.electronics-development-route .electronics-lead {
  color: #193842;
  font-size: clamp(18px, 1.35vw, 24px);
  line-height: 1.38;
}

body.electronics-development-route .electronics-hero-copy .btn,
body.electronics-development-route .electronics-final-copy .btn {
  justify-self: start;
}

body.electronics-development-route .electronics-thesis {
  position: absolute;
  left: 5.5%;
  right: 5.5%;
  bottom: 5.4%;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(10px, 1.15vw, 16px);
}

body.electronics-development-route .electronics-thesis article,
body.electronics-development-route .electronics-card {
  border: 1px solid rgba(24, 125, 131, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 44px rgba(21, 58, 76, 0.12);
  backdrop-filter: blur(10px);
}

body.electronics-development-route .electronics-thesis article {
  padding: clamp(12px, 1.35vw, 20px);
}

body.electronics-development-route .electronics-thesis p {
  margin: 0;
  color: #203b46;
  font-size: clamp(14px, 1vw, 17px);
  font-weight: 720;
  line-height: 1.34;
}

body.electronics-development-route .electronics-slide--cards .electronics-frame {
  min-height: min(941px, calc(100svh - 76px));
  height: auto;
  aspect-ratio: auto;
}

body.electronics-development-route .electronics-card-layout {
  inset: 6% 5.5%;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: clamp(16px, 1.7vw, 24px);
}

body.electronics-development-route .electronics-section-head {
  display: grid;
  gap: 10px;
  max-width: 1060px;
}

body.electronics-development-route .electronics-section-head h2,
body.electronics-development-route .electronics-process-copy h2,
body.electronics-development-route .electronics-final-copy h2 {
  color: #0d2630;
  font-size: clamp(30px, 2.8vw, 52px);
  line-height: 1.04;
  letter-spacing: 0;
}

body.electronics-development-route .electronics-card-grid {
  display: grid;
  gap: clamp(14px, 1.35vw, 22px);
  align-items: stretch;
}

body.electronics-development-route .electronics-card-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.electronics-development-route .electronics-card-grid--six {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.electronics-development-route .electronics-card {
  min-width: 0;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr;
}

body.electronics-development-route .electronics-card-media {
  aspect-ratio: 1672 / 941;
  background: #eef5f7;
}

body.electronics-development-route .electronics-card-media img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
  filter: none;
  opacity: 1;
}

body.electronics-development-route .electronics-card-body {
  display: grid;
  gap: 10px;
  padding: clamp(14px, 1.35vw, 20px);
}

body.electronics-development-route .electronics-card h3 {
  margin: 0;
  color: #112c36;
  font-size: clamp(20px, 1.45vw, 28px);
  line-height: 1.08;
  letter-spacing: 0;
}

body.electronics-development-route .electronics-card p {
  margin: 0;
  color: #48616b;
  font-size: clamp(14px, 0.95vw, 16px);
  line-height: 1.44;
}

body.electronics-development-route .electronics-process-copy {
  left: 5.5%;
  top: 6.6%;
  width: 82%;
  display: grid;
  gap: 12px;
}

body.electronics-development-route .electronics-process-copy p {
  max-width: 900px;
  font-size: clamp(17px, 1.2vw, 21px);
  line-height: 1.42;
}

body.electronics-development-route .electronics-final-copy {
  left: 5.5%;
  top: 12%;
  width: min(760px, 52%);
  display: grid;
  gap: clamp(12px, 1.25vw, 18px);
}

body.electronics-development-route .electronics-helper {
  color: #187d83;
  font-weight: 700;
}

@media (max-width: 1180px) {
  body.electronics-development-route .electronics-card-grid--three,
  body.electronics-development-route .electronics-card-grid--six {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.electronics-development-route .electronics-hero-copy {
    width: 58%;
  }

  body.electronics-development-route .electronics-hero-copy h1 {
    font-size: clamp(36px, 4.5vw, 56px);
  }
}

@media (max-width: 780px) {
  body.electronics-development-route .electronics-slide {
    padding: 0 12px;
  }

  body.electronics-development-route .electronics-frame {
    width: min(100%, 560px);
  }

  body.electronics-development-route .electronics-hero .electronics-frame,
  body.electronics-development-route .electronics-process .electronics-frame,
  body.electronics-development-route .electronics-final .electronics-frame {
    min-height: calc(100svh - 69px);
    aspect-ratio: auto;
  }

  body.electronics-development-route .electronics-hero-copy {
    left: 5%;
    top: 4.2%;
    width: 90%;
    gap: 7px;
  }

  body.electronics-development-route .electronics-hero-copy h1 {
    max-width: 330px;
    font-size: clamp(30px, 9.2vw, 38px);
    line-height: 1;
  }

  body.electronics-development-route .electronics-hero-copy p {
    max-width: 340px;
    font-size: 13.5px;
    line-height: 1.28;
  }

  body.electronics-development-route .electronics-lead {
    font-size: 15px;
    line-height: 1.3;
  }

  body.electronics-development-route .electronics-hero-copy .btn {
    padding: 10px 14px;
    font-size: 13px;
  }

  body.electronics-development-route .electronics-thesis {
    left: 5%;
    right: 5%;
    bottom: 3.5%;
    grid-template-columns: 1fr;
    gap: 7px;
  }

  body.electronics-development-route .electronics-thesis article {
    padding: 9px 11px;
  }

  body.electronics-development-route .electronics-thesis p {
    font-size: 12.5px;
    line-height: 1.2;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-frame {
    width: min(100%, 560px);
    min-height: 0;
  }

  body.electronics-development-route .electronics-card-layout {
    position: relative;
    inset: auto;
    padding: 22px 12px;
    gap: 14px;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-bg {
    object-fit: fill;
  }

  body.electronics-development-route .electronics-section-head {
    gap: 7px;
  }

  body.electronics-development-route .electronics-section-head h2,
  body.electronics-development-route .electronics-process-copy h2,
  body.electronics-development-route .electronics-final-copy h2 {
    font-size: clamp(26px, 7.4vw, 34px);
  }

  body.electronics-development-route .electronics-section-head p,
  body.electronics-development-route .electronics-process-copy p,
  body.electronics-development-route .electronics-final-copy p {
    font-size: 14.5px;
    line-height: 1.36;
  }

  body.electronics-development-route .electronics-card-grid--three,
  body.electronics-development-route .electronics-card-grid--six {
    grid-template-columns: 1fr;
  }

  body.electronics-development-route .electronics-card-body {
    padding: 13px;
  }

  body.electronics-development-route .electronics-card h3 {
    font-size: 21px;
  }

  body.electronics-development-route .electronics-card p {
    font-size: 14px;
    line-height: 1.38;
  }

  body.electronics-development-route .electronics-process-copy {
    left: 5%;
    top: 4.5%;
    width: 90%;
  }

  body.electronics-development-route .electronics-final-copy {
    left: 5%;
    top: 10%;
    width: 90%;
  }

  body.electronics-development-route .electronics-final-copy .btn {
    justify-self: stretch;
    justify-content: center;
  }
}

@media (max-width: 420px) {
  body.electronics-development-route .electronics-hero-copy h1 {
    font-size: 29px;
  }

  body.electronics-development-route .electronics-hero-copy p {
    font-size: 12.5px;
  }

  body.electronics-development-route .electronics-lead {
    font-size: 13.5px;
  }

  body.electronics-development-route .electronics-thesis p {
    font-size: 11.5px;
  }
}

body.electronics-development-route .electronics-slide {
  width: min(100%, 1392px, calc(100svh * 1672 / 941));
  margin-inline: auto;
  padding-inline: 0;
  display: block;
  min-height: 0;
  overflow: visible;
}

body.electronics-development-route .electronics-slide:not(.electronics-slide--cards) {
  width: min(100%, 1392px, calc(100svh * 1672 / 941));
}

body.electronics-development-route .electronics-frame {
  width: 100%;
  min-height: 0;
  overflow: hidden;
}

body.electronics-development-route .electronics-slide--cards .electronics-frame {
  min-height: 0;
  aspect-ratio: auto;
}

body.electronics-development-route .electronics-slide--cards .electronics-card-layout {
  position: relative;
  inset: auto;
  padding: clamp(36px, 4.8vw, 68px) clamp(32px, 4.4vw, 62px);
}

body.electronics-development-route .electronics-slide--cards .electronics-bg {
  object-fit: fill;
}

@media (max-width: 780px) {
  body.electronics-development-route .electronics-slide {
    width: min(100%, 560px);
  }

  body.electronics-development-route .electronics-slide:not(.electronics-slide--cards) {
    width: min(100%, 560px);
  }

  body.electronics-development-route .electronics-slide--cards .electronics-card-layout {
    padding: 18px clamp(16px, 5vw, 24px);
    gap: 10px;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-section-head {
    gap: 5px;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-section-head h2 {
    font-size: clamp(23px, 6.4vw, 30px);
    line-height: 1.02;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-section-head p {
    font-size: 13.5px;
    line-height: 1.3;
  }
}

@media (max-width: 420px) {
body.electronics-development-route .electronics-slide,
  body.electronics-development-route .electronics-slide:not(.electronics-slide--cards) {
    width: 100%;
  }
}

/* Electronics full-width background override approved during Phase 3.
   Backgrounds fill the whole section width; content stays in a fixed inner column. */
body.electronics-development-route .electronics-slide,
body.electronics-development-route .electronics-slide:not(.electronics-slide--cards) {
  --electronics-fixed-column: min(calc(100% - 40px), 1392px);
  width: 100% !important;
  max-width: none !important;
  min-height: min(56.25vw, calc(100svh - 1px)) !important;
  display: grid !important;
  place-items: center !important;
  margin-inline: 0 !important;
  padding-inline: 0 !important;
  overflow: clip !important;
}

body.electronics-development-route .electronics-frame {
  width: 100% !important;
  max-width: none !important;
  min-height: inherit !important;
  aspect-ratio: auto !important;
  overflow: visible !important;
}

body.electronics-development-route .electronics-bg {
  width: 100% !important;
  height: 100% !important;
  object-fit: fill !important;
}

body.electronics-development-route .electronics-hero-copy {
  left: calc((100% - var(--electronics-fixed-column)) / 2 + var(--electronics-fixed-column) * 0.055) !important;
  width: min(calc(var(--electronics-fixed-column) * 0.52), 760px) !important;
}

body.electronics-development-route .electronics-process-copy {
  left: calc((100% - var(--electronics-fixed-column)) / 2 + var(--electronics-fixed-column) * 0.055) !important;
  width: min(calc(var(--electronics-fixed-column) * 0.82), 1140px) !important;
}

body.electronics-development-route .electronics-final-copy {
  left: calc((100% - var(--electronics-fixed-column)) / 2 + var(--electronics-fixed-column) * 0.055) !important;
  width: min(calc(var(--electronics-fixed-column) * 0.52), 760px) !important;
}

body.electronics-development-route .electronics-thesis-grid {
  position: absolute !important;
  right: calc((100% - var(--electronics-fixed-column)) / 2 + var(--electronics-fixed-column) * 0.053) !important;
  bottom: 5.4% !important;
  left: calc((100% - var(--electronics-fixed-column)) / 2 + var(--electronics-fixed-column) * 0.053) !important;
  z-index: 1 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(10px, 1vw, 16px) !important;
}

body.electronics-development-route .electronics-thesis {
  position: static !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  display: block !important;
  min-width: 0 !important;
  padding: clamp(13px, 1.25vw, 18px) !important;
  border: 1px solid rgba(31, 123, 255, 0.14) !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 14px 38px rgba(15, 55, 115, 0.08) !important;
  backdrop-filter: none !important;
}

body.electronics-development-route .electronics-thesis h3 {
  margin: 0 0 6px !important;
  color: #071b3a !important;
  font-size: clamp(15px, 1.08vw, 19px) !important;
  line-height: 1.14 !important;
}

body.electronics-development-route .electronics-thesis p {
  margin: 0 !important;
  color: #29405f !important;
  font-size: clamp(12px, 0.82vw, 14px) !important;
  font-weight: 400 !important;
  line-height: 1.35 !important;
}

body.electronics-development-route .electronics-slide--cards {
  min-height: auto !important;
  overflow: visible !important;
}

body.electronics-development-route .electronics-slide--cards .electronics-frame {
  min-height: 0 !important;
}

body.electronics-development-route .electronics-slide--cards .electronics-card-layout {
  width: var(--electronics-fixed-column) !important;
  margin-inline: auto !important;
}

@media (max-width: 820px) {
  body.electronics-development-route .electronics-slide,
  body.electronics-development-route .electronics-slide:not(.electronics-slide--cards) {
    --electronics-fixed-column: min(calc(100% - 28px), 560px);
    display: block !important;
    min-height: 0 !important;
    padding-inline: 0 !important;
    overflow: visible !important;
  }

  body.electronics-development-route .electronics-frame {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 34px 14px !important;
  }

  body.electronics-development-route .electronics-bg {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    aspect-ratio: auto !important;
    object-fit: fill !important;
  }

  body.electronics-development-route .electronics-hero-copy,
  body.electronics-development-route .electronics-process-copy,
  body.electronics-development-route .electronics-final-copy,
  body.electronics-development-route .electronics-card-layout {
    position: relative !important;
    inset: auto !important;
    z-index: 1 !important;
    width: 100% !important;
    max-width: none !important;
  }

  body.electronics-development-route .electronics-hero-copy,
  body.electronics-development-route .electronics-process-copy,
  body.electronics-development-route .electronics-final-copy {
    order: 1 !important;
    display: grid !important;
    gap: 10px !important;
  }

  body.electronics-development-route .electronics-thesis-grid {
    position: relative !important;
    inset: auto !important;
    order: 3 !important;
    grid-template-columns: 1fr !important;
  }

  body.electronics-development-route .electronics-slide--cards .electronics-card-layout {
    width: 100% !important;
  }

  body.electronics-development-route .electronics-process {
    min-height: calc(100svh - 1px) !important;
  }
}

body.software-development-route {
  background: #f6f8fb;
  color: #132235;
}

body.software-development-route .generated-page {
  background: #f6f8fb;
}

body.software-development-route .software-development-page {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2.4vw, 34px);
  padding: clamp(16px, 2.4vw, 32px) 0 clamp(26px, 3vw, 48px);
}

body.software-development-route .btn.btn-primary {
  background: #0b5fb3;
  border-color: #0b5fb3;
  color: #ffffff;
}

body.software-development-route .btn.btn-primary:hover {
  background: #084f96;
  border-color: #084f96;
}

body.software-development-route .software-slide {
  width: min(100%, 1392px, calc(100svh * 1672 / 941));
  margin-inline: auto;
  padding-inline: 0;
}

body.software-development-route .software-frame {
  position: relative;
  width: 100%;
  min-height: 0;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  border-radius: 24px;
  background: #ffffff;
  box-shadow: 0 24px 70px rgba(29, 61, 89, 0.13);
  isolation: isolate;
}

body.software-development-route .software-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
}

body.software-development-route .software-copy,
body.software-development-route .software-card-layout,
body.software-development-route .software-process-list,
body.software-development-route .software-final-actions {
  position: relative;
  z-index: 1;
}

body.software-development-route .software-copy {
  display: grid;
  gap: clamp(10px, 1vw, 16px);
  width: min(44%, 610px);
  color: #172437;
}

body.software-development-route .software-copy h1,
body.software-development-route .software-copy h2,
body.software-development-route .software-section-head h2 {
  margin: 0;
  color: #0f1d2d;
  letter-spacing: 0;
  line-height: 1.02;
}

body.software-development-route .software-copy h1 {
  font-size: clamp(43px, 4.7vw, 74px);
}

body.software-development-route .software-copy h2,
body.software-development-route .software-section-head h2 {
  font-size: clamp(36px, 3.6vw, 58px);
}

body.software-development-route .software-copy p,
body.software-development-route .software-section-head p,
body.software-development-route .software-card p,
body.software-development-route .software-process-list p,
body.software-development-route .software-final-actions p {
  margin: 0;
  color: #37516b;
  letter-spacing: 0;
  line-height: 1.45;
  word-break: normal;
  overflow-wrap: normal;
  hyphens: manual;
}

body.software-development-route .software-copy p {
  font-size: clamp(15px, 1.18vw, 19px);
}

body.software-development-route .software-lead {
  color: #1f3954;
  font-size: clamp(17px, 1.35vw, 22px);
  font-weight: 650;
}

body.software-development-route .software-copy .btn {
  width: max-content;
  margin-top: 4px;
}

body.software-development-route .software-hero-copy {
  position: absolute;
  left: 5.4%;
  top: 10%;
  width: min(41.8%, 580px);
}

body.software-development-route .software-process-copy {
  position: absolute;
  left: 5.4%;
  top: 7.2%;
  right: 5.4%;
  width: auto;
}

body.software-development-route .software-proof-copy {
  position: absolute;
  left: 5.4%;
  top: 7%;
  width: min(42%, 590px);
}

body.software-development-route .software-final-copy {
  position: absolute;
  left: 5.4%;
  top: 7.2%;
  right: 5.4%;
  width: auto;
}

body.software-development-route .software-final-actions {
  position: absolute;
  left: 5.4%;
  bottom: 7%;
  z-index: 1;
  display: grid;
  gap: 14px;
  width: min(48%, 680px);
}

body.software-development-route .software-final-actions .btn {
  width: max-content;
}

body.software-development-route .software-process-copy h2,
body.software-development-route .software-final-copy h2 {
  max-width: 100%;
}

body.software-development-route .software-process-text {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 28px);
  width: 100%;
}

body.software-development-route .software-process-text p,
body.software-development-route .software-final-actions p {
  font-size: clamp(15px, 1.12vw, 18px);
}

body.software-development-route .software-slide--cards {
  width: min(100%, 1392px);
}

body.software-development-route .software-slide--cards .software-frame {
  aspect-ratio: auto;
}

body.software-development-route .software-card-layout {
  display: grid;
  gap: clamp(22px, 2.7vw, 38px);
  padding: clamp(36px, 4.8vw, 68px) clamp(32px, 4.4vw, 62px);
}

body.software-development-route .software-section-head {
  display: grid;
  gap: 10px;
  width: min(760px, 100%);
}

body.software-development-route .software-section-head p {
  max-width: 720px;
  font-size: clamp(15px, 1.12vw, 18px);
}

body.software-development-route .software-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.7vw, 24px);
}

body.software-development-route .software-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(69, 109, 139, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 34px rgba(32, 72, 99, 0.09);
}

body.software-development-route .software-card-media {
  display: block;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  background: #eef5f8;
}

body.software-development-route .software-card-media img {
  display: block;
  width: 100%;
  height: auto;
}

body.software-development-route .software-card-body {
  display: grid;
  gap: 8px;
  padding: clamp(15px, 1.55vw, 22px);
}

body.software-development-route .software-card h3 {
  margin: 0;
  color: #10253a;
  font-size: clamp(20px, 1.45vw, 25px);
  line-height: 1.08;
  letter-spacing: 0;
}

body.software-development-route .software-card p {
  font-size: clamp(13.5px, 1vw, 16px);
}

body.software-development-route .software-process-list {
  position: absolute;
  left: 5.4%;
  right: 5.4%;
  bottom: 6%;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.software-development-route .software-process-list li {
  display: grid;
  gap: 7px;
  min-height: 168px;
  padding: 15px 14px;
  border: 1px solid rgba(70, 117, 146, 0.17);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 10px 30px rgba(31, 75, 98, 0.09);
}

body.software-development-route .software-process-list span {
  color: #1f8a93;
  font-size: 13px;
  font-weight: 800;
}

body.software-development-route .software-process-list strong {
  color: #13283c;
  font-size: 16px;
  line-height: 1.12;
}

body.software-development-route .software-process-list p {
  font-size: 12.5px;
  line-height: 1.32;
}

body.software-development-route .software-bullets,
body.software-development-route .software-topic-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.software-development-route .software-bullets li,
body.software-development-route .software-topic-list li {
  color: #24415b;
  line-height: 1.28;
}

body.software-development-route .software-bullets li {
  padding-left: 18px;
  position: relative;
}

body.software-development-route .software-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #20a2a4;
}

body.software-development-route .software-topic-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

body.software-development-route .software-topic-list li {
  padding: 9px 11px;
  border: 1px solid rgba(48, 110, 139, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  font-size: 14px;
  font-weight: 650;
}

@media (max-width: 1180px) {
  body.software-development-route .software-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.software-development-route .software-process-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.software-development-route .software-process-list li {
    min-height: 132px;
  }

  body.software-development-route .software-hero-copy {
    width: min(53.2%, 618px);
  }

  body.software-development-route .software-proof-copy {
    width: min(51%, 610px);
  }

  body.software-development-route .software-process-copy,
  body.software-development-route .software-final-copy {
    right: 5.4%;
    width: auto;
  }

  body.software-development-route .software-final-actions {
    width: min(54%, 700px);
  }
}

@media (max-width: 780px) {
  body.software-development-route .software-development-page {
    gap: 14px;
    padding-top: 12px;
  }

  body.software-development-route .software-slide,
  body.software-development-route .software-slide:not(.software-slide--cards) {
    width: min(100%, 560px);
  }

  body.software-development-route .software-frame {
    border-radius: 18px;
  }

  body.software-development-route .software-hero .software-frame,
  body.software-development-route .software-process .software-frame,
  body.software-development-route .software-proof .software-frame,
  body.software-development-route .software-final .software-frame {
    min-height: calc(100svh - 70px);
    aspect-ratio: auto;
  }

  body.software-development-route .software-hero-copy,
  body.software-development-route .software-process-copy,
  body.software-development-route .software-proof-copy,
  body.software-development-route .software-final-copy {
    left: 5%;
    top: 4.5%;
    width: 90%;
  }

  body.software-development-route .software-process-copy,
  body.software-development-route .software-final-copy {
    right: auto;
  }

  body.software-development-route .software-process-text {
    grid-template-columns: 1fr;
    width: min(100%, 360px);
    gap: 7px;
  }

  body.software-development-route .software-final-actions {
    left: 5%;
    right: 5%;
    bottom: 4%;
    width: auto;
    gap: 8px;
  }

  body.software-development-route .software-copy h1 {
    max-width: 350px;
    font-size: clamp(30px, 8.8vw, 38px);
  }

  body.software-development-route .software-copy h2,
  body.software-development-route .software-section-head h2 {
    font-size: clamp(26px, 7.3vw, 34px);
  }

  body.software-development-route .software-copy p,
  body.software-development-route .software-section-head p {
    max-width: 360px;
    font-size: 14px;
    line-height: 1.34;
  }

  body.software-development-route .software-lead {
    font-size: 15px;
  }

  body.software-development-route .software-copy .btn {
    justify-self: stretch;
    justify-content: center;
    width: auto;
    padding: 10px 14px;
    font-size: 13px;
  }

  body.software-development-route .software-final-actions .btn {
    width: auto;
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
  }

  body.software-development-route .software-card-layout {
    padding: 28px clamp(16px, 5vw, 28px);
  }

  body.software-development-route .software-card-grid {
    grid-template-columns: 1fr;
  }

  body.software-development-route .software-card-body {
    padding: 13px;
  }

  body.software-development-route .software-card h3 {
    font-size: 21px;
  }

  body.software-development-route .software-card p {
    font-size: 14px;
    line-height: 1.38;
  }

  body.software-development-route .software-process-list {
    left: 5%;
    right: 5%;
    bottom: 4%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  body.software-development-route .software-process-list li {
    min-height: 0;
    padding: 9px 10px;
  }

  body.software-development-route .software-process-list strong {
    font-size: 13px;
  }

  body.software-development-route .software-process-list p {
    font-size: 11px;
    line-height: 1.2;
  }

  body.software-development-route .software-bullets {
    gap: 6px;
  }

  body.software-development-route .software-bullets li,
  body.software-development-route .software-topic-list li {
    font-size: 12.5px;
  }
}

@media (max-width: 420px) {
  body.software-development-route .software-slide,
  body.software-development-route .software-slide:not(.software-slide--cards) {
    width: 100%;
  }

  body.software-development-route .software-copy h1 {
    font-size: 29px;
  }

  body.software-development-route .software-copy p {
    font-size: 12.5px;
  }

  body.software-development-route .software-process-list p {
    display: none;
  }
}

/* MQTT Broker product workflow. Source of truth:
   specs/product-plans/mqtt-broker-wireframe-plan-2026-06-02.md */
body.mqtt-broker-route {
  background: #f7fbff;
}

body.mqtt-broker-route .btn.btn-primary {
  background: #0a67b7;
  border-color: #0a67b7;
  color: #ffffff;
}

body.mqtt-broker-route .btn.btn-primary:hover {
  background: #075596;
  border-color: #075596;
}

body.mqtt-broker-route :where(h1,h2,h3,p,li,a,button,span,label,strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.mqtt-broker-route .mqtt-slide {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  min-height: max(760px, calc((100vw - 15px) * 941 / 1672));
  background: #f7fbff;
  color: #142437;
}

body.mqtt-broker-route .mqtt-bg {
  position: absolute;
  inset: 0 auto auto 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
  pointer-events: none;
}

body.mqtt-broker-route .mqtt-slide--cards .mqtt-bg {
  inset: 0;
  height: 100%;
  object-fit: cover;
}

body.mqtt-broker-route .mqtt-inner {
  position: relative;
  z-index: 1;
  min-height: inherit;
}

body.mqtt-broker-route .mqtt-copy,
body.mqtt-broker-route .mqtt-section-head {
  display: grid;
  gap: clamp(12px, 1.4vw, 20px);
  color: #142437;
}

body.mqtt-broker-route .mqtt-copy h1,
body.mqtt-broker-route .mqtt-copy h2,
body.mqtt-broker-route .mqtt-section-head h2 {
  margin: 0;
  color: #0d1f31;
  line-height: 1.03;
}

body.mqtt-broker-route .mqtt-copy h1 {
  max-width: 780px;
  font-size: clamp(43px, 5.1vw, 78px);
}

body.mqtt-broker-route .mqtt-copy h2,
body.mqtt-broker-route .mqtt-section-head h2 {
  max-width: 900px;
  font-size: clamp(34px, 3.8vw, 58px);
}

body.mqtt-broker-route .mqtt-copy p,
body.mqtt-broker-route .mqtt-section-head p,
body.mqtt-broker-route .mqtt-card p,
body.mqtt-broker-route .mqtt-process-list p,
body.mqtt-broker-route .mqtt-final-points span {
  margin: 0;
  color: #3f5871;
  line-height: 1.45;
}

body.mqtt-broker-route .mqtt-copy p {
  max-width: 680px;
  font-size: clamp(15px, 1.2vw, 19px);
}

body.mqtt-broker-route .mqtt-lead {
  color: #203b56;
  font-size: clamp(17px, 1.4vw, 22px);
  font-weight: 650;
}

body.mqtt-broker-route .mqtt-kicker {
  margin: 0;
  color: #0d7e8a;
  font-size: 13px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.mqtt-broker-route .mqtt-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 6px;
}

body.mqtt-broker-route .mqtt-hero-inner,
body.mqtt-broker-route .mqtt-security-inner,
body.mqtt-broker-route .mqtt-final-inner {
  display: grid;
  align-items: center;
  padding-block: clamp(70px, 7vw, 112px);
}

body.mqtt-broker-route .mqtt-hero-copy {
  width: min(58%, 780px);
}

body.mqtt-broker-route .mqtt-summary {
  position: absolute;
  right: 0;
  bottom: clamp(44px, 5vw, 72px);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  width: min(560px, 44%);
}

body.mqtt-broker-route .mqtt-summary p,
body.mqtt-broker-route .mqtt-final-points p {
  margin: 0;
  border: 1px solid rgba(51, 117, 148, 0.18);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 12px 34px rgba(32, 72, 99, 0.08);
}

body.mqtt-broker-route .mqtt-summary p {
  padding: 14px 15px;
  color: #12304b;
  font-size: 14px;
  font-weight: 760;
  line-height: 1.18;
}

body.mqtt-broker-route .mqtt-slide--cards {
  min-height: auto;
}

body.mqtt-broker-route .mqtt-card-layout {
  position: relative;
  z-index: 1;
  display: grid;
  gap: clamp(24px, 3vw, 42px);
  padding-block: clamp(62px, 7vw, 96px);
}

body.mqtt-broker-route .mqtt-section-head {
  width: min(860px, 100%);
}

body.mqtt-broker-route .mqtt-section-head p {
  max-width: 780px;
  font-size: clamp(15px, 1.15vw, 18px);
}

body.mqtt-broker-route .mqtt-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(14px, 1.5vw, 22px);
}

body.mqtt-broker-route .mqtt-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(54, 114, 145, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 34px rgba(33, 79, 106, 0.09);
}

body.mqtt-broker-route .mqtt-card-media {
  display: block;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  background: #eef6fb;
}

body.mqtt-broker-route .mqtt-card-media img {
  display: block;
  width: 100%;
  height: auto;
}

body.mqtt-broker-route .mqtt-card-body {
  display: grid;
  gap: 8px;
  padding: clamp(14px, 1.45vw, 20px);
}

body.mqtt-broker-route .mqtt-card h3 {
  margin: 0;
  color: #10263c;
  font-size: clamp(19px, 1.35vw, 24px);
  line-height: 1.1;
}

body.mqtt-broker-route .mqtt-card p {
  font-size: clamp(13.5px, 0.98vw, 16px);
}

body.mqtt-broker-route .mqtt-process-inner {
  display: grid;
  align-content: space-between;
  padding-block: clamp(56px, 6.4vw, 88px);
}

body.mqtt-broker-route .mqtt-process-copy {
  width: min(820px, 70%);
}

body.mqtt-broker-route .mqtt-process-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin: clamp(48px, 6vw, 76px) 0 0;
  padding: 0;
  list-style: none;
}

body.mqtt-broker-route .mqtt-process-list li {
  display: grid;
  gap: 7px;
  min-height: 150px;
  padding: 15px 14px;
  border: 1px solid rgba(60, 118, 148, 0.17);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 10px 28px rgba(31, 75, 98, 0.08);
}

body.mqtt-broker-route .mqtt-process-list span {
  color: #0b8990;
  font-size: 13px;
  font-weight: 830;
}

body.mqtt-broker-route .mqtt-process-list strong {
  color: #112a42;
  font-size: 16px;
  line-height: 1.12;
}

body.mqtt-broker-route .mqtt-process-list p {
  font-size: 12.7px;
  line-height: 1.32;
}

body.mqtt-broker-route .mqtt-security-copy {
  width: min(52%, 720px);
  margin-left: auto;
}

body.mqtt-broker-route .mqtt-bullets {
  display: grid;
  gap: 9px;
  margin: 2px 0 0;
  padding: 0;
  list-style: none;
}

body.mqtt-broker-route .mqtt-bullets li {
  position: relative;
  padding-left: 19px;
  color: #24415b;
  font-size: clamp(14px, 1.06vw, 17px);
  line-height: 1.32;
}

body.mqtt-broker-route .mqtt-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #18a5a8;
}

body.mqtt-broker-route .mqtt-webhook-list li {
  min-height: 128px;
}

body.mqtt-broker-route .mqtt-final-copy {
  width: min(58%, 800px);
}

body.mqtt-broker-route .mqtt-final-points {
  position: absolute;
  right: 0;
  bottom: clamp(48px, 5.3vw, 80px);
  display: grid;
  gap: 10px;
  width: min(440px, 36%);
}

body.mqtt-broker-route .mqtt-final-points p {
  display: grid;
  gap: 5px;
  padding: 15px 16px;
}

body.mqtt-broker-route .mqtt-final-points strong {
  color: #10263c;
  font-size: 15px;
}

body.mqtt-broker-route .mqtt-final-points span {
  font-size: 13.5px;
  line-height: 1.32;
}

@media (max-width: 1180px) {
  body.mqtt-broker-route .mqtt-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.mqtt-broker-route .mqtt-process-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body.mqtt-broker-route .mqtt-process-list li {
    min-height: 128px;
  }

  body.mqtt-broker-route .mqtt-hero-copy,
  body.mqtt-broker-route .mqtt-security-copy,
  body.mqtt-broker-route .mqtt-final-copy {
    width: min(66%, 760px);
  }

  body.mqtt-broker-route .mqtt-summary,
  body.mqtt-broker-route .mqtt-final-points {
    width: min(420px, 38%);
  }
}

@media (max-height: 820px) and (min-width: 781px) {
  body.mqtt-broker-route .mqtt-hero-inner,
  body.mqtt-broker-route .mqtt-security-inner,
  body.mqtt-broker-route .mqtt-final-inner,
  body.mqtt-broker-route .mqtt-process-inner {
    padding-block: 48px;
  }

  body.mqtt-broker-route .mqtt-copy h1 {
    font-size: clamp(40px, 4.4vw, 64px);
  }

  body.mqtt-broker-route .mqtt-copy h2,
  body.mqtt-broker-route .mqtt-section-head h2 {
    font-size: clamp(32px, 3.2vw, 50px);
  }

  body.mqtt-broker-route .mqtt-process-list {
    margin-top: 30px;
  }

  body.mqtt-broker-route .mqtt-process-list li,
  body.mqtt-broker-route .mqtt-webhook-list li {
    min-height: 118px;
    padding: 12px;
  }

  body.mqtt-broker-route .mqtt-process-list p {
    font-size: 12px;
    line-height: 1.24;
  }
}

@media (max-width: 780px) {
  body.mqtt-broker-route .mqtt-slide {
    min-height: calc(100svh - 70px);
  }

  body.mqtt-broker-route .mqtt-bg {
    inset: 0;
    height: 100%;
    object-fit: cover;
  }

  body.mqtt-broker-route .mqtt-slide--cards {
    min-height: auto;
  }

  body.mqtt-broker-route .mqtt-hero-inner,
  body.mqtt-broker-route .mqtt-security-inner,
  body.mqtt-broker-route .mqtt-final-inner,
  body.mqtt-broker-route .mqtt-process-inner {
    min-height: inherit;
    padding-block: 30px;
  }

  body.mqtt-broker-route .mqtt-card-layout {
    padding-block: 34px;
  }

  body.mqtt-broker-route .mqtt-hero-copy,
  body.mqtt-broker-route .mqtt-security-copy,
  body.mqtt-broker-route .mqtt-final-copy,
  body.mqtt-broker-route .mqtt-process-copy {
    width: min(100%, 420px);
  }

  body.mqtt-broker-route .mqtt-copy h1 {
    max-width: 380px;
    font-size: clamp(31px, 8.5vw, 39px);
  }

  body.mqtt-broker-route .mqtt-copy h2,
  body.mqtt-broker-route .mqtt-section-head h2 {
    font-size: clamp(26px, 7.2vw, 34px);
  }

  body.mqtt-broker-route .mqtt-copy p,
  body.mqtt-broker-route .mqtt-section-head p {
    max-width: 390px;
    font-size: 14px;
    line-height: 1.34;
  }

  body.mqtt-broker-route .mqtt-lead {
    font-size: 15px;
  }

  body.mqtt-broker-route .mqtt-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: min(100%, 340px);
  }

  body.mqtt-broker-route .mqtt-actions .btn {
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
  }

  body.mqtt-broker-route .mqtt-summary,
  body.mqtt-broker-route .mqtt-final-points {
    position: relative;
    right: auto;
    bottom: auto;
    grid-template-columns: 1fr;
    width: min(100%, 380px);
    margin-top: 20px;
  }

  body.mqtt-broker-route .mqtt-summary p {
    padding: 10px 12px;
    font-size: 13px;
  }

  body.mqtt-broker-route .mqtt-card-grid {
    grid-template-columns: 1fr;
  }

  body.mqtt-broker-route .mqtt-card-body {
    padding: 13px;
  }

  body.mqtt-broker-route .mqtt-card h3 {
    font-size: 21px;
  }

  body.mqtt-broker-route .mqtt-card p {
    font-size: 14px;
    line-height: 1.38;
  }

  body.mqtt-broker-route .mqtt-process-list {
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 18px;
  }

  body.mqtt-broker-route .mqtt-process-list li,
  body.mqtt-broker-route .mqtt-webhook-list li {
    min-height: 0;
    padding: 10px 11px;
  }

  body.mqtt-broker-route .mqtt-process-list strong {
    font-size: 14px;
  }

  body.mqtt-broker-route .mqtt-process-list p {
    font-size: 12px;
    line-height: 1.25;
  }

  body.mqtt-broker-route .mqtt-bullets li {
    font-size: 13px;
  }
}

@media (max-width: 420px) {
  body.mqtt-broker-route .mqtt-copy h1 {
    font-size: 30px;
  }

  body.mqtt-broker-route .mqtt-copy p,
  body.mqtt-broker-route .mqtt-section-head p {
    font-size: 12.8px;
  }

  body.mqtt-broker-route .mqtt-kicker {
    font-size: 11.5px;
  }
}

/* Go!Mer product workflow. Source of truth:
   .artifacts/product-plans/gomer/gomer-wireframe-plan-2026-06-02.md */
body.gomer-route {
  background: #f7fbff;
}

body.gomer-route .btn.btn-primary {
  background: #118dcb;
  border-color: #118dcb;
  color: #ffffff;
}

body.gomer-route .btn.btn-primary:hover {
  background: #0c74aa;
  border-color: #0c74aa;
}

body.gomer-route :where(h1,h2,h3,p,li,a,button,span,label,strong,dt,dd) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.gomer-route .gomer-slide {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  min-height: max(760px, calc((100vw - 15px) * 992 / 1586));
  background: #f7fbff;
  color: #162737;
}

/* PowerTracker Phase 3 integration */
body.powertracker-route {
  background: #f7fbff;
}

body.powertracker-route .btn.btn-primary {
  background: #0a67b7;
  border-color: #0a67b7;
  color: #ffffff;
}

body.powertracker-route .btn.btn-primary:hover {
  background: #075596;
  border-color: #075596;
}

body.powertracker-route :where(h1,h2,h3,p,li,a,button,span,strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.powertracker-route .powertracker-slide {
  position: relative;
  isolation: isolate;
  box-sizing: border-box;
  overflow: hidden;
  width: 100%;
  min-height: clamp(640px, calc(100vh - 77px), 760px);
  background: #f7fbff;
  color: #142437;
}

body.powertracker-route .powertracker-bg {
  position: absolute;
  inset: 0 auto auto 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  object-position: center;
  pointer-events: none;
}

body.powertracker-route .powertracker-slide--cards {
  min-height: auto;
}

body.powertracker-route .powertracker-slide--cards .powertracker-bg {
  inset: 0;
  height: 100%;
  object-fit: fill;
}

body.powertracker-route .powertracker-inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  min-height: inherit;
  display: grid;
  align-items: center;
  padding-block: clamp(64px, 7vw, 108px);
}

body.powertracker-route .powertracker-copy,
body.powertracker-route .powertracker-section-head {
  display: grid;
  gap: clamp(12px, 1.35vw, 20px);
  color: #142437;
}

body.powertracker-route .powertracker-copy h1,
body.powertracker-route .powertracker-copy h2,
body.powertracker-route .powertracker-section-head h2 {
  margin: 0;
  color: #0d1f31;
  line-height: 1.04;
}

body.powertracker-route .powertracker-copy h1 {
  max-width: 800px;
  font-size: clamp(42px, 4.7vw, 72px);
}

body.powertracker-route .powertracker-copy h2,
body.powertracker-route .powertracker-section-head h2 {
  max-width: 900px;
  font-size: clamp(34px, 3.7vw, 58px);
}

body.powertracker-route .powertracker-copy p,
body.powertracker-route .powertracker-section-head p,
body.powertracker-route .powertracker-card p,
body.powertracker-route .powertracker-list li,
body.powertracker-route .powertracker-section-note {
  margin: 0;
  color: #3f5871;
  line-height: 1.45;
}

body.powertracker-route .powertracker-copy p {
  max-width: 680px;
  font-size: clamp(15px, 1.14vw, 19px);
}

body.powertracker-route .powertracker-lead {
  color: #203b56;
  font-size: clamp(17px, 1.35vw, 22px);
  font-weight: 680;
}

body.powertracker-route .powertracker-audience {
  color: #10263c;
  font-weight: 720;
}

body.powertracker-route .powertracker-kicker {
  margin: 0;
  color: #0d7e8a;
  font-size: 13px;
  font-weight: 820;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.powertracker-route .powertracker-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 6px;
}

body.powertracker-route .powertracker-copy--left {
  width: min(58%, 790px);
}

body.powertracker-route .powertracker-copy--right {
  width: min(57%, 760px);
  margin-left: auto;
}

body.powertracker-route .powertracker-card-layout {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  display: grid;
  gap: clamp(24px, 3vw, 42px);
  padding-block: clamp(62px, 7vw, 96px);
  padding-inline: clamp(24px, 4vw, 72px);
}

body.powertracker-route .powertracker-section-head {
  width: min(900px, 100%);
}

body.powertracker-route .powertracker-section-head p {
  max-width: 790px;
  font-size: clamp(15px, 1.15vw, 18px);
}

body.powertracker-route .powertracker-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(14px, 1.5vw, 22px);
}

body.powertracker-route .powertracker-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(54, 114, 145, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 14px 34px rgba(33, 79, 106, 0.09);
}

body.powertracker-route .powertracker-card-media {
  display: block;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  background: #eef6fb;
}

body.powertracker-route .powertracker-card-media img {
  display: block;
  width: 100%;
  height: auto;
}

body.powertracker-route .powertracker-card-body {
  display: grid;
  gap: 8px;
  padding: clamp(14px, 1.45vw, 20px);
}

body.powertracker-route .powertracker-card h3 {
  margin: 0;
  color: #10263c;
  font-size: clamp(19px, 1.35vw, 24px);
  line-height: 1.1;
}

body.powertracker-route .powertracker-card p {
  font-size: clamp(13.5px, 0.98vw, 16px);
}

body.powertracker-route .powertracker-list {
  display: grid;
  gap: 9px;
  margin: 2px 0 0;
  padding: 0;
  list-style: none;
}

body.powertracker-route .powertracker-list li {
  position: relative;
  padding-left: 19px;
  font-size: clamp(14px, 1.04vw, 17px);
  line-height: 1.35;
}

body.powertracker-route .powertracker-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.56em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #18a5a8;
}

body.powertracker-route .powertracker-section-note {
  width: min(720px, 100%);
  font-size: clamp(14px, 1.05vw, 17px);
  font-weight: 650;
}

body.powertracker-route .powertracker-final-copy {
  width: min(62%, 820px);
}

@media (max-width: 1180px) {
  body.powertracker-route .powertracker-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.powertracker-route .powertracker-copy--left,
  body.powertracker-route .powertracker-copy--right,
  body.powertracker-route .powertracker-final-copy {
    width: min(66%, 760px);
  }
}

@media (max-height: 820px) and (min-width: 781px) {
  body.powertracker-route .powertracker-inner {
    padding-block: 46px;
  }

  body.powertracker-route .powertracker-copy h1 {
    font-size: clamp(38px, 4.1vw, 62px);
  }

  body.powertracker-route .powertracker-copy h2,
  body.powertracker-route .powertracker-section-head h2 {
    font-size: clamp(31px, 3.1vw, 48px);
  }

  body.powertracker-route .powertracker-copy {
    gap: 11px;
  }

  body.powertracker-route .powertracker-list {
    gap: 6px;
  }
}

@media (max-width: 780px) {
  body.powertracker-route .powertracker-slide {
    min-height: auto;
    background: #f7fbff;
  }

  body.powertracker-route .powertracker-inner,
  body.powertracker-route .powertracker-card-layout {
    min-height: auto;
    padding-block: 34px;
    padding-inline: 20px;
  }

  body.powertracker-route .powertracker-copy--left,
  body.powertracker-route .powertracker-copy--right,
  body.powertracker-route .powertracker-final-copy {
    width: min(100%, 430px);
    margin-left: 0;
  }

  body.powertracker-route .powertracker-copy h1 {
    max-width: 390px;
    font-size: clamp(31px, 8.4vw, 39px);
  }

  body.powertracker-route .powertracker-copy h2,
  body.powertracker-route .powertracker-section-head h2 {
    font-size: clamp(27px, 7vw, 34px);
  }

  body.powertracker-route .powertracker-actions {
    align-items: stretch;
    flex-direction: column;
  }

  body.powertracker-route .powertracker-actions .btn {
    width: 100%;
    justify-content: center;
  }

  body.powertracker-route .powertracker-card-grid {
    grid-template-columns: 1fr;
  }

  body.powertracker-route .powertracker-card-media img {
    width: 100%;
    height: auto;
  }
}

body.gomer-route .gomer-bg {
  position: absolute;
  inset: 0 auto auto 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center top;
  pointer-events: none;
}

body.gomer-route .gomer-slide--cards {
  min-height: auto;
}

body.gomer-route .gomer-slide--cards .gomer-bg {
  inset: 0;
  height: 100%;
  object-fit: contain;
}

body.gomer-route .gomer-inner {
  position: relative;
  z-index: 1;
  min-height: inherit;
}

body.gomer-route .gomer-copy,
body.gomer-route .gomer-section-head {
  display: grid;
  gap: clamp(12px, 1.35vw, 20px);
  color: #162737;
}

body.gomer-route .gomer-copy h1,
body.gomer-route .gomer-copy h2,
body.gomer-route .gomer-section-head h2 {
  margin: 0;
  color: #10202e;
  line-height: 1.03;
}

body.gomer-route .gomer-copy h1 {
  max-width: 780px;
  font-size: clamp(42px, 5vw, 76px);
}

body.gomer-route .gomer-copy h2,
body.gomer-route .gomer-section-head h2 {
  max-width: 900px;
  font-size: clamp(34px, 3.75vw, 58px);
}

body.gomer-route .gomer-copy p,
body.gomer-route .gomer-section-head p,
body.gomer-route .gomer-card p,
body.gomer-route .gomer-spec-list dd,
body.gomer-route .gomer-spec-list dt,
body.gomer-route .gomer-bullets li {
  margin: 0;
  color: #42596c;
  line-height: 1.45;
}

body.gomer-route .gomer-copy p {
  max-width: 675px;
  font-size: clamp(15px, 1.15vw, 19px);
}

body.gomer-route .gomer-lead,
body.gomer-route .gomer-audience,
body.gomer-route .gomer-result {
  color: #203a50;
  font-weight: 680;
}

body.gomer-route .gomer-lead {
  font-size: clamp(17px, 1.35vw, 22px);
}

body.gomer-route .gomer-kicker {
  margin: 0;
  color: #0b8e9d;
  font-size: 13px;
  font-weight: 820;
  text-transform: uppercase;
}

body.gomer-route .gomer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 6px;
}

body.gomer-route .gomer-hero-inner,
body.gomer-route .gomer-need-inner,
body.gomer-route .gomer-install-inner {
  display: grid;
  align-items: center;
  padding-block: clamp(64px, 6.8vw, 108px);
}

body.gomer-route .gomer-hero-copy,
body.gomer-route .gomer-install-copy {
  width: min(56%, 760px);
}

body.gomer-route .gomer-need-copy {
  width: min(52%, 730px);
  margin-left: auto;
}

body.gomer-route .gomer-operation-inner {
  display: grid;
  align-content: start;
  padding-block: clamp(54px, 6vw, 86px);
}

body.gomer-route .gomer-operation-copy {
  width: min(820px, 70%);
}

body.gomer-route .gomer-operation-bottom {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 1px;
  height: 1px;
  overflow: hidden;
  pointer-events: none;
}

body.gomer-route .gomer-bullets {
  display: grid;
  gap: 9px;
  margin: 2px 0 0;
  padding: 0;
  list-style: none;
}

body.gomer-route .gomer-bullets li {
  position: relative;
  padding-left: 20px;
  font-size: clamp(14px, 1.05vw, 17px);
  line-height: 1.33;
}

body.gomer-route .gomer-bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #19a0a8;
}

body.gomer-route .gomer-card-layout {
  position: relative;
  z-index: 1;
  display: grid;
  gap: clamp(24px, 3vw, 42px);
  padding-block: clamp(58px, 6.7vw, 94px);
}

body.gomer-route .gomer-section-head {
  width: min(880px, 100%);
}

body.gomer-route .gomer-section-head p {
  max-width: 760px;
  font-size: clamp(15px, 1.13vw, 18px);
}

body.gomer-route .gomer-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(14px, 1.45vw, 22px);
}

body.gomer-route .gomer-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(49, 112, 134, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 14px 34px rgba(28, 76, 94, 0.09);
}

body.gomer-route .gomer-card-media {
  display: block;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  background: #edf7fa;
}

body.gomer-route .gomer-card-media img {
  display: block;
  width: 100%;
  height: auto;
}

body.gomer-route .gomer-card-body {
  display: grid;
  gap: 8px;
  padding: clamp(14px, 1.45vw, 20px);
}

body.gomer-route .gomer-card h3 {
  margin: 0;
  color: #102431;
  font-size: clamp(19px, 1.3vw, 24px);
  line-height: 1.1;
}

body.gomer-route .gomer-card p {
  font-size: clamp(13.5px, 0.96vw, 16px);
}

body.gomer-route .gomer-spec-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 10px;
  margin: 2px 0 0;
}

body.gomer-route .gomer-spec-list div {
  display: grid;
  gap: 3px;
  padding: 12px 13px;
  border: 1px solid rgba(35, 120, 146, 0.15);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.74);
}

body.gomer-route .gomer-spec-list dt {
  color: #0f6f88;
  font-size: 12px;
  font-weight: 820;
  text-transform: uppercase;
}

body.gomer-route .gomer-spec-list dd {
  font-size: 14px;
  font-weight: 670;
}

@media (max-width: 1180px) {
  body.gomer-route .gomer-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.gomer-route .gomer-hero-copy,
  body.gomer-route .gomer-need-copy,
  body.gomer-route .gomer-install-copy {
    width: min(64%, 740px);
  }
}

@media (max-height: 820px) and (min-width: 781px) {
  body.gomer-route .gomer-hero-inner,
  body.gomer-route .gomer-need-inner,
  body.gomer-route .gomer-install-inner,
  body.gomer-route .gomer-operation-inner {
    padding-block: 46px;
  }

  body.gomer-route .gomer-copy h1 {
    font-size: clamp(39px, 4.2vw, 62px);
  }

  body.gomer-route .gomer-copy h2,
  body.gomer-route .gomer-section-head h2 {
    font-size: clamp(31px, 3vw, 48px);
  }

  body.gomer-route .gomer-spec-list div {
    padding: 9px 11px;
  }
}

@media (max-width: 780px) {
  body.gomer-route .gomer-slide {
    min-height: auto;
  }

  body.gomer-route .gomer-bg {
    display: none;
  }

  body.gomer-route .gomer-slide--cards {
    min-height: auto;
  }

  body.gomer-route .gomer-hero-inner,
  body.gomer-route .gomer-need-inner,
  body.gomer-route .gomer-install-inner,
  body.gomer-route .gomer-operation-inner {
    min-height: auto;
    padding-block: 34px;
  }

  body.gomer-route .gomer-card-layout {
    padding-block: 34px;
  }

  body.gomer-route .gomer-hero-copy,
  body.gomer-route .gomer-need-copy,
  body.gomer-route .gomer-install-copy,
  body.gomer-route .gomer-operation-copy {
    width: min(100%, 420px);
    margin-left: 0;
  }

  body.gomer-route .gomer-copy h1 {
    max-width: 390px;
    font-size: clamp(30px, 8.3vw, 39px);
  }

  body.gomer-route .gomer-copy h2,
  body.gomer-route .gomer-section-head h2 {
    font-size: clamp(25px, 7vw, 34px);
  }

  body.gomer-route .gomer-copy p,
  body.gomer-route .gomer-section-head p {
    max-width: 390px;
    font-size: 14px;
    line-height: 1.34;
  }

  body.gomer-route .gomer-lead {
    font-size: 15px;
  }

  body.gomer-route .gomer-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: min(100%, 350px);
  }

  body.gomer-route .gomer-actions .btn {
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
  }

  body.gomer-route .gomer-card-grid,
  body.gomer-route .gomer-spec-list {
    grid-template-columns: 1fr;
  }

  body.gomer-route .gomer-card-body {
    padding: 13px;
  }

  body.gomer-route .gomer-card h3 {
    font-size: 21px;
  }

  body.gomer-route .gomer-card p,
  body.gomer-route .gomer-bullets li {
    font-size: 14px;
    line-height: 1.34;
  }

  body.gomer-route .gomer-spec-list dt {
    font-size: 11px;
  }

  body.gomer-route .gomer-spec-list dd {
    font-size: 13px;
  }
}

@media (max-width: 420px) {
  body.gomer-route .gomer-copy h1 {
    font-size: 29px;
  }

body.gomer-route .gomer-copy p,
body.gomer-route .gomer-section-head p,
body.gomer-route .gomer-card p,
body.gomer-route .gomer-bullets li {
    font-size: 12.8px;
  }

  body.gomer-route .gomer-kicker {
    font-size: 11.5px;
  }
}

/* GateKeeper product workflow. Source of truth:
   .artifacts/product-plans/gatekeeper/gatekeeper-section-contracts-2026-06-02.json */
body.gatekeeper-route {
  background: #f7fbff;
}

body.gatekeeper-route .gatekeeper-page :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
  letter-spacing: 0;
}

body.gatekeeper-route .gatekeeper-slide {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  min-height: min(max(680px, calc((100vw - 15px) * 941 / 1672)), 100vh);
  background: #f7fbff;
  color: #142437;
}

body.gatekeeper-route .gatekeeper-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  object-position: center;
  pointer-events: none;
  filter: none;
  opacity: 1;
}

body.gatekeeper-route .gatekeeper-slide--cards {
  min-height: auto;
}

body.gatekeeper-route .gatekeeper-slide--cards .gatekeeper-bg {
  inset: 0;
  height: 100%;
  object-fit: fill;
}

body.gatekeeper-route .gatekeeper-inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  min-height: inherit;
}

body.gatekeeper-route .gatekeeper-hero-inner,
body.gatekeeper-route .gatekeeper-install-inner,
body.gatekeeper-route .gatekeeper-ecosystem-inner {
  display: grid;
  align-items: center;
  padding-block: clamp(54px, 6vw, 90px);
}

body.gatekeeper-route .gatekeeper-access-inner {
  display: grid;
  align-items: stretch;
  grid-template-rows: minmax(0, 1fr) minmax(0, auto);
  padding-block: clamp(46px, 5vw, 74px);
}

body.gatekeeper-route .gatekeeper-card-layout {
  box-sizing: border-box;
  padding-inline: clamp(28px, 4vw, 72px);
}

body.gatekeeper-route .gatekeeper-copy,
body.gatekeeper-route .gatekeeper-section-head {
  display: grid;
  gap: clamp(12px, 1.4vw, 20px);
}

body.gatekeeper-route .gatekeeper-hero-copy,
body.gatekeeper-route .gatekeeper-access-copy,
body.gatekeeper-route .gatekeeper-ecosystem-copy {
  width: min(56%, 780px);
}

body.gatekeeper-route .gatekeeper-access-bottom {
  align-self: end;
  width: min(48%, 620px);
}

body.gatekeeper-route .gatekeeper-access-copy {
  align-self: start;
}

body.gatekeeper-route .gatekeeper-install-copy {
  width: min(56%, 780px);
  margin-left: auto;
}

body.gatekeeper-route .gatekeeper-kicker {
  margin: 0;
  color: #0a67b7;
  font-size: clamp(12px, 0.95vw, 14px);
  font-weight: 820;
  line-height: 1.1;
  text-transform: uppercase;
}

body.gatekeeper-route .gatekeeper-copy h1,
body.gatekeeper-route .gatekeeper-copy h2,
body.gatekeeper-route .gatekeeper-section-head h2 {
  margin: 0;
  color: #0d1f31;
  font-weight: 830;
  line-height: 1.04;
}

body.gatekeeper-route .gatekeeper-copy h1 {
  max-width: 760px;
  font-size: clamp(43px, 5vw, 78px);
}

body.gatekeeper-route .gatekeeper-copy h2,
body.gatekeeper-route .gatekeeper-section-head h2 {
  font-size: clamp(30px, 3vw, 54px);
}

body.gatekeeper-route .gatekeeper-copy p,
body.gatekeeper-route .gatekeeper-section-head p,
body.gatekeeper-route .gatekeeper-card p,
body.gatekeeper-route .gatekeeper-list li {
  margin: 0;
  color: rgba(20, 36, 55, 0.82);
  font-size: clamp(15px, 1.12vw, 19px);
  line-height: 1.45;
}

body.gatekeeper-route .gatekeeper-lead {
  color: #102431;
  font-size: clamp(18px, 1.45vw, 24px);
  font-weight: 670;
}

body.gatekeeper-route .gatekeeper-audience,
body.gatekeeper-route .gatekeeper-result {
  color: #0e5d8e;
  font-weight: 700;
}

body.gatekeeper-route .gatekeeper-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 4px;
}

body.gatekeeper-route .gatekeeper-actions .btn {
  position: relative;
  z-index: 2;
}

body.gatekeeper-route .gatekeeper-product-view {
  position: absolute;
  z-index: 1;
  right: clamp(18px, 4vw, 64px);
  bottom: clamp(36px, 5vw, 90px);
  width: clamp(120px, 16vw, 210px);
  height: auto;
  pointer-events: none;
}

body.gatekeeper-route .gatekeeper-card-layout {
  position: relative;
  z-index: 1;
  display: grid;
  gap: clamp(24px, 3vw, 42px);
  padding-block: clamp(58px, 6.8vw, 96px);
}

body.gatekeeper-route .gatekeeper-section-head {
  width: min(900px, 100%);
}

body.gatekeeper-route .gatekeeper-section-head p {
  max-width: 790px;
}

body.gatekeeper-route .gatekeeper-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.6vw, 22px);
}

body.gatekeeper-route .gatekeeper-card {
  display: grid;
  overflow: hidden;
  border: 1px solid rgba(54, 114, 145, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 34px rgba(28, 76, 94, 0.09);
}

body.gatekeeper-route .gatekeeper-card-media {
  display: block;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
  background: #edf7fb;
}

body.gatekeeper-route .gatekeeper-card-media img {
  display: block;
  width: 100%;
  height: auto;
}

body.gatekeeper-route .gatekeeper-card-body {
  display: grid;
  gap: 8px;
  padding: clamp(14px, 1.45vw, 20px);
}

body.gatekeeper-route .gatekeeper-card h3 {
  margin: 0;
  color: #102431;
  font-size: clamp(19px, 1.35vw, 25px);
  line-height: 1.1;
}

body.gatekeeper-route .gatekeeper-list {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

body.gatekeeper-route .gatekeeper-list li {
  position: relative;
  padding-left: 20px;
}

body.gatekeeper-route .gatekeeper-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #0a8fd8;
}

@media (max-width: 1180px) {
  body.gatekeeper-route .gatekeeper-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.gatekeeper-route .gatekeeper-hero-copy,
  body.gatekeeper-route .gatekeeper-access-copy,
  body.gatekeeper-route .gatekeeper-ecosystem-copy,
  body.gatekeeper-route .gatekeeper-install-copy {
    width: min(64%, 740px);
  }

  body.gatekeeper-route .gatekeeper-product-view {
    width: clamp(110px, 18vw, 180px);
  }
}

@media (max-height: 820px) and (min-width: 781px) {
  body.gatekeeper-route .gatekeeper-bg {
    height: 100%;
    object-fit: fill;
  }

  body.gatekeeper-route .gatekeeper-hero-inner,
  body.gatekeeper-route .gatekeeper-install-inner,
  body.gatekeeper-route .gatekeeper-ecosystem-inner,
  body.gatekeeper-route .gatekeeper-access-inner {
    padding-block: 44px;
  }

  body.gatekeeper-route .gatekeeper-copy h1 {
    font-size: clamp(38px, 4.2vw, 62px);
  }

  body.gatekeeper-route .gatekeeper-copy h2,
  body.gatekeeper-route .gatekeeper-section-head h2 {
    font-size: clamp(30px, 3vw, 48px);
  }
}

@media (max-width: 780px) {
  body.gatekeeper-route .gatekeeper-slide {
    min-height: auto;
  }

  body.gatekeeper-route .gatekeeper-bg {
    display: none;
  }

  body.gatekeeper-route .gatekeeper-hero-inner,
  body.gatekeeper-route .gatekeeper-install-inner,
  body.gatekeeper-route .gatekeeper-ecosystem-inner,
  body.gatekeeper-route .gatekeeper-access-inner {
    min-height: auto;
    padding-block: 34px;
  }

  body.gatekeeper-route .gatekeeper-card-layout {
    padding-block: 30px;
  }

  body.gatekeeper-route .gatekeeper-hero-copy,
  body.gatekeeper-route .gatekeeper-access-copy,
  body.gatekeeper-route .gatekeeper-ecosystem-copy,
  body.gatekeeper-route .gatekeeper-install-copy {
    width: min(100%, 430px);
    margin-left: 0;
  }

  body.gatekeeper-route .gatekeeper-product-view {
    position: relative;
    right: auto;
    bottom: auto;
    width: min(180px, 58vw);
    margin-top: 18px;
    justify-self: center;
  }

  body.gatekeeper-route .gatekeeper-copy h1 {
    max-width: 390px;
    font-size: clamp(30px, 8.2vw, 39px);
  }

  body.gatekeeper-route .gatekeeper-copy h2,
  body.gatekeeper-route .gatekeeper-section-head h2 {
    font-size: clamp(25px, 7vw, 34px);
  }

  body.gatekeeper-route .gatekeeper-copy p,
  body.gatekeeper-route .gatekeeper-section-head p,
  body.gatekeeper-route .gatekeeper-card p,
  body.gatekeeper-route .gatekeeper-list li {
    max-width: 410px;
    font-size: 14px;
    line-height: 1.34;
  }

  body.gatekeeper-route .gatekeeper-lead {
    font-size: 15px;
  }

  body.gatekeeper-route .gatekeeper-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: min(100%, 350px);
  }

  body.gatekeeper-route .gatekeeper-actions .btn {
    justify-content: center;
    padding: 10px 14px;
    font-size: 13px;
  }

  body.gatekeeper-route .gatekeeper-card-grid {
    grid-template-columns: 1fr;
  }

  body.gatekeeper-route .gatekeeper-card-body {
    padding: 13px;
  }

  body.gatekeeper-route .gatekeeper-card h3 {
    font-size: 21px;
  }
}

@media (max-width: 420px) {
  body.gatekeeper-route .gatekeeper-copy h1 {
    font-size: 29px;
  }

  body.gatekeeper-route .gatekeeper-copy p,
  body.gatekeeper-route .gatekeeper-section-head p,
  body.gatekeeper-route .gatekeeper-card p,
  body.gatekeeper-route .gatekeeper-list li {
    font-size: 12.8px;
  }

  body.gatekeeper-route .gatekeeper-kicker {
    font-size: 11.5px;
  }
}
/* HeatMaster Phase 3 integration, 2026-06-02 */
body.heatmaster-route {
  background: #f6f3ea;
}

body.heatmaster-route .heatmaster-page,
body.heatmaster-route .heatmaster-page :where(h1, h2, h3, p, li, a, button, span, strong) {
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

body.heatmaster-route .heatmaster-page {
  background: #f6f3ea;
  color: #142019;
}

body.heatmaster-route .heatmaster-page .reveal {
  opacity: 1;
  transform: none;
}

.heatmaster-slide {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
  overflow: hidden;
  padding: 0;
  background: #f6f3ea;
}

.heatmaster-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  object-position: center;
  filter: none;
  opacity: 1;
  pointer-events: none;
}

.heatmaster-inner {
  position: relative;
  z-index: 1;
  min-height: 100svh;
}

.heatmaster-copy,
.heatmaster-process-copy,
.heatmaster-process-note {
  color: #17231b;
}

.heatmaster-copy {
  width: min(55%, 740px);
  padding-top: clamp(64px, 8svh, 112px);
  padding-bottom: clamp(56px, 8svh, 96px);
}

.heatmaster-copy--left {
  margin-right: auto;
}

.heatmaster-copy--right {
  margin-left: auto;
}

.heatmaster-kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  color: #2f7b47;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.heatmaster-kicker::before {
  width: 28px;
  height: 2px;
  content: "";
  background: #69a76d;
}

.heatmaster-copy h1,
.heatmaster-copy h2,
.heatmaster-process-copy h2 {
  max-width: 780px;
  margin-bottom: 18px;
  color: #142019;
  letter-spacing: 0;
  line-height: 1.06;
}

.heatmaster-copy h1 {
  font-size: clamp(42px, 4.8vw, 70px);
}

.heatmaster-copy h2,
.heatmaster-process-copy h2 {
  font-size: clamp(34px, 3.5vw, 52px);
}

.heatmaster-copy h3 {
  margin-bottom: 10px;
  color: #1c3524;
  font-size: 17px;
  line-height: 1.18;
}

.heatmaster-copy p,
.heatmaster-copy li,
.heatmaster-process-copy p,
.heatmaster-process-note p {
  color: #2c3f31;
  font-size: clamp(16px, 1.28vw, 19px);
  line-height: 1.48;
}

.heatmaster-lead {
  max-width: 720px;
  color: #203529;
  font-size: clamp(18px, 1.55vw, 23px);
  line-height: 1.36;
}

.heatmaster-copy p + p,
.heatmaster-process-note p + p {
  margin-top: 14px;
}

.heatmaster-list {
  display: grid;
  gap: 8px;
  margin-top: 18px;
  padding-left: 0;
  list-style: none;
}

.heatmaster-list li {
  position: relative;
  padding-left: 22px;
}

.heatmaster-list li::before {
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  content: "";
  background: #3f9a58;
}

.heatmaster-two-lists {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2vw, 28px);
  margin-top: 20px;
}

.heatmaster-copy--dense {
  width: min(55%, 760px);
  padding-top: clamp(44px, 6svh, 78px);
}

.heatmaster-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 26px;
}

.heatmaster-actions .btn {
  white-space: normal;
}

body.heatmaster-route .heatmaster-actions .btn-primary {
  border-color: #2f7b47;
  background: #2f7b47;
  color: #ffffff;
}

body.heatmaster-route .heatmaster-actions .btn-secondary {
  border-color: rgba(47, 123, 71, 0.34);
  background: rgba(255, 255, 255, 0.74);
  color: #245d36;
}

.heatmaster-process-inner {
  display: grid;
  min-height: 100svh;
  grid-template-rows: minmax(0, 32svh) minmax(0, 35svh) minmax(0, 33svh);
}

.heatmaster-process-copy {
  align-self: end;
  max-width: 1120px;
  padding-bottom: clamp(10px, 2svh, 18px);
}

.heatmaster-process-copy h2 {
  max-width: 1120px;
  margin-bottom: 12px;
}

.heatmaster-process-copy p {
  max-width: 980px;
}

.heatmaster-process-note {
  grid-row: 3;
  align-self: start;
  max-width: 1160px;
  padding-top: clamp(12px, 2svh, 20px);
}

.heatmaster-final-note {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 22px;
}

.heatmaster-final-note p {
  max-width: 760px;
}

.heatmaster-final-note .heatmaster-actions {
  justify-content: flex-end;
  margin-top: 0;
}

@media (max-width: 1180px) {
  .heatmaster-copy {
    width: min(55%, 680px);
  }

  .heatmaster-copy--dense {
    width: min(55%, 700px);
  }

  .heatmaster-final-note {
    grid-template-columns: 1fr;
  }

  .heatmaster-final-note .heatmaster-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 820px) {
  .heatmaster-slide,
  .heatmaster-inner {
    min-height: 100svh;
  }

  .heatmaster-bg {
    object-fit: fill;
  }

  .heatmaster-copy,
  .heatmaster-copy--dense {
    width: 61%;
    padding-top: clamp(30px, 5svh, 48px);
    padding-bottom: clamp(28px, 5svh, 44px);
  }

  .heatmaster-copy--right {
    margin-left: auto;
  }

  .heatmaster-copy h1 {
    font-size: clamp(30px, 8.2vw, 44px);
    line-height: 1.05;
  }

  .heatmaster-copy h2,
  .heatmaster-process-copy h2 {
    font-size: clamp(25px, 6.5vw, 34px);
    line-height: 1.08;
  }

  .heatmaster-copy p,
  .heatmaster-copy li,
  .heatmaster-process-copy p,
  .heatmaster-process-note p {
    font-size: clamp(13px, 3.2vw, 16px);
    line-height: 1.36;
  }

  .heatmaster-lead {
    font-size: clamp(15px, 3.8vw, 18px);
  }

  .heatmaster-kicker {
    margin-bottom: 10px;
    font-size: 11px;
  }

  .heatmaster-list {
    gap: 5px;
    margin-top: 10px;
  }

  .heatmaster-two-lists {
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 12px;
  }

  .heatmaster-copy h3 {
    margin-bottom: 6px;
    font-size: 14px;
  }

  .heatmaster-actions {
    gap: 10px;
    margin-top: 16px;
  }

  .heatmaster-actions .btn {
    min-height: 42px;
    padding: 10px 14px;
    font-size: 13px;
  }

  .heatmaster-process-inner {
    grid-template-rows: 32svh 35svh 33svh;
  }

  .heatmaster-process-copy {
    max-width: 100%;
    padding-bottom: 8px;
  }

  .heatmaster-process-note {
    padding-top: 8px;
  }
}

@media (max-width: 520px) {
  .heatmaster-copy,
  .heatmaster-copy--dense {
    width: 58%;
  }

  .heatmaster-copy h1 {
    font-size: clamp(28px, 7.8vw, 34px);
  }

  .heatmaster-copy h2,
  .heatmaster-process-copy h2 {
    font-size: clamp(23px, 6vw, 28px);
  }

  .heatmaster-copy p,
  .heatmaster-copy li,
  .heatmaster-process-copy p,
  .heatmaster-process-note p {
    font-size: 12.8px;
    line-height: 1.32;
  }

  .heatmaster-hero .heatmaster-copy {
    width: 58%;
  }

  .heatmaster-process-inner {
    grid-template-rows: 32svh 35svh 33svh;
  }

  .heatmaster-final-note .heatmaster-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
}
