:root {
  color-scheme: light;
  --bg: #F2F2F2;
  --fg: #0D0D0D;
  --muted: rgba(13, 13, 13, 0.58);
  --faint: rgba(13, 13, 13, 0.34);
  --rule: rgba(13, 13, 13, 0.16);
  --nav: #0D0D0D;
  --nav-fg: #F2F2F2;
  --nav-contrast: #0D0D0D;
  --nav-muted: rgba(242, 242, 242, 0.62);
  --nav-rule: rgba(242, 242, 242, 0.2);
  --nav-hover: rgba(242, 242, 242, 0.12);
  --inverse: #FFFFFF;
  --easing: cubic-bezier(0.16, 1, 0.3, 1);
  --font-display: "Google Sans Display", "Google Sans", "Product Sans", sans-serif;
  --font-body: "Google Sans Text", "Google Sans", "Roboto", Arial, Helvetica, sans-serif;
  --font-base: "Google Sans", "Product Sans", "Roboto", Arial, Helvetica, sans-serif;
  --font-mono: "Google Sans Mono", "Roboto Mono", "Courier New", monospace;
  --font: var(--font-base);
  --text-2xs: 7.68pt;
  --text-xs: 9pt;
  --text-sm: 10.5pt;
  --text-base: 12pt;
  --text-md: 13.5pt;
  --text-lg: 15pt;
  --text-xl: 18pt;
  --text-2xl: 22.5pt;
  --text-3xl: 27pt;
  --text-4xl: 36pt;
  --text-5xl: 45pt;
  --text-6xl: 54pt;
  --text-hero: clamp(30pt, 6vw, 60pt);
  --text-h1: clamp(22.5pt, 4vw, 27pt);
  --text-h2: clamp(18pt, 3vw, 22.5pt);
  --text-h3: clamp(15pt, 2.5vw, 18pt);
  --text-body: clamp(11.25pt, 1.5vw, 12pt);
  --weight-light: 300;
  --weight-regular: 400;
  --weight-medium: 500;
  --weight-bold: 700;
  --leading-none: 1;
  --leading-tight: 1.2;
  --leading-snug: 1.35;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;
  --leading-loose: 1.8;
  --leading-double: 2;
  --tracking-tighter: 0em;
  --tracking-tight: 0em;
  --tracking-normal: 0em;
  --tracking-wide: 0.025em;
  --tracking-wider: 0.05em;
  --tracking-widest: 0.15em;
  --tracking-ultra: 0.25em;
  --paragraph-spacing-sm: 0.75em;
  --paragraph-spacing-md: 1em;
  --paragraph-spacing-lg: 1.5em;
  --measure-narrow: 45ch;
  --measure-default: 65ch;
  --measure-wide: 80ch;
  --measure-full: 100%;
  --text-indent-sm: 1em;
  --text-indent-md: 2em;
  --rhythm: 0.25rem;
  --space-1: calc(var(--rhythm) * 1);
  --space-2: calc(var(--rhythm) * 2);
  --space-3: calc(var(--rhythm) * 3);
  --space-4: calc(var(--rhythm) * 4);
  --space-5: calc(var(--rhythm) * 5);
  --space-6: calc(var(--rhythm) * 6);
  --space-8: calc(var(--rhythm) * 8);
  --space-10: calc(var(--rhythm) * 10);
  --space-12: calc(var(--rhythm) * 12);
  --space-16: calc(var(--rhythm) * 16);
  --space-20: calc(var(--rhythm) * 20);
  --space-24: calc(var(--rhythm) * 24);
  --color-text-primary: var(--fg);
  --color-text-secondary: var(--muted);
  --color-text-tertiary: var(--faint);
  --color-text-inverse: var(--inverse);
  --color-text-accent: #1a56db;
  --color-text-muted: #9ca3af;
  --page-pad: clamp(20px, 5vw, 72px);
  --nav-pad: clamp(8px, 1.2vw, 18px);
  --nav-h: 60px;
  --scroll-progress: 0;
  --page-hero-min: clamp(620px, calc(100vh - var(--nav-h) - 70px), 900px);
  --page-hero-grid-min: clamp(480px, calc(100vh - var(--nav-h) - 210px), 700px);
  --page-hero-padding-top: clamp(28px, 4vw, 64px);
  --page-hero-padding-bottom: clamp(54px, 7vw, 104px);
  --page-hero-grid-gap: clamp(36px, 8vw, 124px);
  --page-hero-content-gap: 14px;
  --page-title-size: clamp(25.5pt, 5vw, 46.5pt);
  --page-title-line-height: var(--leading-tight);
  --page-copy-max: min(760px, 100%);
  --page-copy-size: clamp(11.25pt, 1.15vw, 12.75pt);
  --page-copy-line-height: var(--leading-relaxed);
  --section-title-size: clamp(25.5pt, 5vw, 46.5pt);
  --section-title-line-height: var(--leading-tight);
  --section-copy-size: clamp(11.25pt, 1.15vw, 12.75pt);
  --section-copy-line-height: var(--leading-relaxed);
  --title-box-gap: clamp(14px, 1.9vw, 21px);
  --cursor-dark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='32' viewBox='0 0 24 24'%3E%3Cpath fill='%230D0D0D' stroke='%23FFFFFF' stroke-width='0.9' stroke-linejoin='round' d='M4.5.79v22.42l6.56-6.57h9.29L4.5.79z'%3E%3C/path%3E%3C/svg%3E") 4 1, auto;
  --cursor-light: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='32' viewBox='0 0 24 24'%3E%3Cpath fill='%23F2F2F2' stroke='%23FFFFFF' stroke-width='0.9' stroke-linejoin='round' d='M4.5.79v22.42l6.56-6.57h9.29L4.5.79z'%3E%3C/path%3E%3C/svg%3E") 4 1, auto;
  --site-cursor: var(--cursor-dark);
}

@font-face {
  font-family: "Google Sans";
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("https://cdn.jsdelivr.net/fontsource/fonts/google-sans@latest/latin-300-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Google Sans";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("https://cdn.jsdelivr.net/fontsource/fonts/google-sans@latest/latin-400-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Google Sans";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("https://cdn.jsdelivr.net/fontsource/fonts/google-sans@latest/latin-500-normal.woff2") format("woff2");
}

@font-face {
  font-family: "Google Sans";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("https://cdn.jsdelivr.net/fontsource/fonts/google-sans@latest/latin-700-normal.woff2") format("woff2");
}

html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0D0D0D;
  --fg: #F2F2F2;
  --muted: rgba(242, 242, 242, 0.62);
  --faint: rgba(242, 242, 242, 0.34);
  --rule: rgba(242, 242, 242, 0.16);
  --nav: #F2F2F2;
  --nav-fg: #0D0D0D;
  --nav-contrast: #F2F2F2;
  --nav-muted: rgba(13, 13, 13, 0.58);
  --nav-rule: rgba(13, 13, 13, 0.18);
  --nav-hover: rgba(13, 13, 13, 0.08);
  --inverse: #000000;
  --site-cursor: var(--cursor-light);
}

* {
  box-sizing: border-box;
  font-family: inherit;
}

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

html {
  background-color: var(--bg);
  scroll-behavior: smooth;
  scrollbar-width: none;
  font-family: var(--font-body);
  cursor: var(--site-cursor);
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: var(--text-body);
  font-weight: var(--weight-regular);
  line-height: var(--leading-relaxed);
  text-rendering: optimizeLegibility;
  transition: background-color 600ms var(--easing), color 600ms var(--easing);
  cursor: var(--site-cursor);
}

body::selection {
  background: var(--fg);
  color: var(--bg);
}

::-webkit-scrollbar {
  width: 0;
  height: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

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

h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}

h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--weight-medium);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
}

h3 {
  font-family: var(--font-base);
  font-size: var(--text-xl);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-normal);
}

h4 {
  font-family: var(--font-base);
  font-size: var(--text-lg);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
}

h5 {
  font-family: var(--font-base);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  line-height: var(--leading-normal);
}

h6 {
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

code,
pre,
kbd,
samp {
  font-family: var(--font-mono);
  font-size: 10.8pt;
  line-height: var(--leading-relaxed);
}

pre {
  font-size: var(--text-sm);
}

kbd {
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
}

.label {
  font-family: var(--font-base);
}

.label {
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

blockquote {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--weight-light);
  font-style: italic;
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-normal);
}

button {
  color: inherit;
}

a,
button,
[role="button"],
.cta,
.menu-button,
summary,
label {
  cursor: pointer;
}

svg {
  display: block;
}

.site-nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  isolation: isolate;
  height: var(--nav-h);
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 24px;
  padding: 0 var(--nav-pad);
  background-color: var(--nav);
  color: var(--nav-fg);
  transition: background-color 600ms var(--easing), color 600ms var(--easing);
}

.site-nav::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: #F2F2F2;
  z-index: 4;
  pointer-events: none;
  transform: scaleX(var(--scroll-progress));
  transform-origin: left center;
  transition: transform 120ms linear;
  will-change: transform;
}

.brand {
  position: relative;
  z-index: 1;
  width: clamp(158px, 14vw, 220px);
  height: 48px;
  display: inline-block;
  overflow: visible;
}

.brand[data-theme-hint]::after {
  position: absolute;
  z-index: 20;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-4px);
  transition: opacity 160ms ease, transform 180ms var(--easing);
}

.brand[data-theme-hint]::after {
  content: attr(data-theme-hint);
  top: 50%;
  left: clamp(122px, 10.5vw, 172px);
  width: max-content;
  max-width: min(260px, calc(100vw - 260px));
  color: var(--nav-fg);
  font-family: var(--font-base);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  white-space: nowrap;
  transform: translate(-4px, -50%);
}

.brand[data-theme-hint]::after {
  animation: brandHintIntro 2200ms 700ms;
}

.brand[data-theme-hint]:hover::after,
.brand[data-theme-hint]:focus-visible::after {
  opacity: 1;
  transform: translate(0, -50%);
}

@keyframes brandHintIntro {
  0%,
  20%,
  100% {
    opacity: 0;
    transform: translate(-4px, -50%);
  }

  34%,
  62% {
    opacity: 1;
    transform: translate(0, -50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .brand[data-theme-hint]::after {
    animation: none;
  }
}

.brand-logo {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: auto;
  max-height: 36px;
  object-fit: contain;
  object-position: left center;
  opacity: 0;
  transform: translateY(-50%);
  transition: opacity 450ms var(--easing);
}

.brand-logo--light-theme {
  opacity: 1;
}

html[data-theme="dark"] .brand-logo--light-theme {
  opacity: 0;
}

html[data-theme="dark"] .brand-logo--dark-theme {
  opacity: 1;
}

.nav-active-indicator {
  position: absolute;
  bottom: -2px;
  left: 0;
  z-index: 0;
  width: var(--indicator-width, 0px);
  height: 46px;
  background-color: var(--nav-fg);
  border-radius: 14px 14px 0 0;
  box-shadow: 0 -2px 0 #F2F2F2;
  opacity: 0;
  pointer-events: none;
  transform: translateX(var(--indicator-x, 0px));
  transition: transform 620ms var(--easing), width 620ms var(--easing), background-color 600ms var(--easing), box-shadow 600ms var(--easing), opacity 220ms ease;
  will-change: transform, width;
}

.nav-active-indicator.is-ready {
  opacity: 1;
}

.nav-active-indicator.is-placing {
  opacity: 1;
  transition: none;
}

.nav-active-indicator.is-placing::before,
.nav-active-indicator.is-placing::after {
  transition: none;
}

.nav-active-indicator::before,
.nav-active-indicator::after {
  content: "";
  position: absolute;
  bottom: 0;
  width: 16px;
  height: 16px;
  background-color: var(--nav-fg);
  transition: background-color 600ms var(--easing);
}

.nav-active-indicator::before {
  left: -16px;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1 1' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1,0 A1,1 0,0,1 0,1 L1,1 Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1 1' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1,0 A1,1 0,0,1 0,1 L1,1 Z'/%3E%3C/svg%3E");
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.nav-active-indicator::after {
  right: -16px;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1 1' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,0 A1,1 0,0,0 1,1 L0,1 Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1 1' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,0 A1,1 0,0,0 1,1 L0,1 Z'/%3E%3C/svg%3E");
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
}

.nav-link {
  position: relative;
  z-index: 1;
  width: var(--nav-item-width, 90px);
  min-width: 0;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  line-height: 1;
  white-space: nowrap;
  color: var(--nav-muted);
  transition: color 300ms var(--easing), font-weight 300ms var(--easing);
}

.nav-link[data-nav="home"] {
  --nav-item-width: 72px;
}

.nav-link[data-nav="focus"] {
  --nav-item-width: 94px;
}

.nav-link[data-nav="products"] {
  --nav-item-width: 90px;
}

.nav-link[data-nav="about"] {
  --nav-item-width: 90px;
}

.nav-link[data-nav="contact"] {
  --nav-item-width: 84px;
}

.nav-label {
  display: block;
  transform: translateY(0);
  transition: transform 520ms var(--easing);
  will-change: transform;
}

.nav-link:hover,
.nav-link.is-active {
  color: var(--nav-fg);
}

.nav-link.is-active {
  color: var(--nav-contrast);
  font-weight: var(--weight-bold);
}

.nav-link.is-active .nav-label {
  font-weight: var(--weight-bold);
  transform: translateY(8px);
}

.nav-actions {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(2px, 0.5vw, 8px);
  overflow: visible;
}

.menu-button {
  width: 42px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  border: 1px solid var(--nav-rule);
  border-radius: 0;
  background: transparent;
  cursor: pointer;
  transition: border-color 300ms var(--easing), background-color 300ms var(--easing);
}

.menu-button:hover {
  border-color: var(--nav-fg);
  background: var(--nav-hover);
}

.cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: max-content;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
}

.cta {
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid var(--fg);
  border-radius: 8px;
  color: var(--bg);
  background: var(--fg);
  font-family: var(--font-base);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wider);
  line-height: 1;
  text-transform: none;
  transition: transform 300ms var(--easing), background-color 300ms var(--easing), color 300ms var(--easing);
}

.cta:hover {
  transform: translateY(-2px);
  background: transparent;
  color: var(--fg);
}

.cta-secondary {
  background: transparent;
  color: var(--fg);
}

.cta-secondary:hover {
  background: var(--fg);
  color: var(--bg);
}

.home-hero .hero-actions:has(.cta-secondary:is(:hover, :focus-visible)) .cta:not(.cta-secondary) {
  background: transparent;
  color: var(--fg);
}

.home-hero .hero-actions:has(.cta:not(.cta-secondary):is(:hover, :focus-visible)) .cta-secondary {
  background: var(--fg);
  color: var(--bg);
}

.site-nav .cta,
.mobile-panel .cta {
  min-height: 36px;
  border-color: var(--nav-fg);
  background: var(--nav-fg);
  color: var(--nav-contrast);
}

.site-nav .cta:hover,
.mobile-panel .cta:hover {
  background: transparent;
  color: var(--nav-fg);
}

.menu-button {
  display: none;
  border-color: transparent;
  background: transparent;
}

.menu-button:hover {
  border-color: transparent;
  background: transparent;
}

.menu-lines,
.menu-lines::before,
.menu-lines::after {
  display: block;
  width: 18px;
  height: 1px;
  background: currentColor;
  transition: transform 300ms var(--easing), opacity 300ms var(--easing);
}

.menu-lines {
  position: relative;
}

.menu-lines::before,
.menu-lines::after {
  content: "";
  position: absolute;
  left: 0;
}

.menu-lines::before {
  transform: translateY(-6px);
}

.menu-lines::after {
  transform: translateY(6px);
}

body.menu-open .menu-lines {
  background: transparent;
}

body.menu-open .menu-lines::before {
  transform: rotate(45deg);
}

body.menu-open .menu-lines::after {
  transform: rotate(-45deg);
}

main {
  min-height: 100vh;
  padding-top: var(--nav-h);
}

main:focus {
  outline: 0;
}

.page-shell {
  opacity: 0;
  transform: translateY(16px);
  animation: pageIn 600ms var(--easing) forwards;
}

@keyframes pageIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.section {
  width: 100%;
  padding: clamp(68px, 10vw, 144px) var(--page-pad);
  border-bottom: 1px solid var(--rule);
}

.section:first-child {
  border-top: 0;
}

.section-tight {
  padding-top: clamp(42px, 7vw, 92px);
  padding-bottom: clamp(42px, 7vw, 92px);
}

.hero {
  min-height: calc(100vh - var(--nav-h));
  display: grid;
  align-content: end;
  gap: clamp(44px, 7vw, 96px);
  padding-top: clamp(80px, 11vw, 160px);
}

.home-hero {
  align-content: center;
  min-height: var(--page-hero-min);
  overflow: hidden;
  padding-top: var(--page-hero-padding-top);
  padding-bottom: var(--page-hero-padding-bottom);
}

.page-shell[aria-label="Home"] {
  --home-section-min: auto;
  --home-divider-gap: clamp(42px, 5vw, 64px);
  --home-content-gap: var(--title-box-gap);
}

.page-shell[aria-label="Home"]>.section {
  border-bottom: 0;
}

.page-shell[aria-label="Home"]>.section:not(.home-hero) {
  min-height: var(--home-section-min);
  display: grid;
  align-content: start;
  padding-top: var(--home-divider-gap);
  padding-bottom: var(--home-divider-gap);
}

.page-shell[aria-label="Home"] .solutions-grid,
.page-shell[aria-label="Home"] .home-value-grid,
.page-shell[aria-label="Home"] .industry-list {
  margin-top: var(--home-content-gap);
}

.home-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.58fr) minmax(320px, 0.42fr);
  gap: var(--page-hero-grid-gap);
  align-items: center;
  min-height: var(--page-hero-grid-min);
}

.home-hero-content {
  display: grid;
  gap: var(--page-hero-content-gap);
  min-width: 0;
  max-width: 860px;
  position: relative;
  z-index: 2;
}

.hero-title.home-tagline {
  max-width: 880px;
  font-size: var(--page-title-size);
  line-height: var(--page-title-line-height);
}

.home-tagline-line {
  --parallax-y: 0px;
  display: block;
  max-width: 100%;
  text-wrap: balance;
  white-space: nowrap;
  transform: translate3d(0, var(--parallax-y), 0);
  will-change: transform;
}

.hero-title.home-tagline .word {
  transform: translateY(0.55em);
  animation-duration: 980ms;
  animation-delay: calc(120ms + (var(--i) * 120ms));
}

@keyframes taglineIn {
  to {
    opacity: 1;
    transform: translate3d(0, var(--parallax-y), 0);
  }
}

.hero-title,
.product-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(42pt, 8vw, 90pt);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-none);
}

.hero-title .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.45em);
  animation: wordIn 900ms var(--easing) forwards;
  animation-delay: calc(var(--i) * 90ms);
}

.page-title-animated .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.45em);
  animation: wordIn 900ms var(--easing) forwards;
  animation-delay: calc(120ms + (var(--i) * 90ms));
}

@keyframes wordIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-copy {
  max-width: 480px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(13.5pt, 2vw, 18pt);
  line-height: 1.45;
}

.home-hero-copy {
  max-width: min(620px, 100%);
  font-size: var(--page-copy-size);
  line-height: var(--page-copy-line-height);
  overflow-wrap: break-word;
}

.home-hero-copy[data-line-reveal] {
  opacity: 0;
}

.home-hero-copy[data-line-reveal].is-line-ready {
  opacity: 1;
}

.home-hero-copy .copy-line {
  display: block;
  opacity: 0;
  transform: translateY(0.75em);
  animation: focusCopyLineIn 620ms var(--easing) forwards;
  animation-delay: calc(760ms + (var(--line) * 70ms));
  will-change: opacity, transform;
}

.hero-action {
  margin-top: 34px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 34px;
}

.home-hero .hero-actions {
  opacity: 0;
  transform: translateY(14px);
  animation: heroActionsIn 520ms var(--easing) forwards;
  animation-delay: 1120ms;
}

.contact-channel-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 10px;
  margin-top: 2px;
}

.home-final-cta .contact-channel-links {
  justify-content: center;
  margin-top: 10px;
}

.contact-channel-link {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid var(--rule);
  border-radius: 10px;
  background: transparent;
  color: var(--fg);
  transition:
    transform 300ms var(--easing),
    border-color 300ms var(--easing),
    background-color 300ms var(--easing),
    color 300ms var(--easing);
}

.contact-channel-link:hover,
.contact-channel-link:focus-visible {
  border-color: var(--fg);
  background: var(--fg);
  color: var(--bg);
  outline: 0;
  transform: translateY(-2px);
}

.contact-channel-icon {
  width: 22px;
  height: 22px;
}

@keyframes heroActionsIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-actions .hero-action {
  margin-top: 0;
}

.home-section-marker {
  justify-self: end;
  margin: 0;
  color: var(--muted);
  font-family: var(--font-base);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-widest);
  line-height: var(--leading-tight);
  text-align: right;
  text-transform: uppercase;
}

.home-system-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(360px, 46vw, 620px);
  isolation: isolate;
  opacity: 0;
  transform: scale(0.94);
  animation: systemVisualIn 900ms var(--easing) forwards;
  animation-delay: 420ms;
  will-change: opacity, transform;
}

@keyframes systemVisualIn {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.system-map {
  position: relative;
  --system-core-size: clamp(180px, 18vw, 240px);
  --system-core-ring-size: clamp(97.2px, 9.72vw, 129.6px);
  width: min(100%, 560px);
  aspect-ratio: 1;
  color: var(--fg);
  border-radius: 50%;
  background: transparent;
  transform: scale(1);
  transition: transform 520ms var(--easing);
  will-change: transform;
}

.home-system-visual:hover .system-map {
  transform: scale(1.045);
}

.system-map::before {
  content: "";
  position: absolute;
  inset: 11%;
  border: 1px solid var(--rule);
  border-radius: 50%;
  opacity: 0.78;
  animation: systemOrbit 18s linear infinite;
}

.system-map::after {
  content: "";
  position: absolute;
  inset: 29%;
  border: 1px dashed var(--rule);
  border-radius: 50%;
  opacity: 0.72;
  animation: systemOrbit 14s linear infinite reverse;
}

.system-outer-ring,
.system-rail,
.system-packet {
  position: absolute;
  pointer-events: none;
}

.system-outer-ring {
  z-index: 0;
  border: 1px solid transparent;
  border-radius: 50%;
  opacity: 0.46;
  transition: opacity 320ms var(--easing), transform 520ms var(--easing);
}

.system-outer-ring-a {
  inset: -2%;
  border-top-color: color-mix(in srgb, var(--fg) 20%, transparent);
  border-right-color: color-mix(in srgb, var(--fg) 10%, transparent);
  animation: systemOrbit 36000ms linear infinite;
}

.system-outer-ring-b {
  inset: -6%;
  border-bottom-color: color-mix(in srgb, var(--fg) 18%, transparent);
  border-left-color: color-mix(in srgb, var(--fg) 10%, transparent);
  animation: systemOrbit 46000ms linear infinite reverse;
}

.system-outer-ring-c {
  inset: -10%;
  border-top-color: color-mix(in srgb, var(--fg) 12%, transparent);
  border-bottom-color: color-mix(in srgb, var(--fg) 18%, transparent);
  opacity: 0.34;
  animation: systemOuterPulse 8800ms var(--easing) infinite;
}

.home-system-visual:hover .system-outer-ring {
  opacity: 0.72;
}

.home-system-visual:hover .system-outer-ring-a {
  animation-duration: 26000ms;
}

.home-system-visual:hover .system-outer-ring-b {
  animation-duration: 32000ms;
}

.home-system-visual:hover .system-outer-ring-c {
  opacity: 0.5;
  animation-duration: 6200ms;
}

.system-rail {
  z-index: 1;
  border: 1px solid transparent;
  border-radius: 50%;
  opacity: 0.72;
  transition: opacity 300ms var(--easing), filter 300ms var(--easing);
}

.system-rail-a {
  inset: 18%;
  border-top-color: color-mix(in srgb, var(--fg) 64%, transparent);
  border-right-color: color-mix(in srgb, var(--fg) 22%, transparent);
  animation: systemOrbit 14000ms linear infinite;
}

.system-rail-b {
  inset: 26%;
  border-bottom-color: color-mix(in srgb, var(--fg) 44%, transparent);
  border-left-color: color-mix(in srgb, var(--fg) 18%, transparent);
  animation: systemOrbit 11800ms linear infinite reverse;
}

.system-rail-c {
  inset: 39%;
  border-top-color: color-mix(in srgb, var(--fg) 24%, transparent);
  border-bottom-color: color-mix(in srgb, var(--fg) 34%, transparent);
  animation: systemOrbit 9200ms linear infinite;
}

.home-system-visual:hover .system-rail {
  opacity: 0.95;
  animation-duration: 7800ms;
}

.system-node,
.system-pulse {
  position: absolute;
  z-index: 1;
}

.system-node {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid var(--rule);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  color: var(--fg);
  font-size: 9pt;
  font-weight: var(--weight-bold);
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 30px color-mix(in srgb, var(--fg) 5%, transparent);
  appearance: none;
  font: inherit;
  transition: border-color 260ms var(--easing), background-color 260ms var(--easing), box-shadow 260ms var(--easing), transform 260ms var(--easing);
}

.system-node-primary {
  top: 50%;
  left: 50%;
  z-index: 3;
  width: var(--system-core-size);
  min-height: var(--system-core-size);
  display: block;
  padding: 0;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  border-color: var(--fg);
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--fg) 16%, transparent) 0 27%, transparent 28%),
    radial-gradient(circle at 50% 50%, transparent 0 45%, color-mix(in srgb, var(--fg) 7%, transparent) 46% 47%, transparent 48%),
    var(--bg);
  color: var(--fg);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--bg) 70%, transparent),
    0 26px 70px color-mix(in srgb, var(--fg) 12%, transparent);
  animation: coreBreathe 4200ms var(--easing) infinite;
}

.home-system-visual:hover .system-node-primary {
  border-color: color-mix(in srgb, var(--fg) 82%, var(--bg));
}

.system-core-ring,
.system-core-dot {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.system-core-ring {
  inset: 23%;
  border: 1px dashed color-mix(in srgb, var(--fg) 35%, transparent);
  animation: systemOrbit 12s linear infinite;
}

.system-core-dot {
  --core-follow-x: 0px;
  --core-follow-y: 0px;
  --core-scale: 1;
  top: 50%;
  left: 50%;
  width: clamp(22px, 2.8vw, 36px);
  height: clamp(22px, 2.8vw, 36px);
  background: color-mix(in srgb, var(--fg) 62%, var(--bg));
  transform: translate(calc(-50% + var(--core-follow-x)), calc(-50% + var(--core-follow-y))) scale(var(--core-scale));
  animation: coreDot 2600ms var(--easing) infinite;
  transition: transform 220ms var(--easing);
}

.system-pulse {
  z-index: 4;
  --dot-size: 12px;
  --dot-halo-size: 38px;
  --orbit-angle: 0deg;
  --orbit-duration: 26000ms;
  --core-orbit-size: var(--system-core-ring-size);
  inset: auto;
  top: 50%;
  left: 50%;
  width: var(--core-orbit-size);
  height: var(--core-orbit-size);
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  opacity: var(--dot-opacity, 1);
  transform: translate(-50%, -50%) rotate(var(--orbit-angle));
  transform-origin: 50% 50%;
  animation: systemCoreDotOrbit var(--orbit-duration) linear infinite;
}

.system-pulse-a {
  --orbit-angle: -112deg;
  --orbit-duration: 26000ms;
}

.system-pulse-c {
  --orbit-angle: 36deg;
  --orbit-duration: 34000ms;
  --orbit-inset: 39%;
  animation-delay: -7600ms;
}

.system-pulse-c {
  inset: var(--orbit-inset);
  top: auto;
  left: auto;
  width: auto;
  height: auto;
  transform: rotate(var(--orbit-angle));
  animation-name: systemDotOrbit;
}

.home-system-visual:hover .system-pulse {
  opacity: 0.92;
}

.system-packet {
  z-index: 5;
  --dot-size: 8px;
  --dot-halo-size: 20px;
  --dot-opacity: 0.62;
  --orbit-angle: 0deg;
  --orbit-duration: 22000ms;
  --orbit-inset: 18%;
  inset: var(--orbit-inset);
  width: auto;
  height: auto;
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  opacity: var(--dot-opacity);
  transform: rotate(var(--orbit-angle));
  transform-origin: 50% 50%;
  animation: systemDotOrbit var(--orbit-duration) linear infinite;
  transition: opacity 260ms var(--easing);
}

.system-packet-a {
  --orbit-angle: 42deg;
  --orbit-duration: 22000ms;
  --orbit-inset: 18%;
}

.system-packet-b {
  --dot-size: 6px;
  --dot-opacity: 0.46;
  --orbit-angle: 144deg;
  --orbit-duration: 28000ms;
  --orbit-inset: 26%;
  animation-direction: reverse;
}

.system-packet-c {
  --dot-size: 5px;
  --dot-opacity: 0.42;
  --orbit-angle: 286deg;
  --orbit-duration: 18000ms;
  --orbit-inset: 39%;
}

.home-system-visual:hover .system-packet {
  opacity: 0.92;
}

.system-orbit-dot {
  position: absolute;
  z-index: 2;
  --dot-size: 8px;
  --dot-halo-size: 0px;
  --dot-opacity: 0.76;
  --orbit-angle: 0deg;
  --orbit-duration: 28000ms;
  --orbit-inset: 18%;
  inset: var(--orbit-inset);
  width: auto;
  height: auto;
  border-radius: 50%;
  background: transparent;
  opacity: var(--dot-opacity);
  transform: rotate(var(--orbit-angle));
  transform-origin: 50% 50%;
  animation: systemDotOrbit var(--orbit-duration) linear infinite;
}

.system-orbit-dot-a {
  --orbit-angle: 18deg;
  --orbit-duration: 30000ms;
  --orbit-inset: 18%;
}

.system-orbit-dot-b {
  --dot-size: 6px;
  --dot-opacity: 0.48;
  --orbit-angle: 188deg;
  --orbit-duration: 36000ms;
  --orbit-inset: 39%;
}

.system-packet::before,
.system-packet::after,
.system-pulse::before,
.system-pulse::after,
.system-orbit-dot::before,
.system-orbit-dot::after {
  content: "";
  position: absolute;
  top: 50%;
  left: calc(100% - 0.5px);
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(var(--dot-scale, 1));
  transition: transform 260ms var(--easing), opacity 260ms var(--easing);
}

.system-packet::before,
.system-pulse::before,
.system-orbit-dot::before {
  z-index: 1;
  width: var(--dot-size);
  background: var(--fg);
}

.system-packet::before {
  background: color-mix(in srgb, var(--fg) 78%, var(--bg));
}

.system-packet::after,
.system-pulse::after,
.system-orbit-dot::after {
  width: var(--dot-halo-size);
  border: 1px solid color-mix(in srgb, var(--fg) 12%, transparent);
  background: color-mix(in srgb, var(--fg) 7%, transparent);
  opacity: 0.72;
  animation: systemDotPulse 6200ms ease-in-out infinite;
}

.system-orbit-dot::after {
  display: none;
}

.home-system-visual:hover :is(.system-packet, .system-pulse, .system-orbit-dot) {
  --dot-scale: 1.14;
}

@keyframes systemOrbit {
  to {
    transform: rotate(360deg);
  }
}

@keyframes systemDotOrbit {
  to {
    transform: rotate(calc(var(--orbit-angle) + 1turn));
  }
}

@keyframes systemCoreDotOrbit {
  to {
    transform: translate(-50%, -50%) rotate(calc(var(--orbit-angle) + 1turn));
  }
}

@keyframes systemDotPulse {
  50% {
    opacity: 0.42;
    transform: translate(-50%, -50%) scale(1.24);
  }
}

@keyframes systemOuterPulse {
  50% {
    transform: scale(1.035);
    opacity: 0.48;
  }
}

@keyframes coreBreathe {
  50% {
    box-shadow:
      inset 0 0 0 1px color-mix(in srgb, var(--bg) 70%, transparent),
      0 34px 86px color-mix(in srgb, var(--fg) 18%, transparent);
    transform: translate(-50%, -50%) scale(1.025);
  }
}

@keyframes coreDot {
  50% {
    --core-scale: 0.72;
    opacity: 0.58;
  }
}

@keyframes orbitDotA {
  from {
    transform: translate(-50%, -50%) rotate(18deg) translateX(clamp(104px, 11vw, 150px)) rotate(-18deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(378deg) translateX(clamp(104px, 11vw, 150px)) rotate(-378deg);
  }
}

@keyframes orbitDotB {
  from {
    transform: translate(-50%, -50%) rotate(188deg) translateX(clamp(78px, 8vw, 116px)) rotate(-188deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(-172deg) translateX(clamp(78px, 8vw, 116px)) rotate(172deg);
  }
}

@keyframes orbitPacketA {
  from {
    transform: translate(-50%, -50%) rotate(42deg) translateX(clamp(122px, 13vw, 178px)) rotate(-42deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(402deg) translateX(clamp(122px, 13vw, 178px)) rotate(-402deg);
  }
}

@keyframes orbitPacketB {
  from {
    transform: translate(-50%, -50%) rotate(144deg) translateX(clamp(88px, 9.5vw, 132px)) rotate(-144deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(504deg) translateX(clamp(88px, 9.5vw, 132px)) rotate(-504deg);
  }
}

@keyframes orbitPacketC {
  from {
    transform: translate(-50%, -50%) rotate(286deg) translateX(clamp(56px, 6.5vw, 90px)) rotate(-286deg);
  }

  to {
    transform: translate(-50%, -50%) rotate(646deg) translateX(clamp(56px, 6.5vw, 90px)) rotate(-646deg);
  }
}

@keyframes innerPulseA {

  0%,
  100% {
    transform: translate(0, 0);
  }

  35% {
    transform: translate(18px, -10px);
  }

  70% {
    transform: translate(-10px, 16px);
  }
}

@keyframes innerPulseB {

  0%,
  100% {
    transform: translate(0, 0);
  }

  40% {
    transform: translate(-16px, 12px);
  }

  76% {
    transform: translate(12px, -14px);
  }
}

@keyframes innerPulseC {

  0%,
  100% {
    transform: translate(0, 0);
  }

  42% {
    transform: translate(-18px, -12px);
  }

  78% {
    transform: translate(10px, 14px);
  }
}

@keyframes systemPulse {
  70% {
    box-shadow: 0 0 0 20px color-mix(in srgb, var(--fg) 0%, transparent);
  }

  100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--fg) 0%, transparent);
  }
}

.home-section-lede {
  display: grid;
  gap: 22px;
}

.home-section-title {
  max-width: 930px;
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--section-title-size);
  font-weight: var(--weight-bold);
  line-height: var(--section-title-line-height);
}

.home-balanced-title {
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
}

@property --grid-line-alpha {
  syntax: "<number>";
  inherits: true;
  initial-value: 1;
}

.solutions-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  margin-top: clamp(36px, 6vw, 72px);
}

.solution-card {
  min-height: 240px;
  display: grid;
  align-content: space-between;
  gap: 24px;
  padding: clamp(22px, 3vw, 36px);
  border-top: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  border-right: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
}

.solutions-grid .solution-card:first-child {
  border-left: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
}

.home-capabilities-grid .solution-card {
  min-height: clamp(270px, 22vw, 294px);
  align-content: start;
  grid-template-rows: none;
  gap: 0;
  position: relative;
  z-index: 1;
  border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  overflow: hidden;
  background: var(--bg);
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    background-color 680ms var(--easing),
    border-color 680ms var(--easing);
}

.home-capabilities-grid .solution-card::before,
.home-value-grid .home-value-card::before,
.contact-method-card::before {
  content: "";
  justify-self: end;
  width: 8px;
  height: 8px;
  margin-bottom: clamp(18px, 2.4vw, 30px);
  border-radius: 50%;
  background: var(--muted);
  opacity: 0.78;
  transition: opacity 520ms var(--easing), transform 680ms var(--easing), background-color 520ms var(--easing);
}

.home-capabilities-grid .solution-card:hover::before,
.home-capabilities-grid .solution-card:focus-within::before,
.home-value-grid .home-value-card:hover::before,
.home-value-grid .home-value-card:focus-within::before,
.contact-method-card:hover::before,
.contact-method-card:focus-within::before {
  opacity: 1;
  transform: translateY(-2px);
  background: var(--fg);
}

.home-capabilities-grid .solution-card+.solution-card {
  margin-left: -1px;
}

.home-capabilities-grid .solution-card:hover,
.home-capabilities-grid .solution-card:focus-within,
.home-value-grid .home-value-card:hover,
.home-value-grid .home-value-card:focus-within {
  z-index: 2;
}

.home-capabilities-grid .solution-card:nth-child(1),
.home-value-grid .home-value-card:nth-child(1) {
  --delay: 0ms;
}

.home-capabilities-grid .solution-card:nth-child(2),
.home-value-grid .home-value-card:nth-child(2) {
  --delay: 120ms;
}

.home-capabilities-grid .solution-card:nth-child(3),
.home-value-grid .home-value-card:nth-child(3) {
  --delay: 240ms;
}

.solution-title {
  margin: 0;
  font-size: clamp(18pt, 2.2vw, 22.5pt);
  font-weight: var(--weight-bold);
  line-height: 1;
  transition: transform 680ms var(--easing);
}

.home-capabilities-grid .solution-title {
  margin-bottom: clamp(12px, 1.5vw, 17px);
}

.home-capabilities-grid .solution-card:hover .solution-title,
.home-capabilities-grid .solution-card:focus-within .solution-title,
.home-value-grid .home-value-card:hover h3,
.home-value-grid .home-value-card:focus-within h3 {
  transform: translateY(-2px);
}

.solution-copy {
  margin: 0;
  color: var(--muted);
  font-size: clamp(11.25pt, 1.2vw, 12.75pt);
  line-height: 1.45;
  transition: opacity 520ms var(--easing), transform 720ms var(--easing);
}

.home-capabilities-grid .solution-card:hover .solution-copy,
.home-capabilities-grid .solution-card:focus-within .solution-copy,
.home-value-grid .home-value-card:hover>p,
.home-value-grid .home-value-card:focus-within>p {
  opacity: 0.78;
  transform: translateY(-2px);
}

.home-value-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  margin-top: clamp(34px, 6vw, 72px);
}

.home-value-card {
  min-height: clamp(270px, 22vw, 294px);
  display: grid;
  grid-template-rows: none;
  align-content: start;
  gap: 0;
  padding: clamp(22px, 3vw, 36px);
  position: relative;
  z-index: 1;
  border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  overflow: hidden;
  background: var(--bg);
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    background-color 680ms var(--easing),
    border-color 680ms var(--easing);
}

.home-value-grid .home-value-card+.home-value-card {
  margin-left: -1px;
}

.home-value-card h3 {
  margin: 0;
  font-size: clamp(15pt, 1.9vw, 21pt);
  font-weight: var(--weight-bold);
  line-height: 1.05;
  transition: transform 680ms var(--easing);
}

.home-value-grid .home-value-card h3 {
  margin-bottom: clamp(12px, 1.5vw, 17px);
}

.home-value-card p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(11.25pt, 1.2vw, 12.75pt);
  line-height: 1.55;
  transition: opacity 520ms var(--easing), transform 720ms var(--easing);
}

.home-card-body {
  display: grid;
  gap: 14px;
  max-width: 430px;
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  overflow: hidden;
  filter: blur(2px);
  transform: translateY(12px);
  transition: max-height 820ms var(--easing), margin-top 780ms var(--easing), opacity 560ms var(--easing), transform 780ms var(--easing), filter 560ms var(--easing);
}

.home-capabilities-grid .home-card-body {
  gap: 3px;
}

.home-capabilities-grid .solution-card:hover .home-card-body,
.home-capabilities-grid .solution-card:focus-within .home-card-body,
.home-value-grid .home-value-card:hover .home-card-body,
.home-value-grid .home-value-card:focus-within .home-card-body {
  max-height: 360px;
  margin-top: clamp(14px, 2vw, 22px);
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.home-card-body>p {
  color: var(--fg);
  font-size: clamp(9.75pt, 0.96vw, 11.25pt);
  line-height: 1.42;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 520ms var(--easing) 120ms, transform 680ms var(--easing) 120ms;
}

.home-card-points {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 1.1em;
  color: var(--muted);
  font-size: clamp(9pt, 0.9vw, 10.5pt);
  line-height: 1.32;
}

.home-card-points li {
  opacity: 0;
  padding-left: 0.1em;
  transform: translateY(8px);
  transition: opacity 520ms var(--easing), transform 680ms var(--easing);
}

.home-card-points li:nth-child(1) {
  transition-delay: 160ms;
}

.home-card-points li:nth-child(2) {
  transition-delay: 220ms;
}

.home-card-points li:nth-child(3) {
  transition-delay: 280ms;
}

.home-capabilities-grid .solution-card:hover .home-card-body>p,
.home-capabilities-grid .solution-card:focus-within .home-card-body>p,
.home-value-grid .home-value-card:hover .home-card-body>p,
.home-value-grid .home-value-card:focus-within .home-card-body>p,
.home-capabilities-grid .solution-card:hover .home-card-points li,
.home-capabilities-grid .solution-card:focus-within .home-card-points li,
.home-value-grid .home-value-card:hover .home-card-points li,
.home-value-grid .home-value-card:focus-within .home-card-points li {
  opacity: 1;
  transform: translateY(0);
}

.industry-list {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin: clamp(34px, 6vw, 70px) 0 0;
  padding: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
  list-style: none;
}

.industry-list li {
  min-height: 102px;
  display: grid;
  place-items: center;
  padding: 18px;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  font-size: clamp(10.5pt, 1.05vw, 12pt);
  font-weight: var(--weight-bold);
  line-height: 1.35;
  text-align: center;
}

.home-final-cta {
  display: grid;
  justify-items: center;
  gap: 18px;
  width: 100%;
  max-width: 1040px;
  margin: 0 auto;
  padding: 0;
  text-align: center;
}

.home-final-cta h2 {
  max-width: 780px;
  margin: 0;
  font-size: clamp(25.5pt, 5vw, 48pt);
  font-weight: var(--weight-bold);
  line-height: 1.02;
}

.page-shell[aria-label="Home"] .home-final-cta {
  max-width: 1180px;
}

.page-shell[aria-label="Home"] .home-final-cta h2 {
  max-width: min(1180px, 100%);
}

.home-final-title-line {
  display: block;
  overflow-wrap: break-word;
}

.home-final-title-line-nowrap {
  white-space: nowrap;
}

.home-final-cta p {
  max-width: 720px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(12pt, 1.35vw, 14.25pt);
  line-height: 1.55;
}

.home-final-cta .cta {
  margin-top: 8px;
}

.page-shell[aria-label="Home"]>.section.home-cta-section {
  row-gap: clamp(22px, 3vw, 34px);
  padding-bottom: clamp(128px, 12vw, 180px);
}

.home-cta-reveal .home-final-title-line,
.home-cta-reveal .home-final-cta p,
.home-cta-reveal .home-final-cta .cta,
.home-cta-reveal .home-final-cta .contact-channel-links {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 800ms var(--easing), transform 800ms var(--easing);
}

.home-cta-reveal .home-final-title-line {
  transform: translateY(0.7em);
  transition-duration: 680ms;
  transition-delay: calc(80ms + (var(--line) * 140ms));
}

.home-cta-reveal .home-final-cta p {
  transition-delay: 520ms;
}

.home-cta-reveal .home-final-cta .cta {
  transition-delay: 640ms;
}

.home-cta-reveal .home-final-cta .contact-channel-links {
  transition-delay: 760ms;
}

.home-cta-reveal.is-visible .home-final-title-line,
.home-cta-reveal.is-visible .home-final-cta p,
.home-cta-reveal.is-visible .home-final-cta .cta,
.home-cta-reveal.is-visible .home-final-cta .contact-channel-links {
  opacity: 1;
  transform: translateY(0);
}

.page-shell[aria-label="Our Focus"] {
  --focus-content-gap: clamp(34px, 5vw, 66px);
  --focus-sticky-offset: 25vh;
  --focus-principles-offset: calc(var(--focus-sticky-offset) + 5vh);
}

.page-shell[aria-label="Our Focus"]>.section {
  border-bottom: 0;
}

.page-shell[aria-label="Our Focus"] .focus-selection-section .focus-sticky-label {
  top: 0;
  min-height: 100vh;
  align-content: center;
  padding-top: 0;
}

.page-shell[aria-label="Our Focus"] .focus-selection-section .focus-principles {
  top: 0;
  min-height: 100vh;
  align-content: center;
  padding-top: 0;
  padding-bottom: 0;
}

.focus-hero {
  align-content: center;
  min-height: var(--page-hero-min);
  overflow: hidden;
  padding-top: var(--page-hero-padding-top);
  padding-bottom: var(--page-hero-padding-bottom);
}

.focus-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.58fr) minmax(320px, 0.42fr);
  gap: var(--page-hero-grid-gap);
  align-items: center;
  min-height: var(--page-hero-grid-min);
}

.focus-hero-content {
  position: relative;
  z-index: 2;
  display: grid;
  gap: var(--page-hero-content-gap);
  width: 100%;
  max-width: 900px;
  min-width: 0;
}

.focus-hero-marker {
  justify-self: start;
  text-align: left;
}

.focus-title {
  max-width: 880px;
  font-size: var(--page-title-size);
  line-height: var(--page-title-line-height);
}

.focus-hero-body {
  display: grid;
  gap: 0;
  width: 100%;
  max-width: none;
}

.focus-hero-copy {
  max-width: var(--page-copy-max);
  font-size: var(--page-copy-size);
  line-height: var(--page-copy-line-height);
  text-align: left;
  text-align-last: left;
}

.focus-hero-copy[data-line-reveal],
.about-hero-copy[data-line-reveal] {
  opacity: 0;
}

.focus-hero-copy[data-line-reveal].is-line-ready,
.about-hero-copy[data-line-reveal].is-line-ready {
  opacity: 1;
}

.focus-hero-copy .copy-line,
.about-hero-copy .copy-line {
  display: block;
  opacity: 0;
  transform: translateY(0.75em);
  animation: focusCopyLineIn 620ms var(--easing) forwards;
  animation-delay: calc(560ms + (var(--line) * 70ms));
  will-change: opacity, transform;
}

@keyframes focusCopyLineIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.focus-hero-lower {
  margin-top: clamp(50px, 6.7vw, 106px);
}

.focus-hero-tagline {
  margin: 0;
  color: var(--fg);
  font-size: clamp(25.5pt, 5vw, 46.5pt);
  font-weight: var(--weight-bold);
  line-height: 0.98;
}

.focus-lens-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(360px, 46vw, 620px);
  isolation: isolate;
  opacity: 0;
  transform: scale(0.96);
  animation: focusVisualIn 900ms var(--easing) forwards;
  animation-delay: 480ms;
  will-change: opacity, transform;
}

@keyframes focusVisualIn {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.focus-lens-map {
  --lens-x: 0px;
  --lens-y: 0px;
  position: relative;
  width: min(100%, 540px);
  aspect-ratio: 1;
  color: var(--fg);
  transform: scale(1);
  transition: transform 520ms var(--easing);
  will-change: transform;
}

.focus-lens-visual:hover .focus-lens-map,
.focus-lens-visual.is-cursor-linked .focus-lens-map {
  transform: scale(1.035);
}

.focus-lens-map::after {
  content: "";
  position: absolute;
  inset: 22%;
  border: 1px solid color-mix(in srgb, var(--fg) 16%, transparent);
  border-radius: 50%;
  opacity: 0.6;
  animation: focusAperture 6200ms var(--easing) infinite;
}

.focus-lens-aperture,
.focus-lens-reticle,
.focus-lens-sweep,
.focus-lens-target,
.focus-lens-node {
  position: absolute;
  pointer-events: none;
}

.focus-lens-aperture {
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 48%;
  aspect-ratio: 1;
  border: 1px solid color-mix(in srgb, var(--fg) 52%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--fg) 12%, transparent) 0 18%, transparent 19% 100%),
    radial-gradient(circle at 50% 50%, transparent 0 53%, color-mix(in srgb, var(--fg) 8%, transparent) 54% 56%, transparent 57%);
  transform: translate(calc(-50% + (var(--lens-x) * 0.32)), calc(-50% + (var(--lens-y) * 0.32)));
  transition: border-color 300ms var(--easing), transform 240ms var(--easing);
}

.focus-lens-target {
  top: 50%;
  left: 50%;
  z-index: 4;
  width: 22%;
  aspect-ratio: 1;
  border: 1px solid color-mix(in srgb, var(--fg) 62%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--fg) 78%, var(--bg)) 0 17%, transparent 18%),
    radial-gradient(circle at 50% 50%, transparent 0 45%, color-mix(in srgb, var(--fg) 18%, transparent) 46% 48%, transparent 49%);
  transform: translate(calc(-50% + var(--lens-x)), calc(-50% + var(--lens-y)));
  transition: transform 220ms var(--easing), box-shadow 360ms var(--easing), border-color 360ms var(--easing);
  box-shadow: 0 18px 54px color-mix(in srgb, var(--fg) 8%, transparent);
}

.focus-lens-visual:hover .focus-lens-target,
.focus-lens-visual.is-cursor-linked .focus-lens-target {
  border-color: color-mix(in srgb, var(--fg) 88%, transparent);
  box-shadow: 0 24px 76px color-mix(in srgb, var(--fg) 12%, transparent);
}

.focus-lens-reticle {
  z-index: 3;
  background: color-mix(in srgb, var(--fg) 24%, transparent);
  opacity: 0.76;
}

.focus-lens-reticle-x {
  top: 50%;
  right: 12%;
  left: 12%;
  height: 1px;
  transform: translateY(calc(var(--lens-y) * 0.55));
}

.focus-lens-reticle-y {
  top: 12%;
  bottom: 12%;
  left: 50%;
  width: 1px;
  transform: translateX(calc(var(--lens-x) * 0.55));
}

.focus-lens-sweep {
  z-index: 5;
  top: 50%;
  right: 13%;
  left: 13%;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--fg) 62%, transparent), transparent);
  opacity: 0.62;
  transform: translateY(calc(var(--lens-y) * 0.25));
  animation: focusSweep 5200ms ease-in-out infinite;
}

.focus-lens-node {
  z-index: 6;
  width: 11px;
  aspect-ratio: 1;
  border: 1px solid color-mix(in srgb, var(--fg) 24%, transparent);
  border-radius: 50%;
  background: color-mix(in srgb, var(--fg) 72%, var(--bg));
  box-shadow: 0 0 0 14px color-mix(in srgb, var(--fg) 5%, transparent);
  opacity: 0.62;
  filter: blur(0.6px);
  transition: opacity 360ms var(--easing), filter 360ms var(--easing), transform 360ms var(--easing);
}

.focus-lens-node-a {
  top: 28%;
  left: 26%;
  transform: translate(calc(var(--lens-x) * -0.24), calc(var(--lens-y) * -0.12));
  animation: focusNodePulse 7200ms ease-in-out infinite;
}

.focus-lens-node-b {
  top: 24%;
  right: 24%;
  transform: translate(calc(var(--lens-x) * 0.18), calc(var(--lens-y) * -0.2));
  animation: focusNodePulse 7600ms ease-in-out infinite 900ms;
}

.focus-lens-node-c {
  right: 26%;
  bottom: 26%;
  transform: translate(calc(var(--lens-x) * 0.22), calc(var(--lens-y) * 0.16));
  animation: focusNodePulse 7000ms ease-in-out infinite 1500ms;
}

.focus-lens-node-d {
  bottom: 30%;
  left: 24%;
  transform: translate(calc(var(--lens-x) * -0.18), calc(var(--lens-y) * 0.22));
  animation: focusNodePulse 8200ms ease-in-out infinite 500ms;
}

.focus-lens-visual:hover .focus-lens-node,
.focus-lens-visual.is-cursor-linked .focus-lens-node {
  opacity: 0.9;
  filter: blur(0);
}

@keyframes focusAperture {
  50% {
    opacity: 0.86;
    transform: scale(0.965);
  }
}

@keyframes focusSweep {

  0%,
  100% {
    opacity: 0.2;
    transform: translateY(calc(-76px + (var(--lens-y) * 0.25)));
  }

  50% {
    opacity: 0.74;
    transform: translateY(calc(76px + (var(--lens-y) * 0.25)));
  }
}

@keyframes focusNodePulse {
  50% {
    box-shadow: 0 0 0 20px color-mix(in srgb, var(--fg) 3%, transparent);
  }
}

.focus-section {
  display: grid;
  gap: var(--focus-content-gap);
}

.focus-selection-section {
  min-height: 160vh;
  align-content: start;
}

.focus-outcome-section {
  margin-top: -15vh;
  padding-top: clamp(24px, 3.92vw, 52px);
  padding-bottom: clamp(60px, 9.52vw, 132px);
}

.focus-grid {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
}

.focus-hero-list {
  margin-top: var(--title-box-gap);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  border: 0;
  border-radius: 0;
  overflow: visible;
}

.focus-hero-list .focus-card {
  --focus-row-pad: clamp(24px, 3.2vw, 36px);
  min-height: auto;
  grid-template-columns: 1fr;
  align-content: start;
  gap: 0;
  padding: clamp(18px, 2.2vw, 26px) clamp(26px, 3.6vw, 38px);
  position: relative;
  z-index: 1;
  height: 100%;
  min-height: clamp(162px, 9.6vw, 184px);
  background: var(--bg);
  border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  overflow: hidden;
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    padding 720ms var(--easing),
    background-color 720ms var(--easing),
    border-color 720ms var(--easing);
}

.focus-hero-list .focus-card+.focus-card {
  margin-left: -1px;
}

.focus-hero-list .focus-card:hover,
.focus-hero-list .focus-card:focus-within {
  z-index: 2;
}

.focus-hero-list .focus-card:hover,
.focus-hero-list .focus-card:focus-within {
  padding-top: clamp(18px, 2.2vw, 26px);
  padding-bottom: clamp(18px, 2.2vw, 26px);
  transform: none;
}

.focus-card {
  --focus-row-pad: clamp(28px, 4vw, 46px);
  min-height: auto;
  display: grid;
  grid-template-columns: 24px minmax(180px, 0.3fr) minmax(0, 0.7fr);
  gap: clamp(20px, 4vw, 58px);
  align-items: start;
  padding: var(--focus-row-pad) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    padding 680ms var(--easing),
    background-color 680ms var(--easing),
    border-color 680ms var(--easing);
}

.focus-card:hover,
.focus-card:focus-within {
  padding-top: calc(var(--focus-row-pad) + 6px);
  padding-bottom: calc(var(--focus-row-pad) + 6px);
  background: color-mix(in srgb, var(--fg) 2.5%, transparent);
}

.focus-card-heading {
  display: grid;
  gap: 16px;
}

.focus-hero-list .focus-card-heading {
  gap: clamp(12px, 1.5vw, 17px);
}

.focus-card h3 {
  margin: 0;
  font-size: clamp(16.5pt, 1.9vw, 22.5pt);
  font-weight: var(--weight-bold);
  line-height: 1.03;
  transform: translateX(0);
  transition: color 520ms var(--easing), transform 680ms var(--easing);
}

.focus-hero-list .focus-card h3 {
  max-width: 330px;
  font-size: clamp(16.5pt, 1.85vw, 22.5pt);
  line-height: 0.98;
}

.focus-card:hover h3,
.focus-card:focus-within h3 {
  transform: translateX(8px);
}

.focus-hero-list .focus-card:hover h3,
.focus-hero-list .focus-card:focus-within h3 {
  transform: translateX(0) translateY(-2px);
}

.focus-card-heading p {
  margin: 0;
  color: var(--muted);
  font-size: 10.5pt;
  font-weight: var(--weight-bold);
  letter-spacing: 0.02em;
  line-height: 1.4;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  filter: blur(2px);
  transform: translateY(10px);
  transition: max-height 760ms var(--easing), opacity 520ms var(--easing), transform 720ms var(--easing), filter 520ms var(--easing);
}

.focus-hero-list .focus-card-heading p {
  max-width: 360px;
  max-height: none;
  opacity: 1;
  overflow: visible;
  filter: none;
  transform: none;
  font-size: clamp(11.25pt, 1.18vw, 12.75pt);
  font-weight: var(--weight-regular);
  letter-spacing: 0;
  line-height: 1.48;
  transition: color 520ms var(--easing), transform 720ms var(--easing), opacity 520ms var(--easing);
}

.focus-hero-list .focus-card:hover .focus-card-heading p,
.focus-hero-list .focus-card:focus-within .focus-card-heading p {
  opacity: 1;
  transform: none;
}

.focus-card-body {
  display: grid;
  gap: 18px;
  max-width: 760px;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  filter: blur(2px);
  transform: translateY(12px);
  transition: max-height 820ms var(--easing), opacity 560ms var(--easing), transform 780ms var(--easing), filter 560ms var(--easing);
}

.focus-hero-list .focus-card-body {
  gap: 14px;
  max-width: 360px;
  margin-top: 0;
  transition: max-height 820ms var(--easing), opacity 560ms var(--easing), transform 780ms var(--easing), filter 560ms var(--easing), margin-top 780ms var(--easing);
}

.focus-card:hover .focus-card-heading p,
.focus-card:focus-within .focus-card-heading p {
  max-height: 72px;
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.focus-card:hover .focus-card-body,
.focus-card:focus-within .focus-card-body {
  max-height: 300px;
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.focus-hero-list .focus-card:hover .focus-card-body,
.focus-hero-list .focus-card:focus-within .focus-card-body {
  max-height: 0;
  margin-top: 0;
}

.focus-card p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(11.25pt, 1.15vw, 12.75pt);
  line-height: 1.52;
}

.focus-card-body>p {
  color: var(--fg);
  font-size: clamp(9.75pt, 0.96vw, 11.25pt);
  line-height: 1.42;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 520ms var(--easing) 120ms, transform 680ms var(--easing) 120ms;
}

.focus-card:hover .focus-card-body>p,
.focus-card:focus-within .focus-card-body>p {
  opacity: 1;
  transform: translateY(0);
}

.focus-card .focus-card-heading p {
  font-size: 10.5pt;
  font-weight: var(--weight-bold);
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.focus-hero-list .focus-card .focus-card-heading p {
  font-size: clamp(11.25pt, 1.18vw, 12.75pt);
  font-weight: var(--weight-regular);
  letter-spacing: 0;
  line-height: 1.48;
}

.focus-card-points {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 1.1em;
  list-style: disc;
  color: var(--muted);
  font-size: clamp(9pt, 0.9vw, 10.5pt);
  line-height: 1.32;
}

.focus-card-points li {
  opacity: 0;
  padding-left: 0.1em;
  transform: translateY(8px);
  transition: opacity 520ms var(--easing), transform 680ms var(--easing);
}

.focus-card-points li:nth-child(1) {
  transition-delay: 160ms;
}

.focus-card-points li:nth-child(2) {
  transition-delay: 220ms;
}

.focus-card-points li:nth-child(3) {
  transition-delay: 280ms;
}

.focus-card:hover .focus-card-points li,
.focus-card:focus-within .focus-card-points li {
  opacity: 1;
  transform: translateY(0);
}

.focus-operating-grid {
  display: grid;
  grid-template-columns: minmax(270px, 0.36fr) minmax(0, 0.64fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}

.focus-selection-section .focus-operating-grid {
  min-height: 140.8vh;
}

.focus-sticky-label {
  position: sticky;
  top: var(--nav-h);
  display: grid;
  gap: clamp(28px, 4vw, 56px);
  align-self: start;
  min-height: calc(100vh - var(--nav-h));
  align-content: start;
  padding-top: var(--focus-sticky-offset);
}

.focus-sticky-label h2 {
  max-width: 500px;
  margin: 0;
  font-size: clamp(33pt, 5vw, 57pt);
  font-weight: var(--weight-bold);
  line-height: 0.98;
}

.focus-sticky-label h2 span {
  color: #0d0d0d;
}

/* Typewriter animation */
[data-typewriter] {
  color: #0d0d0d;
}

html[data-theme="dark"] [data-typewriter] {
  color: #F2F2F2;
}

.tw-word {
  display: inline-block;
  white-space: nowrap;
}

.tw-char {
  display: inline;
  opacity: 0;
  transition: opacity 80ms var(--easing);
  transition-delay: calc(var(--ci) * 70ms);
}

.tw-ready {
  position: relative;
  overflow: visible;
}

.tw-active .tw-char {
  opacity: 1;
}

.tw-cursor {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 3px;
  height: var(--tw-cursor-height, 0.85em);
  margin-left: 4px;
  background: #0d0d0d;
  transform: translate3d(var(--tw-cursor-x, 0px), var(--tw-cursor-y, 0px), 0);
  opacity: 0;
  pointer-events: none;
  animation: twCursorBlink 600ms step-end infinite;
  animation-delay: 200ms;
  transition: transform 70ms linear;
}

html[data-theme="dark"] .tw-cursor {
  background: #F2F2F2;
}

[data-typewriter].tw-active .tw-cursor {
  opacity: 1;
  animation: twCursorBlink 600ms step-end infinite, twCursorFade 400ms var(--easing) forwards;
  animation-delay: var(--tw-duration, 4200ms), calc(var(--tw-duration, 4200ms) + 1200ms);
}

@keyframes twCursorBlink {
  50% {
    opacity: 0;
  }
}

@keyframes twCursorFade {
  to {
    opacity: 0;
    display: none;
  }
}

.focus-principles {
  position: sticky;
  top: var(--nav-h);
  display: grid;
  align-content: start;
  gap: clamp(34px, 6vh, 56px);
  min-height: calc(100vh - var(--nav-h));
  padding-top: var(--focus-principles-offset);
  padding-bottom: 0;
  border-bottom: 0;
}

.focus-principle {
  --focus-principle-release-y: 0px;
  --focus-principle-reveal-y: 32px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: start;
  justify-content: flex-start;
  min-height: auto;
  padding: 0;
  overflow: visible;
  border: 0;
  border-radius: 0;
  background: var(--bg);
  box-shadow: none;
  transform: translateY(calc(var(--focus-principle-release-y) + var(--focus-principle-reveal-y)));
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms);
}

.focus-principle.is-visible {
  --focus-principle-reveal-y: 0px;
}

.focus-principle-title {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0;
  max-width: none;
  font-size: clamp(16.5pt, 2vw, 24pt);
  font-weight: var(--weight-bold);
  line-height: 0.98;
  white-space: nowrap;
}

.focus-principle p {
  width: 100%;
  max-width: none;
  margin: 10px 0 0;
  padding-left: 22px;
  border-left: 0;
  color: var(--muted);
  font-size: clamp(11.25pt, 1.18vw, 14.25pt);
  line-height: 1.5;
}

.focus-principle-dot {
  display: inline-block;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--fg);
  opacity: 0;
  transform: scale(0.5);
  transition:
    opacity 600ms var(--easing),
    transform 600ms var(--easing);
}

.focus-principle.is-visible .focus-principle-dot {
  opacity: 1;
  transform: scale(1);
}

.focus-outcome-panel {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  padding: clamp(19px, 2.8vw, 39px) 0 clamp(49px, 7.2vw, 101px);
}

.focus-outcome-copy {
  display: grid;
  gap: 24px;
  width: min(100%, 980px);
  max-width: 980px;
  justify-self: center;
}

.focus-outcome-copy h2 {
  margin: 0;
  font-size: clamp(22.5pt, 4vw, 40.5pt);
  font-weight: var(--weight-bold);
  line-height: 1.06;
  text-align: center;
}

.focus-outcome-copy [data-line-reveal] {
  opacity: 0;
}

.focus-outcome-copy [data-line-reveal].is-line-ready {
  opacity: 1;
}

.focus-outcome-copy .copy-line {
  display: block;
  opacity: 0;
  transform: translateY(0.7em);
  will-change: opacity, transform;
}

.focus-outcome-panel.is-visible .focus-outcome-copy .copy-line {
  animation: focusCopyLineIn 640ms var(--easing) forwards;
  animation-delay: calc(420ms + (var(--line) * 110ms));
}

.focus-outcome-copy p {
  justify-self: center;
  max-width: 650px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(12.75pt, 1.55vw, 15.75pt);
  line-height: 1.48;
  text-align: center;
}

.focus-outcome-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: clamp(12px, 2vw, 24px);
  border: 1px solid var(--rule);
  opacity: 0;
  transform: translateY(22px);
  transition:
    opacity 720ms var(--easing) 560ms,
    transform 720ms var(--easing) 560ms;
  will-change: opacity, transform;
}

.focus-outcome-list span {
  min-height: 76px;
  display: grid;
  align-items: center;
  justify-items: center;
  padding: 12px 18px;
  color: var(--fg);
  font-size: clamp(12.75pt, 1.45vw, 15.75pt);
  font-weight: var(--weight-bold);
  line-height: 1.12;
  text-align: center;
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity 640ms var(--easing) var(--delay, calc(760ms + (var(--metric-index, 0) * 130ms))),
    transform 640ms var(--easing) var(--delay, calc(760ms + (var(--metric-index, 0) * 130ms)));
  will-change: opacity, transform;
}

.focus-outcome-list span:nth-child(1) {
  --metric-index: 0;
}

.focus-outcome-list span:nth-child(2) {
  --metric-index: 1;
}

.focus-outcome-list span:nth-child(3) {
  --metric-index: 2;
}

.focus-outcome-panel.is-visible .focus-outcome-list,
.focus-outcome-panel.is-visible .focus-outcome-list span {
  opacity: 1;
  transform: translateY(0);
}

.focus-outcome-list span+span {
  border-left: 1px solid var(--rule);
}

.product-logo-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
  transform: scale(1.018);
}

.product-detail-logo-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  border-radius: 0;
}

.product-detail-page {
  --product-open-duration: 760ms;
  --product-open-step: 80ms;
}

.product-detail-page .product-cover,
.product-detail-page .product-document-logo,
.product-detail-page .product-document-topbar>.product-tag-list,
.product-detail-page .product-document-topbar .product-action-row,
.product-detail-page .product-document-shell,
.product-detail-page .product-info-block {
  opacity: 0;
  transition-duration: var(--product-open-duration);
  transition-timing-function: var(--easing);
  transition-property: opacity, transform, width, height, background-color, padding, box-shadow;
}

.product-detail-page .product-cover {
  transform: translateY(-18px);
  transform-origin: top center;
}

.product-detail-page .product-document-logo {
  transform: translateY(18px) scale(0.94);
  transform-origin: top left;
  transition-delay: calc(var(--product-open-step) * 1);
}

.product-detail-page .product-document-topbar>.product-tag-list {
  transform: translateY(14px);
  transition-delay: calc(var(--product-open-step) * 2);
}

.product-detail-page .product-document-topbar .product-action-row {
  transform: translateY(-10px);
  transition-delay: calc(var(--product-open-step) * 2);
}

.product-detail-page .product-document-shell {
  transform: translateY(20px);
  transition-delay: calc(var(--product-open-step) * 3);
}

.product-detail-page .product-info-block {
  transform: translateY(22px);
  transition-delay: calc(var(--product-open-step) * (4 + var(--info-index, 0)));
}

.product-detail-page .product-info-block:nth-child(1) {
  --info-index: 0;
}

.product-detail-page .product-info-block:nth-child(2) {
  --info-index: 1;
}

.product-detail-page .product-info-block:nth-child(3) {
  --info-index: 2;
}

.product-detail-page .product-info-block:nth-child(4) {
  --info-index: 3;
}

.product-detail-page .product-info-block:nth-child(5) {
  --info-index: 4;
}

.product-detail-page .product-info-block:nth-child(6) {
  --info-index: 5;
}

.product-detail-page.is-product-open .product-cover,
.product-detail-page.is-product-open .product-document-logo,
.product-detail-page.is-product-open .product-document-topbar>.product-tag-list,
.product-detail-page.is-product-open .product-document-topbar .product-action-row,
.product-detail-page.is-product-open .product-document-shell,
.product-detail-page.is-product-open .product-info-block {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  .product-detail-page .product-cover,
  .product-detail-page .product-document-logo,
  .product-detail-page .product-document-topbar>.product-tag-list,
  .product-detail-page .product-document-topbar .product-action-row,
  .product-detail-page .product-document-shell,
  .product-detail-page .product-info-block {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

.product-cover-section {
  position: relative;
  overflow: hidden;
  border-bottom: 0;
  background: #f2f2f2;
  transform: translateZ(0);
  contain: layout style;
}

.product-cover {
  position: relative;
  width: 100%;
  min-height: 0;
  height: clamp(165px, 18.75vw, 293px);
  display: grid;
  align-items: center;
  padding: clamp(28px, 4vw, 58px) var(--page-pad);
  border-bottom: 1px solid var(--rule);
  color: #0d0d0d;
  isolation: isolate;
  will-change: height, opacity;
  transition: opacity 760ms var(--easing), transform 760ms var(--easing), height 520ms var(--easing), background-color 520ms var(--easing), padding 520ms var(--easing);
}

.product-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(242, 242, 242, 0.96) 0%, rgba(242, 242, 242, 0.82) 34%, rgba(242, 242, 242, 0.34) 62%, rgba(242, 242, 242, 0.08) 100%);
  pointer-events: none;
  transition: opacity 360ms var(--easing);
}

.product-cover-image {
  position: absolute;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  object-position: center;
  will-change: transform, opacity;
  transform: translateZ(0);
  transition: opacity 360ms var(--easing);
}

.product-cover-video {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #000;
  object-fit: contain;
  opacity: 0;
  visibility: hidden;
  will-change: transform, opacity;
  transform: translateZ(0);
  transition: opacity 360ms var(--easing), visibility 0s linear 360ms;
}

.product-cover.is-playing-intro-video {
  height: min(clamp(260px, 56.25vw, 720px), max(260px, calc(100vh - 210px)));
  padding: 0;
  background: #000;
}

.product-cover.is-playing-intro-video::before,
.product-cover.is-playing-intro-video .product-cover-image {
  opacity: 0;
}

.product-cover.is-playing-intro-video .product-cover-video {
  opacity: 1;
  visibility: visible;
  transition-delay: 0s;
}

.product-document-hero {
  --product-action-edge-gap: clamp(12px, 2vw, 32px);
  position: relative;
  min-height: auto;
  padding-top: 0;
  padding-bottom: clamp(72px, 9vw, 132px);
  border-bottom: 0;
  display: grid;
  gap: clamp(9px, 1.2vw, 17px);
}

.product-document-topbar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: clamp(18px, 3vw, 48px);
  width: 100%;
  min-width: 0;
  transition: gap 520ms var(--easing);
}

.product-document-shell {
  display: grid;
  gap: var(--product-title-copy-gap, clamp(7px, 1vw, 12px));
  width: 100%;
  max-width: none;
}

.product-document-logo {
  width: clamp(112px, 12vw, 166px);
  aspect-ratio: 1;
  margin-top: calc(clamp(56px, 7vw, 92px) * -1);
  overflow: hidden;
  border: 0;
  border-radius: 0;
  background: var(--fg);
  box-shadow: 0 0 0 1.6px var(--bg);
  transition: opacity 760ms var(--easing), transform 760ms var(--easing), width 520ms var(--easing), box-shadow 520ms var(--easing);
}

.product-detail-page.is-intro-video-open .product-document-logo {
  width: clamp(88px, 8vw, 124px);
}

.product-mobile-tags {
  display: none;
}

.product-title {
  max-width: min(640px, 100%);
  font-size: clamp(25.5pt, 4.2vw, 48pt);
  font-weight: var(--weight-bold);
  line-height: 1;
  text-transform: none;
}

.detail-overview {
  max-width: none;
  margin: 0;
  color: var(--muted);
  font-family: var(--font-body);
  font-size: var(--section-copy-size);
  line-height: var(--section-copy-line-height);
}

.product-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin: clamp(10px, 1.2vw, 18px) 0 0;
  padding: 0;
  color: var(--fg);
  font-size: clamp(9.75pt, 0.95vw, 12pt);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wider);
  line-height: 1.2;
  list-style: none;
}

.product-tag-list li {
  display: inline-flex;
  align-items: center;
}

.product-tag-list li+li::before {
  content: "";
  width: 4px;
  height: 4px;
  margin: 0 clamp(10px, 1.1vw, 16px);
  border-radius: 50%;
  background: currentColor;
  opacity: 0.42;
}

.product-document-topbar>.product-tag-list {
  grid-column: 2;
  grid-row: 1;
  align-self: center;
  justify-self: start;
  max-width: 100%;
  margin: 0;
}

.product-info-stack {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(26px, 4vw, 56px);
  width: 100%;
  max-width: none;
  margin-top: clamp(30px, 5vw, 72px);
}

.product-info-block {
  display: grid;
  align-content: start;
  gap: clamp(8px, 1.1vw, 14px);
}

.product-info-block h2 {
  display: flex;
  align-items: baseline;
  gap: clamp(10px, 1.2vw, 16px);
  margin: 0;
  color: var(--fg);
  font-size: clamp(16.5pt, 2vw, 25.5pt);
  font-weight: var(--weight-bold);
  line-height: 1.04;
}

.product-info-dot {
  width: 0.24em;
  height: 0.24em;
  border-radius: 50%;
  background: var(--fg);
  flex: 0 0 auto;
  transform: translateY(-0.12em);
}

.product-info-subtitle {
  max-width: none;
  margin: 0;
  color: var(--fg);
  font-size: clamp(11.25pt, 1.1vw, 13.5pt);
  font-weight: var(--weight-medium);
  line-height: 1.45;
}

.product-info-copy {
  max-width: none;
  margin: 0;
  color: var(--muted);
  font-family: var(--font-body);
  font-size: clamp(10.5pt, 1vw, 12.75pt);
  line-height: 1.58;
}

.product-info-points {
  display: grid;
  gap: 8px;
  margin: clamp(4px, 0.7vw, 8px) 0 0;
  padding-left: 1.15em;
  color: var(--muted);
  font-family: var(--font-body);
  font-size: clamp(10.5pt, 1vw, 12.75pt);
  line-height: 1.5;
}

.product-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: clamp(4px, 1vw, 12px);
}

.product-document-topbar .product-action-row {
  grid-column: 3;
  grid-row: 1;
  align-self: start;
  justify-self: end;
  justify-content: flex-end;
  margin-top: var(--product-action-edge-gap);
  transform: none;
}

.product-action {
  appearance: none;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 clamp(14px, 1.5vw, 22px);
  border: 1px solid var(--fg);
  border-radius: 6px;
  background: var(--fg);
  color: var(--bg);
  font-family: var(--font-base);
  font-size: clamp(9.75pt, 0.9vw, 11.25pt);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wider);
  line-height: 1;
  text-transform: none;
  overflow: hidden;
  transition: transform 300ms var(--easing), background-color 300ms var(--easing), color 300ms var(--easing), border-color 300ms var(--easing);
}

.product-action[data-intro-video-trigger] {
  min-width: clamp(138px, 12vw, 166px);
}

.product-action-label {
  display: inline-block;
  transition: opacity 180ms ease, transform 220ms var(--easing);
  will-change: opacity, transform;
}

.product-action.is-changing-label .product-action-label {
  opacity: 0;
  transform: translateY(0.45em);
}

.product-action:hover,
.product-action:focus-visible {
  transform: translateY(-2px);
  background: var(--bg);
  color: var(--fg);
  border-color: var(--fg);
}

.product-action-primary {
  background: var(--fg);
  color: var(--bg);
}

@media (max-width: 1180px) and (min-width: 901px) {
  .product-document-hero {
    --product-action-edge-gap: clamp(14px, 2vw, 22px);
  }

  .product-document-topbar {
    grid-template-columns: auto minmax(0, 1fr) max-content;
    gap: clamp(14px, 2vw, 24px);
  }

  .product-document-topbar>.product-tag-list {
    align-self: start;
    margin-top: var(--product-action-edge-gap);
    font-size: clamp(8.4pt, 1.05vw, 10.2pt);
  }

  .product-document-topbar .product-action-row {
    grid-column: 3;
    grid-row: 1;
    align-self: start;
    justify-self: end;
    gap: 8px;
    max-width: 100%;
    margin-top: var(--product-action-edge-gap);
  }

  .product-document-topbar .product-action {
    min-height: 42px;
    padding-right: clamp(10px, 1.2vw, 14px);
    padding-left: clamp(10px, 1.2vw, 14px);
    font-size: clamp(8.4pt, 1vw, 9.75pt);
  }

  .product-document-topbar .product-action[data-intro-video-trigger] {
    min-width: clamp(124px, 13vw, 144px);
  }
}

.site-footer {
  padding: clamp(28px, 5vw, 54px) var(--page-pad) 0;
  background-color: var(--fg);
  color: var(--bg);
  transition: background-color 600ms var(--easing), color 600ms var(--easing);
}

.footer-primary {
  display: grid;
  grid-template-columns: minmax(220px, 0.42fr) minmax(320px, 0.58fr);
  gap: clamp(28px, 6vw, 86px);
  align-items: start;
}

.footer-brand {
  position: relative;
  display: block;
  width: clamp(150px, 16vw, 230px);
  height: 34px;
  margin-bottom: 4px;
  overflow: hidden;
}

.footer-logo {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: auto;
  max-height: 34px;
  object-fit: contain;
  object-position: left center;
  opacity: 0;
  transform: translateY(-50%);
  transition: opacity 450ms var(--easing);
}

.footer-logo--light-theme {
  opacity: 1;
}

html[data-theme="dark"] .footer-logo--light-theme {
  opacity: 0;
}

html[data-theme="dark"] .footer-logo--dark-theme {
  opacity: 1;
}

.footer-statement {
  max-width: 420px;
  margin: 0;
  font-size: clamp(12.75pt, 1.7vw, 16.5pt);
  font-weight: var(--weight-medium);
  line-height: 1.25;
  opacity: 0.72;
}

.footer-groups {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(20px, 3vw, 44px);
}

.footer-group {
  display: grid;
  align-content: start;
  gap: 12px;
}

.footer-group h2 {
  margin: 0 0 8px;
  color: inherit;
  font-size: 9.75pt;
  font-weight: var(--weight-bold);
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
  opacity: 0.62;
}

.footer-group a,
.footer-bottom a {
  width: max-content;
  max-width: 100%;
  color: inherit;
  font-size: 12pt;
  font-weight: var(--weight-bold);
  line-height: 1.2;
  overflow-wrap: anywhere;
  text-decoration: none;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.22em;
}

.footer-group a:hover,
.footer-bottom a:hover {
  text-decoration-line: underline;
}

.footer-bottom {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-top: clamp(28px, 5vw, 54px);
  padding-top: clamp(8px, 1.2vw, 13px);
  padding-bottom: clamp(8px, 1.2vw, 13px);
  color: inherit;
}

.footer-bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  width: 100vw;
  height: 1px;
  background: color-mix(in srgb, var(--bg) 24%, transparent);
  transform: translateX(-50%);
}

.footer-bottom p {
  margin: 0;
  font-size: 10.5pt;
  font-weight: var(--weight-bold);
  line-height: 1.2;
  opacity: 0.62;
}

.footer-contact {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 0;
}

.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 800ms var(--easing), transform 800ms var(--easing);
  transition-delay: var(--delay, 0ms);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.focus-selection-section .focus-principle.reveal,
.focus-selection-section .focus-principle.reveal.is-visible {
  transform: translateY(calc(var(--focus-principle-release-y) + var(--focus-principle-reveal-y)));
}

.reveal-grid {
  --grid-line-alpha: 0;
  transition: --grid-line-alpha 800ms var(--easing);
}

.reveal-grid.is-visible {
  --grid-line-alpha: 1;
}

.top-fade-target {
  transition: opacity 110ms ease, transform 110ms ease;
  will-change: opacity, transform;
}

.top-fade-target.is-near-nav {
  opacity: 0;
  transform: translateY(-10px);
}

.mobile-panel {
  display: none;
}

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

@media (max-width: 1180px) {

  .hero-title.home-tagline,
  .focus-title,
  .focus-hero-tagline,
  .about-title,
  .contact-title,
  .products-showcase-title {
    font-size: clamp(24pt, 5vw, 40.5pt);
  }

  .focus-operating-grid {
    grid-template-columns: minmax(220px, 0.36fr) minmax(0, 0.64fr);
    gap: clamp(28px, 4vw, 56px);
  }

  .focus-principle {
    min-height: 28.8vh;
  }

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

  .solutions-grid .solution-card {
    border-top: 0;
    border-left: 0;
  }

  .solutions-grid .solution-card:nth-child(-n + 2) {
    border-top: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .solutions-grid .solution-card:nth-child(odd) {
    border-left: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .home-capabilities-grid .solution-card {
    margin-top: 0;
    margin-left: 0;
    border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .home-capabilities-grid .solution-card:nth-child(even) {
    margin-left: -1px;
  }

  .home-capabilities-grid .solution-card:nth-child(n + 3) {
    margin-top: -1px;
  }

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

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

  .focus-hero-list .focus-card:nth-child(odd) {
    margin-left: 0;
  }

  .focus-hero-list .focus-card:nth-child(n + 3) {
    margin-top: -1px;
  }
}

@media (max-width: 900px) {
  .site-nav {
    grid-template-columns: 1fr auto;
  }

  .page-shell[aria-label="Home"]>.section.home-cta-section {
    padding-bottom: clamp(38px, 8vw, 54px);
  }

  .page-shell[aria-label="Home"] .home-final-cta .cta {
    margin-bottom: clamp(22px, 5vw, 34px);
  }

  .page-shell[aria-label="About Us"] .home-cta-section {
    padding-bottom: 14vh;
  }

  .nav-actions .nav-link,
  .nav-actions .nav-active-indicator {
    display: none;
  }

  .menu-button {
    display: inline-grid;
  }

  .mobile-panel {
    position: fixed;
    inset: var(--nav-h) 0 auto 0;
    z-index: 45;
    display: grid;
    gap: 0;
    padding: 0 var(--nav-pad);
    border-bottom: 1px solid var(--nav-rule);
    background: var(--nav);
    color: var(--nav-fg);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-12px);
    transition: opacity 360ms var(--easing), transform 360ms var(--easing);
  }

  body.menu-open .mobile-panel {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .mobile-panel .nav-link {
    width: 100%;
    min-width: 0;
    height: auto;
    justify-content: flex-start;
    padding: 20px clamp(12px, 4vw, 18px);
    border-bottom: 1px solid var(--nav-rule);
    font-size: 17.5pt;
    font-weight: var(--weight-regular);
    color: var(--nav-fg);
    opacity: 0.6;
    background: transparent;
  }

  .mobile-panel .nav-link::after {
    content: "";
    width: 0.28em;
    height: 0.28em;
    margin-left: auto;
    border-radius: 50%;
    background: currentColor;
    opacity: 0;
    transform: scale(0.8);
    transition: opacity 260ms var(--easing), transform 260ms var(--easing);
  }

  .mobile-panel .nav-label,
  .mobile-panel .nav-link.is-active .nav-label {
    transform: none;
  }

  .mobile-panel .nav-link.is-active {
    height: auto;
    align-self: auto;
    background: transparent;
    color: var(--nav-fg);
    opacity: 1;
    font-weight: var(--weight-bold);
    border-radius: 0;
  }

  .mobile-panel .nav-link.is-active .nav-label {
    font-weight: var(--weight-bold);
  }

  .mobile-panel .nav-link.is-active::after {
    opacity: 1;
    transform: scale(1);
  }

  .home-hero-grid,
  .focus-hero-grid,
  .focus-operating-grid,
  .focus-outcome-panel {
    grid-template-columns: 1fr;
  }

  .product-cover {
    height: clamp(210px, 30vw, 320px);
  }

  .hero {
    min-height: auto;
  }

  .home-hero-grid {
    min-height: auto;
  }

  .hero-title.home-tagline,
  .focus-title,
  .focus-hero-tagline,
  .about-title,
  .contact-title,
  .products-showcase-title {
    font-size: clamp(22.5pt, 5.8vw, 33pt);
  }

  .home-system-visual {
    min-height: 390px;
  }

  .focus-hero {
    min-height: auto;
  }

  .focus-hero-grid {
    min-height: auto;
  }

  .focus-hero-content {
    max-width: none;
  }

  .focus-hero-copy {
    max-width: none;
  }

  .focus-lens-visual {
    min-height: 360px;
  }

  .focus-lens-map {
    width: min(100%, 430px);
  }

  .focus-hero-lower {
    margin-top: clamp(32px, 5.6vw, 52px);
  }

  .focus-selection-section {
    min-height: auto;
  }

  .focus-selection-section .focus-operating-grid {
    min-height: auto;
  }

  .focus-outcome-section {
    margin-top: 0;
  }

  .focus-sticky-label {
    position: static;
    min-height: auto;
    transform: none !important;
  }

  .focus-sticky-label h2 {
    max-width: 430px;
    font-size: clamp(34.5pt, 8vw, 48pt);
  }

  .focus-principles {
    position: static;
    grid-template-rows: none;
    gap: clamp(28px, 6vw, 48px);
    min-height: auto;
    padding-top: 0;
    padding-bottom: 0;
    border-bottom: 0;
  }

  .focus-principle {
    position: static;
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: auto;
    justify-content: flex-start;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .focus-principle-title {
    font-size: clamp(18pt, 3.4vw, 24pt);
  }

  .focus-principle p {
    max-width: none;
    margin-top: 8px;
    padding-left: 0;
    border-left: 0;
    font-size: clamp(12pt, 2.2vw, 15pt);
  }

  .focus-card {
    grid-template-columns: 1fr;
  }

  .focus-card {
    gap: 18px;
  }

  .focus-hero-list {
    grid-template-columns: 1fr;
  }

  .focus-hero-list .focus-card {
    min-height: auto;
  }

  .focus-hero-list .focus-card+.focus-card {
    margin-top: -1px;
    margin-left: 0;
  }

  .focus-card-heading p,
  .focus-card-body {
    filter: none;
    max-height: none;
    opacity: 1;
    overflow: visible;
    transform: none;
  }

  .focus-card-body>p,
  .focus-card-points li {
    opacity: 1;
    transform: none;
  }

  .focus-outcome-list {
    grid-template-columns: 1fr;
  }

  .focus-outcome-list span+span {
    border-top: 1px solid var(--rule);
    border-left: 0;
  }

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

  .home-value-grid {
    grid-template-columns: 1fr;
  }

  .home-value-card {
    min-height: auto;
    margin-top: 0;
    margin-left: 0;
    border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .home-value-grid .home-value-card+.home-value-card {
    margin-top: -1px;
    margin-left: 0;
  }

  .home-card-body {
    max-height: none;
    margin-top: 14px;
    opacity: 1;
    overflow: visible;
    filter: none;
    transform: none;
  }

  .home-card-body>p,
  .home-card-points li {
    opacity: 1;
    transform: none;
  }

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

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

@media (max-width: 600px) {
  :root {
    --nav-h: 56px;
    --page-pad: 20px;
    --page-hero-padding-top: 38px;
    --page-hero-padding-bottom: 42px;
    --page-hero-content-gap: 12px;
  }

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  .site-nav {
    gap: 10px;
    width: 100%;
    padding-right: 10px;
  }

  .brand {
    width: 136px;
    height: 40px;
  }

  .brand[data-theme-hint]::after {
    display: none;
  }

  .nav-actions {
    overflow: visible;
  }

  .menu-button {
    color: var(--nav-fg);
  }

  .brand-logo {
    max-height: 32px;
  }

  .menu-button {
    width: 34px;
    height: 34px;
  }

  .section {
    padding-top: 34px;
    padding-bottom: 34px;
    overflow: visible;
  }

  .page-shell[aria-label="Home"] {
    --home-section-min: auto;
    --home-divider-gap: 48px;
    --title-box-gap: 16px;
    --home-content-gap: var(--title-box-gap);
  }

  .page-shell[aria-label="Home"]>.section:not(.home-hero) {
    min-height: auto;
    align-content: start;
  }

  .page-shell[aria-label="Home"] #home-capabilities {
    scroll-margin-top: var(--nav-h);
    padding-top: 0;
    padding-bottom: 10px;
    overflow: visible;
  }

  .hero {
    padding-top: 14px;
  }

  .home-hero {
    min-height: calc(100svh - var(--nav-h));
    align-content: center;
    padding-top: 28px;
    padding-bottom: 28px;
  }

  .home-hero-grid {
    gap: 18px;
    width: 100%;
    min-width: 0;
    overflow: hidden;
  }

  .home-hero-copy {
    max-width: 100%;
  }

  .hero-copy {
    font-size: clamp(11.25pt, 3.8vw, 12.75pt);
    line-height: 1.58;
  }

  .hero-title.home-tagline,
  .focus-title,
  .about-title,
  .contact-title,
  .products-showcase-title {
    max-width: 100%;
    font-size: clamp(20pt, 7.6vw, 24pt);
    line-height: 1.08;
    overflow-wrap: anywhere;
  }

  .home-tagline-line {
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .home-system-visual {
    min-height: 230px;
    max-height: 34vh;
    overflow: hidden;
  }

  .system-map {
    --system-core-size: 128px;
    --system-core-ring-size: 69.12px;
    width: min(100%, 270px);
  }

  .system-node {
    min-width: 76px;
    min-height: 36px;
    padding: 0 12px;
    font-size: var(--text-xs);
  }

  .system-node-primary {
    width: 128px;
    min-height: 128px;
  }

  .hero-actions {
    gap: 10px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
  }

  .hero-actions .cta,
  .contact-submit .cta {
    width: 100%;
    min-height: 37px;
    justify-content: center;
    padding: 0 10px;
    font-size: clamp(7.3pt, 2.6vw, 8.1pt);
    letter-spacing: 0;
    white-space: nowrap;
  }

  .home-section-title,
  .contact-form-title {
    font-size: clamp(23pt, 8.4vw, 27pt);
    line-height: 1.02;
  }

  .home-section-lede {
    gap: 8px;
    margin-bottom: 8px;
  }

  .products-showcase-title {
    font-size: clamp(22.5pt, 8vw, 25.5pt);
    line-height: 1.05;
  }

  .focus-hero-content {
    gap: var(--page-hero-content-gap);
  }

  .focus-hero-grid {
    gap: 18px;
  }

  .focus-hero-tagline {
    font-size: clamp(22.5pt, 5.8vw, 33pt);
  }

  .focus-sticky-label {
    gap: 22px;
  }

  .focus-sticky-label h2 {
    font-size: clamp(28.5pt, 12vw, 42pt);
  }

  .focus-principle {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .focus-principle-title {
    max-width: none;
  }

  .page-shell[aria-label="Our Focus"] .focus-principle p {
    padding-left: 22px;
  }

  .focus-lens-visual {
    min-height: 220px;
  }

  .focus-lens-map {
    width: min(100%, 280px);
  }

  .focus-hero-lower {
    margin-top: 8px;
  }

  .page-shell[aria-label="Our Focus"] .focus-hero {
    gap: 22px;
    padding-top: 38px;
    padding-bottom: 8px;
  }

  .page-shell[aria-label="Our Focus"] .focus-selection-section {
    padding-top: 28px;
  }

  .page-shell[aria-label="Our Focus"] .focus-selection-section .focus-sticky-label,
  .page-shell[aria-label="Our Focus"] .focus-selection-section .focus-principles {
    min-height: auto;
    align-content: start;
    padding-top: 0;
    padding-bottom: 0;
  }

  .page-shell[aria-label="Our Focus"] .focus-sticky-label h2 {
    max-width: none;
    font-size: clamp(22.5pt, 5.8vw, 33pt);
    font-weight: var(--weight-bold);
    line-height: 0.98;
    white-space: nowrap;
  }

  .page-shell[aria-label="Our Focus"] .focus-sticky-label h2[data-typewriter],
  .page-shell[aria-label="Our Focus"] .focus-sticky-label h2 .tw-word,
  .page-shell[aria-label="Our Focus"] .focus-sticky-label h2 .tw-char {
    color: var(--fg);
  }

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

  .focus-card {
    min-height: auto;
  }

  .focus-outcome-copy h2 {
    font-size: 25.5pt;
  }

  .solutions-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    width: 100%;
    margin-top: 12px;
    overflow: visible;
  }

  .solution-card {
    min-height: auto;
    padding: clamp(16px, 4.5vw, 24px);
  }

  .solutions-grid .solution-card {
    border-top: 0;
    border-left: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .solutions-grid .solution-card:first-child {
    border-top: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .home-capabilities-grid .solution-card {
    min-height: auto;
    margin-top: 0;
    margin-left: 0;
    border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  }

  .home-capabilities-grid .solution-card,
  .home-capabilities-grid .solution-card:nth-child(even),
  .home-capabilities-grid .solution-card:nth-child(n + 3),
  .home-capabilities-grid .solution-card+.solution-card {
    position: static;
    display: grid;
    width: 100%;
    margin-left: 0;
  }

  .home-capabilities-grid .solution-card+.solution-card {
    margin-top: -1px;
  }

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

  .industry-list li {
    min-height: 64px;
    padding: 10px 6px;
    font-size: clamp(7.8pt, 2.8vw, 9pt);
    line-height: 1.2;
  }

  .product-info-stack {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-top: 34px;
  }

  .product-document-hero {
    --product-mobile-logo-size: clamp(82px, 18vw, 104px);
    --product-mobile-logo-lift: calc(var(--product-mobile-logo-size) * -0.85);
  }

  .product-document-topbar {
    grid-template-columns: var(--product-mobile-logo-size) minmax(0, 1fr);
    gap: 14px;
    min-width: 0;
    align-items: start;
  }

  .product-document-topbar>.product-tag-list {
    display: none;
  }

  .product-document-shell {
    display: grid;
    gap: 12px;
    position: relative;
  }

  .product-document-shell .product-title {
    width: 100%;
    max-width: 100%;
    margin-top: 0;
    margin-left: 0;
    font-size: clamp(24pt, 9vw, 31.5pt);
  }

  .product-mobile-tags {
    display: block;
    margin-top: 0;
  }

  .product-mobile-tags .product-tag-list {
    display: flex;
    max-width: 100%;
    margin: 0;
    padding: 0;
    flex-wrap: nowrap;
    font-size: clamp(7.6pt, 2.55vw, 8.8pt);
    letter-spacing: 0;
    white-space: nowrap;
  }

  .product-document-shell .detail-overview {
    margin-top: 14px;
  }

  .product-tag-list li+li::before {
    width: 3px;
    height: 3px;
    margin: 0 5px;
  }

  .product-document-topbar .product-action-row {
    grid-column: 1 / -1;
    grid-row: 2;
    position: static;
    flex-direction: row;
    justify-content: flex-start;
    gap: 8px;
    margin-top: clamp(14px, 3vw, 24px);
    transform: none;
  }

  .product-action-row {
    width: 100%;
  }

  .product-action {
    flex: 1 1 0;
    justify-content: center;
    min-width: 0;
    min-height: 44px;
    padding-right: 8px;
    padding-left: 8px;
    font-size: clamp(8.4pt, 2.8vw, 10.5pt);
    letter-spacing: 0;
    white-space: normal;
    text-align: center;
  }

  .product-action[data-intro-video-trigger] {
    min-width: 0;
  }

  .product-cover {
    height: clamp(138px, 36vw, 190px);
    padding-inline: var(--page-pad);
  }

  .product-document-logo {
    position: relative;
    z-index: 3;
    align-self: start;
    width: var(--product-mobile-logo-size);
    margin-top: var(--product-mobile-logo-lift);
    box-shadow: 0 0 0 1.2px var(--bg);
  }

  .product-detail-page.is-intro-video-open .product-document-logo {
    width: clamp(76px, 16vw, 92px);
    margin-top: 0;
  }

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

  .footer-group {
    gap: 8px;
    min-width: 0;
  }

  .footer-group h2 {
    margin-bottom: 4px;
    font-size: clamp(7.2pt, 2.7vw, 8.4pt);
    letter-spacing: 0.1em;
  }

  .footer-group a {
    width: auto;
    font-size: clamp(8.4pt, 3.1vw, 10.2pt);
    line-height: 1.25;
    overflow-wrap: anywhere;
  }

  .footer-bottom {
    display: grid;
    width: calc(100% + (var(--page-pad) * 2));
    justify-content: center;
    justify-items: center;
    margin-left: calc(var(--page-pad) * -1);
    margin-right: calc(var(--page-pad) * -1);
    padding-top: 7px;
    padding-bottom: 7px;
    text-align: center;
  }

  .footer-bottom p {
    justify-self: center;
  }

  .site-footer {
    padding-bottom: 0;
  }
}

@media (max-width: 480px) {
  .page-shell,
  .section,
  .home-hero-content,
  .focus-hero-content,
  .about-hero-content,
  .contact-hero-content,
  .product-document-hero,
  .product-document-shell,
  .product-info-block,
  .detail-overview {
    min-width: 0;
    max-width: 100%;
  }

  .product-document-hero {
    gap: 16px;
    padding-right: var(--page-pad);
    padding-bottom: 56px;
    padding-left: var(--page-pad);
    overflow: visible;
  }

  .product-title {
    max-width: 100%;
    font-size: clamp(24pt, 10vw, 33pt);
    overflow-wrap: anywhere;
  }

  .detail-overview,
  .product-info-copy,
  .product-info-subtitle,
  .product-info-points {
    overflow-wrap: break-word;
    word-break: normal;
  }

  .product-info-block h2 {
    align-items: flex-start;
    font-size: clamp(16.5pt, 6.2vw, 21pt);
  }

  .products-showcase-section {
    min-height: auto;
    align-content: start;
    padding-top: 52px;
    padding-bottom: 52px;
  }

  .products-showcase {
    gap: 18px;
  }

  .product-card {
    transform: none !important;
  }

  .product-card-visual {
    aspect-ratio: 1.08 / 1;
  }

  .product-card-content {
    min-height: 56px;
  }

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

@media (hover: none) and (pointer: coarse) {
  .product-card:hover,
  .product-card:focus-visible,
  .solution-card:hover,
  .home-value-card:hover,
  .focus-hero-list .focus-card:hover,
  .contact-method-card:hover {
    transform: none;
    box-shadow: none;
  }

  .product-card:hover .product-card-visual,
  .product-card:hover .product-card-icon::after,
  .solution-card:hover h3,
  .home-value-card:hover h3,
  .contact-method-card:hover h3 {
    transform: none;
  }

  .top-fade-target {
    transition: none;
    will-change: auto;
  }

  .top-fade-target.is-near-nav {
    opacity: 1;
    transform: none;
  }
}

@media (prefers-reduced-motion: reduce) {

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

  .home-tagline-line {
    --parallax-y: 0px !important;
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  .home-hero-copy,
  .home-hero-copy[data-line-reveal],
  .home-hero-copy .copy-line,
  .home-hero .hero-actions {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  .focus-hero-copy,
  .focus-hero-copy[data-line-reveal],
  .focus-hero-copy .copy-line,
  .about-hero-copy,
  .about-hero-copy[data-line-reveal],
  .about-hero-copy .copy-line,
  .focus-outcome-copy [data-line-reveal],
  .focus-outcome-copy .copy-line,
  .focus-outcome-list,
  .focus-outcome-list span,
  .focus-lens-visual,
  .about-globe-visual {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  .home-system-visual {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }

  .system-rail,
  .system-outer-ring,
  .system-packet,
  .system-pulse,
  .system-orbit-dot,
  .focus-lens-map,
  .focus-lens-map::after,
  .focus-lens-sweep,
  .focus-lens-node {
    transform: none !important;
    animation: none !important;
  }

  .system-packet {
    display: none !important;
  }

  .top-fade-target,
  .top-fade-target.is-near-nav {
    opacity: 1 !important;
    transform: none !important;
  }

  .site-nav::after {
    transition: none !important;
  }

  .tw-char {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  [data-typewriter]::after,
  .tw-cursor {
    display: none !important;
  }
}

/* ==========================================================================
   About Page Overrides
   ========================================================================== */

/* Hero Layout */
.about-hero {
  align-content: center;
  min-height: var(--page-hero-min);
  padding-top: var(--page-hero-padding-top);
  padding-bottom: var(--page-hero-padding-bottom);
}

.about-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.54fr) minmax(280px, 0.46fr);
  gap: clamp(36px, 7vw, 112px);
  align-items: center;
  max-width: none;
  min-height: var(--page-hero-grid-min);
}

.about-hero-content {
  display: grid;
  gap: var(--page-hero-content-gap);
  text-align: left;
  max-width: 760px;
  transform: translateY(-5%);
}

.about-title {
  font-size: var(--page-title-size);
  line-height: var(--page-title-line-height);
  letter-spacing: 0;
  margin: 0;
  max-width: none;
  text-align: left;
}

.about-hero-body {
  max-width: min(680px, 100%);
  margin: 0;
  padding-left: 0;
  text-align: left;
}

.about-hero-copy {
  max-width: none;
  font-size: var(--page-copy-size);
  line-height: var(--page-copy-line-height);
  color: var(--muted);
  margin: 0;
  text-align: left;
}

.about-globe-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(420px, 48vw, 700px);
  padding-inline: clamp(0px, 1.4vw, 22px);
  opacity: 0;
  transform: scale(0.92);
  transform-origin: center;
  animation: aboutGlobeIntro 1900ms cubic-bezier(0.16, 1, 0.3, 1) 240ms both;
  will-change: opacity, transform;
}

@keyframes aboutGlobeIntro {
  from {
    opacity: 0;
    transform: scale(0.92);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

.about-globe {
  position: relative;
  width: min(100%, clamp(380px, 34vw, 500px));
  aspect-ratio: 1;
  color: var(--fg);
  isolation: isolate;
  cursor: grab;
  touch-action: pan-y;
  --about-globe-offset-x: calc(clamp(-20px, -1.5vw, -8px) + 5%);
  --about-globe-offset-y: clamp(-28px, -2.2vw, -12px);
  --about-globe-scale: 1;
  --about-globe-tilt-x: 0deg;
  --about-globe-tilt-y: 0deg;
}

.about-globe-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.about-globe-ring {
  z-index: 2;
  transform: translate(var(--about-globe-offset-x), var(--about-globe-offset-y));
  transform-origin: center;
}

.about-globe-source-dot-path {
  opacity: 0 !important;
}

.about-globe-generated-dots {
  pointer-events: none;
}

.about-globe-fade-dot {
  opacity: 1;
  transform-box: fill-box;
  transform-origin: center;
  transition:
    opacity 1700ms cubic-bezier(0.22, 1, 0.36, 1),
    transform 1700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.about-globe-fade-dot.is-faded {
  opacity: 0;
  transform: scale(0.45);
}

.about-globe-core {
  z-index: 1;
  will-change: transform;
  transform:
    translate(var(--about-globe-offset-x), var(--about-globe-offset-y))
    perspective(900px)
    rotateX(var(--about-globe-tilt-x))
    rotateY(var(--about-globe-tilt-y))
    scale(var(--about-globe-scale));
  transform-origin: center;
  transition: transform 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.about-globe.is-interacting .about-globe-core {
  --about-globe-scale: 1.025;
  transition-duration: 420ms;
}

.about-globe.is-dragging .about-globe-core {
  --about-globe-scale: 1.045;
}

.about-globe.is-dragging {
  cursor: grabbing;
}

.about-globe::before {
  content: "";
  display: none;
  position: absolute;
  inset: 8%;
  border-radius: 50%;
  background: var(--fg);
  filter: blur(24px);
  opacity: 0.9;
  pointer-events: none;
  transform: scale(0.9);
}

.about-globe svg {
  position: relative;
  z-index: 1;
  width: 100% !important;
  height: 100% !important;
  display: block;
  filter: none;
}

.about-globe.is-unavailable {
  border: 1px solid var(--fg);
  border-radius: 50%;
  background: var(--bg);
}

/* Section Adjustments */
.about-hero {
  padding-bottom: 0px;
}
.about-method-section {
  --about-method-entry-gap: clamp(5.1rem, 12.75vh, 10.2rem);
  margin-top: calc(var(--about-method-entry-gap) * -1.5);
  padding-top: 0px;
  padding-bottom: clamp(2.9rem, 7.4vh, 5.9rem);
  background-color: var(--surface-1);
  position: relative;
}

.about-method-section .focus-sticky-label {
  top: 0;
  min-height: 100vh;
  align-content: center;
  padding-top: 0;
}

.about-method-section .focus-principles {
  top: 0;
  min-height: 100vh;
  align-content: center;
  padding-top: 0;
  padding-bottom: 0;
}

/* Remove global section bottom borders on the About Us page to eliminate divider lines */
.page-shell[aria-label="About Us"] .section {
  border-bottom: none;
}

.about-reach-section {
  background-color: var(--surface-2);
  margin-top: -28.6vh;
  padding-top: clamp(3.5rem, 8.8vh, 7rem);
  padding-bottom: clamp(1rem, 2vh, 2rem);
}

.page-shell[aria-label="About Us"] .home-cta-section {
  padding-bottom: 35vh;
}

@media (max-width: 900px) {
  .about-hero-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .about-hero-content {
    grid-column: auto;
    grid-row: auto;
    transform: none;
  }

  .about-hero-content,
  .about-title,
  .about-hero-body,
  .about-hero-copy {
    text-align: left;
  }

  .about-title {
    overflow-wrap: anywhere;
  }

  .about-hero-body {
    max-width: 100%;
    margin-right: 0;
    margin-left: 0;
  }

  .about-globe-visual {
    min-height: clamp(300px, 78vw, 500px);
    padding-inline: 0;
  }

  .about-globe {
    width: min(82vw, 410px);
    --about-globe-offset-x: 0px;
    --about-globe-offset-y: -10px;
  }

  .page-shell[aria-label="About Us"] .about-method-section {
    margin-top: 96px;
  }

  .page-shell[aria-label="About Us"] .about-method-section .focus-sticky-label,
  .page-shell[aria-label="About Us"] .about-method-section .focus-principles {
    min-height: auto;
    align-content: start;
  }

  .page-shell[aria-label="About Us"] .about-reach-section {
    margin-top: clamp(24px, 7vw, 42px);
    padding-top: 0;
  }

  .page-shell[aria-label="About Us"] .home-cta-section {
    padding-bottom: 14vh;
  }

}

/* =====================================================
   CONTACT PAGE
   ===================================================== */

.page-shell[aria-label="Contact"]>.section {
  border-bottom: 0;
}

.page-shell[aria-label="Contact"]>.home-cta-section {
  min-height: 90vh;
}

.page-shell[aria-label="Contact"] .home-final-cta h2 {
  max-width: min(1040px, 100%);
}

/* ── Hero ────────────────────────────────────────────── */

.contact-hero {
  align-content: center;
  min-height: var(--page-hero-min);
  overflow: hidden;
  padding-top: var(--page-hero-padding-top);
  padding-bottom: var(--page-hero-padding-bottom);
}

.contact-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.58fr) minmax(320px, 0.42fr);
  gap: var(--page-hero-grid-gap);
  align-items: center;
  min-height: var(--page-hero-grid-min);
}

.contact-hero-content {
  position: relative;
  z-index: 2;
  display: grid;
  gap: var(--page-hero-content-gap);
  width: 100%;
  max-width: 900px;
  min-width: 0;
}

.contact-hero-marker {
  justify-self: start;
  text-align: left;
}

.contact-title {
  max-width: 880px;
  font-size: var(--page-title-size);
  line-height: var(--page-title-line-height);
}

.contact-hero-body {
  display: grid;
  gap: 0;
  width: 100%;
  max-width: none;
}

.contact-hero-copy {
  max-width: var(--page-copy-max);
  font-size: var(--page-copy-size);
  line-height: var(--page-copy-line-height);
  text-align: left;
}

.contact-hero-copy[data-line-reveal] {
  opacity: 0;
}

.contact-hero-copy[data-line-reveal].is-line-ready {
  opacity: 1;
}

.contact-hero-copy .copy-line {
  display: block;
  opacity: 0;
  transform: translateY(0.75em);
  animation: focusCopyLineIn 620ms var(--easing) forwards;
  animation-delay: calc(560ms + (var(--line) * 70ms));
  will-change: opacity, transform;
}

.contact-hero-actions {
  opacity: 0;
  transform: translateY(14px);
  animation: heroActionsIn 520ms var(--easing) forwards;
  animation-delay: 1120ms;
}

@media (min-width: 1121px) {
  .page-shell[aria-label="Contact"]:has(.contact-form-grid.is-submitted) .contact-hero-grid {
    min-height: calc(var(--page-hero-grid-min) * 0.7);
  }

  .page-shell[aria-label="Contact"]:has(.contact-form-grid.is-submitted) .contact-signal-visual {
    min-height: calc(clamp(360px, 46vw, 620px) * 0.7);
  }
}

/* ── Signal Visual ──────────────────────────────────── */

.contact-signal-visual {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(360px, 46vw, 620px);
  isolation: isolate;
  opacity: 0;
  transform: scale(0.96);
  animation: contactVisualIn 900ms var(--easing) forwards;
  animation-delay: 480ms;
  will-change: opacity, transform;
}

@keyframes contactVisualIn {
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.signal-map {
  position: relative;
  width: min(100%, 540px);
  aspect-ratio: 1;
  color: var(--fg);
  transform: scale(1);
  transition: transform 520ms var(--easing);
  will-change: transform;
}

.contact-signal-visual:hover .signal-map {
  transform: scale(1.035);
}

.signal-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  border: 1px solid transparent;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
}

.signal-ring-a {
  width: 92%;
  height: 92%;
  border-color: color-mix(in srgb, var(--fg) 8%, transparent);
  animation: signalPulse 4200ms var(--easing) infinite;
}

.signal-ring-b {
  width: 68%;
  height: 68%;
  border-color: color-mix(in srgb, var(--fg) 14%, transparent);
  animation: signalPulse 4200ms var(--easing) infinite 700ms;
}

.signal-ring-c {
  width: 44%;
  height: 44%;
  border-color: color-mix(in srgb, var(--fg) 22%, transparent);
  animation: signalPulse 4200ms var(--easing) infinite 1400ms;
}

.signal-ring-d {
  width: 22%;
  height: 22%;
  border-color: color-mix(in srgb, var(--fg) 32%, transparent);
  animation: signalPulse 4200ms var(--easing) infinite 2100ms;
}

@keyframes signalPulse {

  0%,
  100% {
    opacity: 0.5;
    transform: translate(-50%, -50%) scale(1);
  }

  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.06);
  }
}

.signal-core {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 3;
  width: 11%;
  aspect-ratio: 1;
  border: 1px solid color-mix(in srgb, var(--fg) 62%, transparent);
  border-radius: 50%;
  background: transparent;
  transform: translate(-50%, -50%);
  box-shadow: 0 18px 54px color-mix(in srgb, var(--fg) 8%, transparent);
  animation: signalCoreBreathe 3200ms var(--easing) infinite;
}

.contact-signal-visual:hover .signal-core {
  border-color: color-mix(in srgb, var(--fg) 88%, transparent);
  box-shadow: 0 24px 76px color-mix(in srgb, var(--fg) 14%, transparent);
}

@keyframes signalCoreBreathe {
  50% {
    box-shadow: 0 26px 72px color-mix(in srgb, var(--fg) 16%, transparent);
    transform: translate(-50%, -50%) scale(1.08);
  }
}

.signal-core-dot {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 4;
  width: clamp(14px, 1.8vw, 22px);
  height: clamp(14px, 1.8vw, 22px);
  border-radius: 50%;
  background: color-mix(in srgb, var(--fg) 62%, var(--bg));
  transform: translate(-50%, -50%);
  animation: signalDotPulse 2600ms var(--easing) infinite;
}

@keyframes signalDotPulse {
  50% {
    transform: translate(-50%, -50%) scale(0.72);
    opacity: 0.58;
  }
}

/* ── Form Section ───────────────────────────────────── */

.contact-form-section {
  padding-right: var(--page-pad);
  padding-left: var(--page-pad);
}

.contact-form-section:has(.contact-form-grid.is-submitted) {
  min-height: 100svh;
  display: grid;
  align-items: center;
}

@media (min-width: 1121px) {
  .contact-form-section:has(.contact-form-grid.is-submitted) {
    padding-top: 0;
  }
}

.contact-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(14px, 2vw, 24px);
  align-items: start;
}

.contact-form-grid.is-submitted {
  min-height: min(420px, 42vh);
  align-items: center;
}

.contact-form-lede[hidden],
.contact-form[hidden],
.contact-thank-you[hidden] {
  display: none;
}

.contact-form-grid.reveal {
  opacity: 1;
  transform: none;
  transition: none;
}

.contact-form-grid.reveal .contact-form-title,
.contact-form-grid.reveal .contact-form-subtitle,
.contact-form-grid.reveal .contact-field,
.contact-form-grid.reveal .contact-submit {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 720ms var(--easing), transform 720ms var(--easing);
  transition-delay: var(--contact-reveal-delay, 0ms);
}

.contact-form-grid.reveal.is-visible .contact-form-title,
.contact-form-grid.reveal.is-visible .contact-form-subtitle,
.contact-form-grid.reveal.is-visible .contact-field,
.contact-form-grid.reveal.is-visible .contact-submit {
  opacity: 1;
  transform: translateY(0);
}

.contact-form-grid .contact-form-title {
  --contact-reveal-delay: 0ms;
}

.contact-form-grid .contact-form-subtitle {
  --contact-reveal-delay: 80ms;
}

.contact-form .contact-field:nth-of-type(1) {
  --contact-reveal-delay: 160ms;
}

.contact-form .contact-field:nth-of-type(2) {
  --contact-reveal-delay: 220ms;
}

.contact-form .contact-field:nth-of-type(3) {
  --contact-reveal-delay: 280ms;
}

.contact-form .contact-field:nth-of-type(4) {
  --contact-reveal-delay: 340ms;
}

.contact-form .contact-field:nth-of-type(5) {
  --contact-reveal-delay: 400ms;
}

.contact-form .contact-field:nth-of-type(6) {
  --contact-reveal-delay: 460ms;
}

.contact-form .contact-field:nth-of-type(7) {
  --contact-reveal-delay: 520ms;
}

.contact-form .contact-submit {
  --contact-reveal-delay: 620ms;
}

.contact-form-lede {
  display: grid;
  gap: 0;
  align-self: start;
  margin-top: 0;
}

.contact-form-title {
  max-width: 930px;
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--section-title-size);
  font-weight: var(--weight-bold);
  line-height: 1;
  white-space: nowrap;
}

.contact-form-subtitle {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-size: var(--section-copy-size);
  line-height: var(--section-copy-line-height);
}

.contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 16px;
  width: 100%;
  max-width: none;
  justify-self: stretch;
}

.contact-field {
  display: grid;
  gap: 7px;
}

.contact-field:has(textarea),
.contact-form-status,
.contact-submit {
  grid-column: 1 / -1;
}

.contact-field label {
  color: var(--fg);
  font-size: clamp(8.75pt, 0.85vw, 9.75pt);
  font-weight: var(--weight-bold);
  line-height: 1.1;
}

.contact-label-optional {
  color: var(--faint);
  font-weight: var(--weight-regular);
}

.contact-field input,
.contact-field textarea {
  width: 100%;
  min-height: 46px;
  padding: 0 20px;
  border: 1px solid var(--rule);
  border-radius: 12px;
  background: transparent;
  color: var(--fg);
  font-size: clamp(10.5pt, 1vw, 11.25pt);
  font-weight: var(--weight-medium);
  line-height: 1.3;
  outline: none;
  resize: vertical;
  transition: height 240ms var(--easing), border-color 300ms var(--easing), color 300ms var(--easing), box-shadow 300ms var(--easing);
}

.contact-field textarea {
  min-height: 112px;
  padding-top: 12px;
  padding-bottom: 12px;
  line-height: 1.45;
  overflow: hidden;
  resize: none;
}

.contact-field input::placeholder,
.contact-field textarea::placeholder {
  color: var(--faint);
  font-weight: var(--weight-regular);
}

.contact-field input:focus,
.contact-field textarea:focus {
  position: relative;
  z-index: 1;
  color: var(--fg);
  border-color: var(--fg);
  box-shadow: 0 0 0 1px var(--fg);
}

.contact-legal-note {
  flex: 1 1 auto;
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-family: var(--font-body);
  font-size: clamp(9.25pt, 0.88vw, 10pt);
  line-height: 1.45;
}

.contact-legal-note a {
  color: var(--fg);
  font-weight: var(--weight-bold);
  text-decoration: none;
}

.contact-legal-note a:hover,
.contact-legal-note a:focus-visible {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

.contact-submit {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-top: 0;
}

.contact-form-status {
  min-height: 1.2em;
  margin: 0;
  color: var(--muted);
  font-family: var(--font-body);
  font-size: clamp(9.5pt, 0.9vw, 10.25pt);
  line-height: 1.35;
}

.contact-form-status:empty {
  display: none;
}

.contact-submit .cta {
  flex: 0 0 auto;
  min-height: 37px;
  padding: 0 22px;
  font-size: 8.7pt;
}

.contact-thank-you {
  grid-column: 1 / -1;
  width: min(100%, 820px);
  display: grid;
  justify-items: center;
  gap: clamp(12px, 1.8vw, 20px);
  margin: 0 auto;
  padding: clamp(22px, 4vw, 52px) 0;
  text-align: center;
  outline: 0;
}

.contact-form-grid.is-submitted .contact-thank-you {
  animation: contactThankPanelIn 780ms var(--easing) both;
}

.contact-form-grid.is-submitted .contact-thank-title,
.contact-form-grid.is-submitted .contact-thank-copy {
  opacity: 0;
  transform: translateY(18px);
  animation: contactThankItemIn 760ms var(--easing) both;
}

.contact-form-grid.is-submitted .contact-thank-title {
  animation-delay: 120ms;
}

.contact-form-grid.is-submitted .contact-thank-copy {
  animation-delay: 220ms;
}

.contact-thank-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(29.4pt, 4.9vw, 64.4pt);
  font-weight: var(--weight-bold);
  line-height: 0.92;
}

.contact-thank-copy {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(8.4pt, 1.015vw, 11.9pt);
  line-height: 1.55;
}

@keyframes contactThankPanelIn {
  from {
    opacity: 0;
    filter: blur(10px);
    transform: translateY(28px) scale(0.98);
  }

  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0) scale(1);
  }
}

@keyframes contactThankItemIn {
  from {
    opacity: 0;
    transform: translateY(18px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .contact-form-grid.reveal .contact-form-title,
  .contact-form-grid.reveal .contact-form-subtitle,
  .contact-form-grid.reveal .contact-field,
  .contact-form-grid.reveal .contact-submit {
    opacity: 1;
    transform: none;
    transition: none;
  }

  .contact-form-grid.is-submitted .contact-thank-you,
  .contact-form-grid.is-submitted .contact-thank-title,
  .contact-form-grid.is-submitted .contact-thank-copy {
    opacity: 1;
    filter: none;
    transform: none;
    animation: none;
  }
}

/* ── Contact Methods ────────────────────────────────── */

.contact-methods-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: var(--title-box-gap);
}

.page-shell[aria-label="Contact"] > .contact-methods-section {
  padding-top: clamp(29.4px, 4.9vw, 64.4px);
}

.contact-method-card {
  display: grid;
  align-content: start;
  gap: 0;
  padding: clamp(22px, 3vw, 36px);
  border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  position: relative;
  z-index: 1;
  background: var(--bg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    background-color 680ms var(--easing),
    border-color 680ms var(--easing);
}

.contact-method-card+.contact-method-card {
  margin-left: -1px;
}

.contact-method-card:hover,
.contact-method-card:focus-within {
  z-index: 2;
  background: color-mix(in srgb, var(--fg) 2.5%, transparent);
}

.contact-method-card h3 {
  margin: 0;
  font-size: clamp(16.5pt, 1.85vw, 22.5pt);
  font-weight: var(--weight-bold);
  line-height: 0.98;
  margin-bottom: clamp(12px, 1.5vw, 17px);
  transition: transform 680ms var(--easing);
}

.contact-method-card:hover h3 {
  transform: translateY(-2px);
}

.contact-method-card p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(11.25pt, 1.18vw, 12.75pt);
  font-weight: var(--weight-regular);
  line-height: 1.48;
  max-width: 360px;
  transition: opacity 520ms var(--easing), transform 720ms var(--easing);
}

.contact-method-card:hover p {
  opacity: 0.78;
  transform: translateY(-2px);
}

.contact-method-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: clamp(18px, 2.4vw, 28px);
  justify-self: start;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transform: translateY(10px);
  transition: max-height 760ms var(--easing), opacity 520ms var(--easing), transform 720ms var(--easing);
}

.contact-method-email {
  font-size: 10.5pt;
  font-weight: var(--weight-bold);
  letter-spacing: 0.02em;
  line-height: 1;
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
}

.copy-email-button {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: color 220ms var(--easing), transform 220ms var(--easing);
}

.copy-email-icon {
  width: 20px;
  height: 20px;
}

.copy-email-button:hover,
.copy-email-button:focus-visible,
.copy-email-button.is-copied {
  color: color-mix(in srgb, var(--fg) 62%, var(--muted));
  transform: translateY(-1px);
}

.copy-email-button.is-copy-failed {
  color: var(--fg);
}

.contact-method-card:hover .contact-method-actions,
.contact-method-card:focus-within .contact-method-actions {
  max-height: 48px;
  opacity: 1;
  transform: translateY(0);
}

/* ── Contact Mobile ─────────────────────────────────── */

@media (max-width: 1120px) {
  .contact-hero-grid {
    grid-template-columns: 1fr;
    gap: clamp(40px, 6vw, 64px);
  }

  .contact-signal-visual {
    min-height: 320px;
    max-width: 400px;
    justify-self: center;
  }

  .contact-form-grid {
    grid-template-columns: 1fr;
    gap: clamp(16px, 2.5vw, 24px);
  }

  .contact-form-lede {
    position: static;
  }

  .contact-form {
    max-width: none;
    justify-self: stretch;
  }

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

  .contact-method-card+.contact-method-card {
    margin-left: 0;
    margin-top: -1px;
  }

  .contact-method-actions {
    max-height: none;
    opacity: 1;
    transform: none;
    overflow: visible;
  }
}

@media (max-width: 760px) {
  .contact-form {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .contact-form-title {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .contact-submit {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }

  .contact-legal-note {
    max-width: none;
  }

  .contact-submit .cta {
    align-self: flex-end;
    width: auto;
  }

  .contact-channel-links {
    gap: 8px;
  }

  .contact-channel-link {
    width: 40px;
    height: 40px;
  }

  .contact-channel-icon {
    width: 20px;
    height: 20px;
  }
}

/* =====================================================
   PRODUCTS PAGE
   ===================================================== */

.page-shell[aria-label="Products"]>.section {
  border-bottom: 0;
}

.page-shell[aria-label="Products"]>.home-cta-section {
  min-height: 90vh;
}

.page-shell[aria-label="Products"]>.home-cta-section .home-final-cta {
  transform: translateY(5vh);
}

.products-showcase-section {
  min-height: calc(100vh - var(--nav-h));
  display: grid;
  align-content: center;
  padding-top: clamp(48px, 6vw, 84px);
  padding-bottom: clamp(48px, 6vw, 84px);
}

.products-showcase-heading {
  display: grid;
  gap: var(--page-hero-content-gap);
  margin-bottom: var(--title-box-gap);
  justify-items: start;
  text-align: left;
}

.products-showcase-title {
  font-size: var(--page-title-size);
  line-height: var(--page-title-line-height);
  text-align: left;
}

.products-showcase {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(20px, 2.6vw, 56px);
  width: 100%;
  max-width: none;
  margin-top: 0;
  margin-right: 0;
  margin-left: 0;
}

.product-card {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto;
  align-content: stretch;
  gap: 0;
  min-height: 0;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  background: var(--bg);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition:
    opacity 800ms var(--easing) var(--delay, 0ms),
    transform 800ms var(--easing) var(--delay, 0ms),
    background-color 560ms var(--easing),
    border-color 560ms var(--easing),
    box-shadow 560ms var(--easing);
}

.product-card:hover,
.product-card:focus-visible {
  z-index: 3;
  background: color-mix(in srgb, var(--fg) 2%, transparent);
  border-color: color-mix(in srgb, var(--fg) 18%, transparent);
  box-shadow:
    0 24px 64px color-mix(in srgb, var(--fg) 6%, transparent),
    0 4px 16px color-mix(in srgb, var(--fg) 3%, transparent);
  outline: 0;
  transform: scale(1.018);
}

.product-card-visual {
  display: grid;
  aspect-ratio: 1 / 1;
  min-height: 0;
  padding: 0;
  transition: transform 680ms var(--easing), filter 520ms var(--easing);
}

.product-card:hover .product-card-visual {
  transform: scale(1.025);
}

.product-card-icon {
  position: relative;
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 0;
  border-radius: 0;
  background: var(--fg);
  color: var(--fg);
  transition: color 400ms var(--easing);
}

.product-card-icon .product-logo-image {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 60%;
}

.product-card-icon::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 0;
  background: color-mix(in srgb, var(--fg) 4%, transparent);
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 520ms var(--easing), transform 620ms var(--easing);
}

.product-card:hover .product-card-icon::after {
  opacity: 1;
  transform: scale(1);
}

.product-card-content {
  display: grid;
  min-height: clamp(62px, 5.4vw, 82px);
  padding: clamp(16px, 1.8vw, 22px);
  border-top: 1px solid color-mix(in srgb, var(--rule) calc(var(--grid-line-alpha, 1) * 100%), transparent);
  background: var(--bg);
  text-align: center;
  place-items: center;
  transition: transform 680ms var(--easing);
}

.product-card:hover .product-card-content {
  transform: none;
}

.product-card-name {
  margin: 0;
  font-size: clamp(12pt, 1.18vw, 15pt);
  font-weight: var(--weight-bold);
  line-height: 1;
  transition: transform 680ms var(--easing);
}

@media (max-width: 900px) {
  .products-showcase {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .products-showcase-section {
    min-height: 0;
    align-content: start;
    padding-bottom: 34px;
  }

  .products-showcase {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
  }

  .page-shell[aria-label="Products"] > .home-cta-section {
    min-height: 41vh;
    padding-top: 0;
  }

  .page-shell[aria-label="Products"] > .home-cta-section .home-final-cta {
    transform: none;
  }

  .product-card-content {
    min-height: 48px;
    padding: 10px 8px;
  }

  .product-card-name {
    font-size: clamp(9.6pt, 3.2vw, 11.25pt);
  }
}

@media (max-width: 600px) {

  .hero-title.home-tagline,
  .focus-title,
  .about-title,
  .contact-title,
  .products-showcase-title {
    font-size: clamp(22.5pt, 8.4vw, 25.5pt);
    line-height: 1;
  }

  .home-hero-copy,
  .focus-hero-copy,
  .about-hero-copy,
  .contact-hero-copy {
    font-size: clamp(11.25pt, 4vw, 13.5pt);
    line-height: var(--page-copy-line-height);
  }
}

@media (max-width: 600px) {
  .focus-title,
  .about-title,
  .contact-title,
  .products-showcase-title {
    font-size: clamp(45pt, 16.8vw, 51pt);
    line-height: 0.96;
  }

  .products-showcase-heading {
    justify-items: start;
    text-align: left;
  }

  .products-showcase-title {
    text-align: left;
  }

  .page-shell[aria-label="Contact"] > .home-cta-section {
    min-height: 68vh;
  }

  .contact-hero {
    min-height: 0;
    align-content: start;
    padding-bottom: 34px;
  }

  .contact-signal-visual {
    display: none;
  }

  .contact-hero-grid {
    gap: 0;
    min-height: 0;
  }

  .home-hero-content,
  .home-hero-grid,
  .hero-title.home-tagline,
  .home-tagline-line,
  .hero-copy,
  .product-document-hero,
  .product-document-shell,
  .product-info-stack,
  .detail-overview {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .hero-title.home-tagline {
    font-size: clamp(19.5pt, 7.1vw, 22.5pt);
    line-height: 1.1;
    overflow-wrap: anywhere;
  }

  .home-tagline-line {
    text-wrap: wrap;
    white-space: normal;
  }

  .hero-title.home-tagline .word {
    display: inline;
  }

  .home-hero-copy,
  .home-hero-copy[data-line-reveal],
  .home-hero-copy .copy-line {
    width: calc(100vw - (var(--page-pad) * 2));
    max-width: calc(100vw - (var(--page-pad) * 2));
    overflow-wrap: break-word;
  }

  .home-hero-copy .copy-line,
  .focus-hero-copy .copy-line,
  .about-hero-copy .copy-line,
  .contact-hero-copy .copy-line {
    display: inline;
    white-space: normal;
  }

  .products-showcase-title {
    font-size: clamp(45pt, 16.8vw, 51pt);
    line-height: 0.96;
    text-align: left;
    overflow-wrap: anywhere;
  }

  .page-title-animated .word {
    display: inline;
  }

  .product-document-hero {
    overflow: visible;
  }

  .product-title,
  .detail-overview,
  .product-info-copy,
  .product-info-subtitle,
  .product-info-points li {
    width: 100%;
    max-width: calc(100vw - (var(--page-pad) * 2));
    overflow-wrap: break-word;
    white-space: normal;
  }

  .product-info-block {
    --product-info-indent: 28px;
    gap: 10px;
  }

  .product-info-block h2 {
    display: grid;
    grid-template-columns: var(--product-info-indent) minmax(0, 1fr);
    gap: 0;
    align-items: baseline;
    font-size: clamp(19.5pt, 7.2vw, 25.5pt);
    line-height: 1.05;
  }

  .product-info-dot {
    justify-self: start;
    transform: translateY(-0.2em);
  }

  .product-info-subtitle,
  .product-info-copy,
  .product-info-points {
    width: calc(100% - var(--product-info-indent));
    max-width: calc(100vw - (var(--page-pad) * 2) - var(--product-info-indent));
    margin-left: var(--product-info-indent);
  }

  .product-info-points {
    padding-left: 1em;
  }

  .detail-overview {
    display: block;
  }

  .home-cta-section,
  .home-final-cta {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .home-section-title {
    transform: none;
  }

  .home-final-cta {
    gap: 16px;
  }

  .home-final-cta h2 {
    width: 100%;
    max-width: calc(100vw - (var(--page-pad) * 2));
    font-size: clamp(21pt, 8vw, 27pt);
    line-height: 1.08;
    overflow-wrap: break-word;
  }

  .home-final-title-line,
  .home-final-title-line-nowrap {
    white-space: normal;
  }

  .home-final-cta p {
    width: 100%;
    max-width: calc(100vw - (var(--page-pad) * 2));
    font-size: clamp(11.25pt, 4vw, 13.5pt);
    line-height: 1.55;
    overflow-wrap: break-word;
  }

  .home-final-cta .cta {
    max-width: calc(100vw - (var(--page-pad) * 2));
    min-height: 44px;
    justify-content: center;
    padding: 0 18px;
    text-align: center;
    white-space: normal;
  }
}

@media (max-width: 600px) {
  .home-hero {
    min-height: 0;
    display: block;
    padding-top: 10px;
    padding-bottom: 6px;
    overflow: visible;
  }

  .home-hero-grid {
    display: block;
    min-height: 0;
  }

  .home-hero-content {
    width: calc(100vw - (var(--page-pad) * 2));
    max-width: calc(100vw - (var(--page-pad) * 2));
    gap: 6px;
    overflow: visible;
  }

  .home-system-visual {
    display: none;
  }

  .hero-title.home-tagline .word,
  .home-hero-copy .copy-line {
    display: inline;
  }

  .hero-title.home-tagline {
    font-size: clamp(16.5pt, 6.35vw, 19.5pt);
    line-height: 1.08;
  }

  .home-tagline-line {
    display: block;
    white-space: nowrap;
    overflow-wrap: normal;
  }

  .home-hero-copy {
    width: 100%;
    max-width: 100%;
    font-size: clamp(9.75pt, 3.25vw, 10.8pt);
    line-height: 1.42;
    margin-top: 0;
  }

  .home-hero .hero-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-top: 2px;
  }

  .home-hero .hero-actions .cta {
    min-width: 0;
    width: 100%;
    min-height: 34px;
    justify-content: center;
    padding: 0 4px;
    font-size: clamp(7.2pt, 2.45vw, 8.4pt);
    line-height: 1.12;
    letter-spacing: 0;
    text-align: center;
    white-space: normal;
    overflow-wrap: anywhere;
  }
}

@media (max-width: 900px) {
  .solution-card,
  .home-value-card,
  .focus-card {
    -webkit-tap-highlight-color: rgba(128, 128, 128, 0.24);
  }

  .home-capabilities-grid .solution-card::before,
  .home-value-grid .home-value-card::before {
    content: "";
    width: 8px;
    height: 8px;
    margin-bottom: clamp(14px, 3.6vw, 22px);
    border: 0;
    border-radius: 0;
    background: transparent;
    opacity: 0.72;
    transform: rotate(45deg);
    border-top: 1.5px solid var(--muted);
    border-right: 1.5px solid var(--muted);
    transition: opacity 220ms var(--easing), transform 260ms var(--easing), border-color 220ms var(--easing);
  }

  .home-capabilities-grid .solution-card.is-card-open::before,
  .home-value-grid .home-value-card.is-card-open::before,
  .home-capabilities-grid .solution-card:focus-visible::before,
  .home-value-grid .home-value-card:focus-visible::before {
    opacity: 1;
    transform: rotate(135deg);
    border-color: #808080;
    background: transparent;
  }

  .solution-card.is-card-open,
  .solution-card:focus-visible,
  .home-value-card.is-card-open,
  .home-value-card:focus-visible,
  .focus-card.is-card-open,
  .focus-card:focus-visible {
    background: color-mix(in srgb, #808080 12%, var(--bg));
    border-color: color-mix(in srgb, #808080 52%, transparent);
  }

  .focus-card-heading p,
  .focus-card-body,
  .home-card-body {
    max-height: 0;
    margin-top: 0;
    opacity: 0;
    overflow: hidden;
    filter: blur(2px);
    transform: translateY(10px);
  }

  .focus-card-body>p,
  .focus-card-points li,
  .home-card-body>p,
  .home-card-points li {
    opacity: 0;
    transform: translateY(8px);
  }

  .home-capabilities-grid .solution-card:hover .home-card-body,
  .home-value-grid .home-value-card:hover .home-card-body,
  .focus-card:hover .focus-card-heading p,
  .focus-card:hover .focus-card-body,
  .focus-hero-list .focus-card:hover .focus-card-body {
    max-height: 0 !important;
    margin-top: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    filter: blur(2px) !important;
    transform: translateY(10px) !important;
  }

  .home-capabilities-grid .solution-card:hover .home-card-body>p,
  .home-capabilities-grid .solution-card:hover .home-card-points li,
  .home-value-grid .home-value-card:hover .home-card-body>p,
  .home-value-grid .home-value-card:hover .home-card-points li,
  .focus-card:hover .focus-card-body>p,
  .focus-card:hover .focus-card-points li {
    opacity: 0 !important;
    transform: translateY(8px) !important;
  }

  .focus-card:focus-visible .focus-card-heading p,
  .focus-card.is-card-open .focus-card-heading p {
    max-height: 72px;
    opacity: 1;
    filter: none;
    transform: none;
  }

  .focus-card:focus-visible .focus-card-body,
  .focus-card.is-card-open .focus-card-body,
  .solution-card:focus-visible .home-card-body,
  .solution-card.is-card-open .home-card-body,
  .home-value-card:focus-visible .home-card-body,
  .home-value-card.is-card-open .home-card-body {
    max-height: 420px;
    margin-top: 14px;
    opacity: 1;
    overflow: visible;
    filter: none;
    transform: none;
  }

  .focus-card.is-card-open:hover .focus-card-heading p,
  .focus-card.is-card-open:hover .focus-card-body,
  .focus-hero-list .focus-card.is-card-open:hover .focus-card-body,
  .solution-card.is-card-open:hover .home-card-body,
  .home-value-card.is-card-open:hover .home-card-body {
    max-height: 420px !important;
    margin-top: 14px !important;
    opacity: 1 !important;
    overflow: visible !important;
    filter: none !important;
    transform: none !important;
  }

  .focus-card:focus-visible .focus-card-body>p,
  .focus-card:focus-visible .focus-card-points li,
  .focus-card.is-card-open .focus-card-body>p,
  .focus-card.is-card-open .focus-card-points li,
  .solution-card:focus-visible .home-card-body>p,
  .solution-card:focus-visible .home-card-points li,
  .solution-card.is-card-open .home-card-body>p,
  .solution-card.is-card-open .home-card-points li,
  .home-value-card:focus-visible .home-card-body>p,
  .home-value-card:focus-visible .home-card-points li,
  .home-value-card.is-card-open .home-card-body>p,
  .home-value-card.is-card-open .home-card-points li {
    opacity: 1;
    transform: none;
  }

  .focus-card.is-card-open:hover .focus-card-body>p,
  .focus-card.is-card-open:hover .focus-card-points li,
  .solution-card.is-card-open:hover .home-card-body>p,
  .solution-card.is-card-open:hover .home-card-points li,
  .home-value-card.is-card-open:hover .home-card-body>p,
  .home-value-card.is-card-open:hover .home-card-points li {
    opacity: 1 !important;
    transform: none !important;
  }

  .focus-card:focus-within:not(:focus-visible):not(.is-card-open) .focus-card-heading p,
  .focus-card:focus-within:not(:focus-visible):not(.is-card-open) .focus-card-body,
  .solution-card:focus-within:not(:focus-visible):not(.is-card-open) .home-card-body,
  .home-value-card:focus-within:not(:focus-visible):not(.is-card-open) .home-card-body {
    max-height: 0;
    margin-top: 0;
    opacity: 0;
    overflow: hidden;
    filter: blur(2px);
    transform: translateY(10px);
  }
}

@media (max-width: 600px) {
  html {
    scroll-behavior: auto;
  }

  .page-shell[aria-label="Home"] {
    --home-divider-gap: 0;
    --home-content-gap: 8px;
    display: block;
  }

  .page-shell[aria-label="Home"] > .section,
  .page-shell[aria-label="Home"] > .section:not(.home-hero),
  .page-shell[aria-label="Home"] .home-hero,
  .page-shell[aria-label="Home"] #home-capabilities {
    display: block;
    min-height: 0 !important;
    align-content: start;
    padding-top: 12px;
    padding-bottom: 12px;
    overflow: visible !important;
  }

  .page-shell[aria-label="Home"] .home-hero {
    padding-top: 12px;
    padding-bottom: 8px;
  }

  .page-shell[aria-label="Home"] #home-capabilities {
    scroll-margin-top: var(--nav-h);
    padding-top: 8px;
    padding-bottom: clamp(34px, 10vw, 52px);
  }

  .page-shell[aria-label="Home"] #home-capabilities + .section-tight {
    padding-bottom: clamp(34px, 10vw, 52px);
  }

  .page-shell[aria-label="Home"] #home-capabilities + .section-tight + .section-tight {
    padding-bottom: clamp(34px, 10vw, 52px);
  }

  .page-shell[aria-label="Home"] .industry-list {
    margin-bottom: clamp(58px, 16vw, 68px);
  }

  .page-shell[aria-label="Home"] > .section.home-cta-section {
    padding-bottom: clamp(23px, 6.4vw, 27px);
  }

  .page-shell[aria-label="Home"] .home-final-cta .cta {
    margin-bottom: clamp(33px, 10.2vw, 42px);
  }

  .page-shell[aria-label="Home"] .home-section-lede {
    margin-bottom: 8px;
  }

  .page-shell[aria-label="Home"] .home-section-title {
    margin: 0;
    font-size: clamp(24pt, 9vw, 30pt);
    line-height: 1;
  }

  .page-shell[aria-label="Home"] .solutions-grid.home-capabilities-grid {
    display: block;
    margin-top: 8px;
    overflow: visible;
  }

  .page-shell[aria-label="Home"] .home-capabilities-grid .solution-card {
    display: grid;
    min-height: 0;
    margin: 0;
    padding: clamp(22px, 3vw, 36px);
  }

  .page-shell[aria-label="Home"] .home-capabilities-grid .solution-card + .solution-card {
    margin-top: -1px;
  }

  .page-shell[aria-label="Home"] .solution-title {
    font-size: clamp(15pt, 1.9vw, 21pt);
    line-height: 1.05;
  }

  .page-shell[aria-label="Home"] .solution-copy {
    font-size: clamp(11.25pt, 1.2vw, 12.75pt);
    line-height: 1.55;
  }

  .page-shell[aria-label="Home"] .reveal-grid {
    --grid-line-alpha: 0;
    transition-delay: var(--grid-delay, 300ms);
  }

  .page-shell[aria-label="Home"] .reveal-grid.is-visible,
  .page-shell[aria-label="Home"] .home-value-grid.reveal-grid.is-visible {
    --grid-line-alpha: 1;
  }
}

@media (max-width: 600px) {
  .page-shell[aria-label="Home"] .home-hero {
    display: grid;
    min-height: calc(100svh - var(--nav-h)) !important;
    align-content: center;
    padding-top: 38px;
    padding-bottom: clamp(18px, 6vw, 28px);
  }

  .page-shell[aria-label="Home"] .home-hero-content {
    gap: clamp(14px, 4.5vw, 20px);
  }

  .page-shell[aria-label="Home"] .hero-title.home-tagline {
    max-width: 9.8ch;
    color: var(--fg);
    font-family: var(--font-display);
    font-size: clamp(30pt, 12.4vw, 42pt);
    font-weight: 700;
    line-height: 0.96;
    letter-spacing: 0;
  }

  .page-shell[aria-label="Home"] .home-tagline-line {
    white-space: normal;
  }

  .page-shell[aria-label="Home"] .hero-title.home-tagline .word {
    display: inline-block;
  }

  .page-shell[aria-label="Home"] .home-hero-copy {
    max-width: 29ch;
    color: var(--muted);
    font-size: clamp(11pt, 4.15vw, 12.25pt);
    line-height: 1.35;
  }

  .page-shell[aria-label="Home"] .home-hero .hero-actions {
    gap: 8px;
    margin-top: 0;
  }

  .page-shell[aria-label="Home"] .home-hero .hero-actions .cta {
    min-height: 36px;
    border-color: var(--fg);
    font-family: var(--font-base);
    font-size: clamp(7.6pt, 2.55vw, 8.6pt);
  }

  .page-shell[aria-label="Home"] .home-hero .hero-actions .cta:not(.cta-secondary) {
    background: var(--fg);
    color: var(--bg);
  }

  .page-shell[aria-label="Home"] .home-hero .hero-actions .cta-secondary {
    background: transparent;
    color: var(--fg);
  }

  .page-shell[aria-label="Home"] .hero-title.home-tagline .word {
    opacity: 0;
    transform: translateY(0.55em);
    animation: wordIn 900ms var(--easing) forwards;
    animation-delay: calc(120ms + (var(--i) * 90ms));
  }

  .page-shell[aria-label="Home"] .home-hero-copy[data-line-reveal] {
    opacity: 0;
  }

  .page-shell[aria-label="Home"] .home-hero-copy[data-line-reveal].is-line-ready {
    opacity: 1;
  }

  .page-shell[aria-label="Home"] .home-hero-copy .copy-line {
    display: block;
    opacity: 0;
    transform: translateY(0.75em);
    animation: focusCopyLineIn 620ms var(--easing) forwards;
    animation-delay: calc(520ms + (var(--line) * 70ms));
  }

  .page-shell[aria-label="Home"] .home-hero .hero-actions {
    opacity: 0;
    transform: translateY(14px);
    animation: heroActionsIn 520ms var(--easing) forwards;
    animation-delay: 900ms;
  }

  .page-shell[aria-label="Home"] .home-hero-grid {
    display: grid;
    gap: clamp(12px, 4vw, 18px);
    align-content: center;
    min-height: calc(100svh - var(--nav-h) - clamp(42px, 14vw, 64px));
  }

  .page-shell[aria-label="Home"] .home-system-visual {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: clamp(260px, 78vw, 360px);
    max-height: none;
    margin-top: clamp(8px, 3vw, 16px);
    overflow: hidden;
    opacity: 0;
    transform: scale(0.94);
    animation: systemVisualIn 900ms var(--easing) forwards;
    animation-delay: 520ms;
  }

  .page-shell[aria-label="Home"] .system-map {
    --system-core-size: clamp(104px, 30vw, 136px);
    --system-core-ring-size: clamp(56px, 16.2vw, 73.4px);
    flex: 0 0 min(124vw, 460px);
    justify-self: center;
    align-self: center;
    width: min(124vw, 460px);
    max-width: none;
  }
}

@media (min-width: 1600px) {
  :root {
    --page-pad: 72px;
    --nav-pad: 18px;
    --page-hero-grid-gap: 109px;
    --page-hero-content-gap: 14px;
    --page-title-size: clamp(25.5pt, 5vw, 46.5pt);
    --section-title-size: clamp(25.5pt, 5vw, 46.5pt);
    --page-copy-size: clamp(11.25pt, 1.15vw, 12.75pt);
    --section-copy-size: clamp(11.25pt, 1.15vw, 12.75pt);
    --page-copy-max: min(760px, 100%);
  }

  .section {
    padding-top: 144px;
    padding-bottom: 144px;
  }

  .section-tight {
    padding-top: 92px;
    padding-bottom: 92px;
  }

  .home-hero-grid,
  .focus-hero-grid,
  .contact-hero-grid,
  .about-hero-grid,
  .focus-operating-grid,
  .focus-outcome-panel,
  .contact-form-grid,
  .footer-primary,
  .footer-bottom {
    width: 100%;
    max-width: 1760px;
    margin-right: auto;
    margin-left: auto;
  }

  .home-hero-grid,
  .focus-hero-grid,
  .contact-hero-grid {
    grid-template-columns: minmax(0, 0.58fr) minmax(320px, 0.42fr);
  }

  .about-hero-grid {
    grid-template-columns: minmax(0, 0.54fr) minmax(280px, 0.46fr);
  }

  .home-hero-content,
  .focus-hero-content,
  .contact-hero-content {
    max-width: 900px;
  }

  .about-hero-content {
    max-width: 760px;
  }

  .hero-title.home-tagline,
  .focus-title,
  .about-title,
  .contact-title {
    max-width: 880px;
  }

  .home-hero-copy,
  .focus-hero-copy,
  .about-hero-copy,
  .contact-hero-copy {
    max-width: var(--page-copy-max);
  }

  .home-system-visual,
  .focus-lens-visual,
  .contact-signal-visual,
  .about-globe-visual {
    justify-self: stretch;
  }

  .system-map {
    width: min(100%, 620px);
  }

  .focus-lens-map {
    width: min(100%, 560px);
  }

  .signal-map {
    width: min(100%, 540px);
  }

  .about-globe {
    width: min(100%, 461px);
  }

  .home-section-lede,
  .solutions-grid,
  .home-value-grid,
  .industry-list,
  .products-showcase-heading,
  .products-showcase,
  .contact-methods-grid {
    width: 100%;
    max-width: 1760px;
    margin-right: auto;
    margin-left: auto;
  }

  .home-section-title,
  .products-showcase-title {
    max-width: 930px;
  }

  .solution-card {
    min-height: 240px;
  }

  .home-capabilities-grid .solution-card {
    min-height: 294px;
  }

  .industry-list li {
    min-height: 102px;
  }

  .products-showcase {
    gap: 56px;
  }

  .product-cover {
    height: 293px;
  }

  .product-document-hero {
    max-width: none;
    padding-top: 0;
    margin-right: auto;
    margin-left: auto;
  }

  .product-document-shell,
  .product-document-topbar,
  .product-info-stack {
    max-width: 1760px;
    margin-right: auto;
    margin-left: auto;
  }

  .product-title {
    max-width: min(640px, 100%);
    font-size: 43pt;
  }

  .detail-overview {
    max-width: none;
  }

  .product-info-stack {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(72px, 6vw, 128px);
    row-gap: 56px;
  }

  .product-info-subtitle,
  .product-info-copy,
  .product-info-points {
    max-width: 72ch;
  }

  .footer-primary {
    grid-template-columns: minmax(220px, 0.42fr) minmax(320px, 0.58fr);
  }

  .footer-statement {
    max-width: 420px;
  }
}
