:root {
  --bg: #efe8db;
  --bg-deep: #dfd5c2;
  --surface: rgba(255, 250, 241, 0.76);
  --surface-strong: rgba(255, 249, 240, 0.92);
  --line: rgba(23, 31, 26, 0.12);
  --line-strong: rgba(23, 31, 26, 0.22);
  --ink: #18221c;
  --muted: #5d675d;
  --olive: #47593f;
  --olive-soft: #667a58;
  --teal: #7ca79f;
  --sage: #a7bf8a;
  --sand: #ccb27a;
  --mist: #dce6dc;
  --white: #fffaf2;
  --shadow-lg: 0 26px 80px rgba(28, 34, 27, 0.14);
  --shadow-md: 0 18px 44px rgba(28, 34, 27, 0.1);
  --radius-xl: 32px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 14px;
  --container: min(1160px, calc(100vw - 48px));
  --pointer-x: 50%;
  --pointer-y: 50%;
  --orb-x: 50%;
  --orb-y: 50%;
  --body-radial-left: rgba(124, 167, 159, 0.24);
  --body-radial-right: rgba(204, 178, 122, 0.2);
  --body-gradient-start: #f5efe4;
  --body-gradient-mid: var(--bg);
  --body-gradient-end: #ebe3d3;
  --inner-body-gradient-start: #f6f0e5;
  --inner-body-gradient-mid: #ede4d5;
  --inner-body-gradient-end: #e9dfcf;
  --grid-line: rgba(24, 34, 28, 0.028);
  --header-scrolled-bg: rgba(245, 239, 228, 0.76);
  --header-scrolled-border: rgba(24, 34, 28, 0.08);
  --nav-bg: rgba(255, 250, 242, 0.54);
  --nav-border: rgba(24, 34, 28, 0.08);
  --button-secondary-bg:
    linear-gradient(
      130deg,
      rgba(255, 250, 242, 0.94),
      rgba(230, 239, 230, 0.76),
      rgba(247, 241, 228, 0.92)
    );
  --button-secondary-border: rgba(24, 34, 28, 0.12);
  --card-border: rgba(24, 34, 28, 0.08);
  --card-border-strong: rgba(24, 34, 28, 0.12);
  --card-surface: rgba(255, 250, 242, 0.68);
  --card-surface-strong: rgba(255, 252, 247, 0.86);
  --panel-surface:
    linear-gradient(180deg, rgba(255, 252, 247, 0.93), rgba(241, 235, 224, 0.88)),
    rgba(255, 252, 247, 0.9);
  --sensor-stage-surface:
    linear-gradient(180deg, rgba(255, 252, 247, 0.94), rgba(242, 236, 226, 0.9)),
    rgba(255, 252, 247, 0.92);
  --proof-surface: rgba(255, 250, 242, 0.64);
  --metric-surface: rgba(255, 250, 242, 0.78);
  --pill-surface: rgba(71, 89, 63, 0.08);
  --pill-border: rgba(24, 34, 28, 0.08);
  --focus-band-surface:
    linear-gradient(180deg, rgba(255, 250, 242, 0.34), rgba(255, 250, 242, 0.08)),
    rgba(240, 234, 222, 0.44);
  --faq-item-surface:
    linear-gradient(180deg, rgba(255, 252, 247, 0.92), rgba(242, 236, 226, 0.82)),
    rgba(255, 250, 242, 0.78);
  --input-border: rgba(24, 34, 28, 0.12);
  --input-bg: rgba(255, 250, 242, 0.86);
  --input-bg-focus: rgba(255, 252, 247, 0.94);
  --detail-divider: rgba(24, 34, 28, 0.08);
  --toggle-bg: rgba(255, 250, 242, 0.68);
  --toggle-border: rgba(24, 34, 28, 0.1);
  --toggle-shadow: 0 12px 30px rgba(28, 34, 27, 0.08);
  --toggle-label: var(--ink);
  --theme-icon-core:
    radial-gradient(circle at 32% 28%, rgba(255, 248, 239, 0.88), rgba(255, 248, 239, 0.14) 18%, rgba(255, 248, 239, 0) 28%),
    linear-gradient(160deg, rgba(213, 180, 125, 0.96) 0%, rgba(212, 202, 180, 0.84) 46%, rgba(132, 182, 174, 0.94) 100%);
  --theme-icon-eclipse: rgba(255, 248, 239, 0.96);
  --theme-icon-eclipse-x: 5px;
  --theme-icon-eclipse-y: -5px;
  --theme-icon-eclipse-scale: 0.74;
  --theme-icon-glint-opacity: 0.92;
  --theme-icon-glint-scale: 1;
  --chart-area-start: rgba(124, 167, 159, 0.12);
  --chart-area-end: rgba(124, 167, 159, 0.02);
  --chart-node-plant: #546b4a;
  --chart-node-liquid: #7ca79f;
  --chart-node-shell: rgba(255, 250, 242, 0.92);
  --chart-threshold: rgba(204, 178, 122, 0.7);
  --chart-glow-start: rgba(255, 250, 242, 0.34);
  --chart-glow-end: rgba(255, 250, 242, 0);
  --chart-plant: #546b4a;
  --chart-liquid: #7ca79f;
  --particle-dark-rgb: 85, 105, 79;
  --particle-teal-rgb: 130, 171, 163;
  --particle-gold-rgb: 202, 164, 92;
  --particle-muted-rgb: 172, 174, 170;
  --particle-line-rgb: 160, 164, 158;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #101612;
  --bg-deep: #0d120f;
  --surface: rgba(22, 29, 25, 0.76);
  --surface-strong: rgba(25, 34, 29, 0.92);
  --line: rgba(255, 248, 239, 0.12);
  --line-strong: rgba(255, 248, 239, 0.22);
  --ink: #f3ece1;
  --muted: #c7c0b2;
  --olive: #b4c39c;
  --olive-soft: #91a882;
  --teal: #84b6ae;
  --sage: #a0b987;
  --sand: #d5b47d;
  --mist: #bfd3cb;
  --white: #fff8ef;
  --shadow-lg: 0 28px 88px rgba(0, 0, 0, 0.34);
  --shadow-md: 0 18px 44px rgba(0, 0, 0, 0.28);
  --body-radial-left: rgba(124, 167, 159, 0.18);
  --body-radial-right: rgba(204, 178, 122, 0.12);
  --body-gradient-start: #101612;
  --body-gradient-mid: #141b17;
  --body-gradient-end: #0d120f;
  --inner-body-gradient-start: #111713;
  --inner-body-gradient-mid: #141b17;
  --inner-body-gradient-end: #0d120f;
  --grid-line: rgba(255, 248, 239, 0.038);
  --header-scrolled-bg: rgba(45, 56, 50, 0.9);
  --header-scrolled-border: rgba(255, 248, 239, 0.08);
  --nav-bg: rgba(39, 49, 44, 0.78);
  --nav-border: rgba(255, 248, 239, 0.08);
  --button-secondary-bg:
    linear-gradient(
      130deg,
      rgba(24, 32, 28, 0.94),
      rgba(26, 36, 32, 0.88),
      rgba(36, 30, 24, 0.9)
    );
  --button-secondary-border: rgba(255, 248, 239, 0.12);
  --card-border: rgba(255, 248, 239, 0.08);
  --card-border-strong: rgba(255, 248, 239, 0.12);
  --card-surface: rgba(19, 26, 23, 0.74);
  --card-surface-strong: rgba(24, 32, 28, 0.9);
  --panel-surface:
    linear-gradient(180deg, rgba(20, 27, 24, 0.96), rgba(15, 21, 18, 0.92)),
    rgba(20, 27, 24, 0.9);
  --sensor-stage-surface:
    linear-gradient(180deg, rgba(20, 27, 24, 0.96), rgba(15, 21, 18, 0.92)),
    rgba(20, 27, 24, 0.9);
  --proof-surface: rgba(19, 26, 23, 0.76);
  --metric-surface: rgba(22, 29, 25, 0.84);
  --pill-surface: rgba(255, 248, 239, 0.08);
  --pill-border: rgba(255, 248, 239, 0.08);
  --focus-band-surface:
    linear-gradient(180deg, rgba(20, 27, 24, 0.78), rgba(14, 19, 17, 0.94)),
    rgba(18, 24, 21, 0.78);
  --faq-item-surface:
    linear-gradient(180deg, rgba(24, 32, 28, 0.94), rgba(16, 22, 19, 0.9)),
    rgba(21, 28, 24, 0.88);
  --input-border: rgba(255, 248, 239, 0.12);
  --input-bg: rgba(17, 23, 20, 0.88);
  --input-bg-focus: rgba(22, 29, 25, 0.96);
  --detail-divider: rgba(255, 248, 239, 0.08);
  --toggle-bg: rgba(41, 51, 46, 0.82);
  --toggle-border: rgba(255, 248, 239, 0.1);
  --toggle-shadow: 0 14px 34px rgba(0, 0, 0, 0.2);
  --toggle-label: var(--white);
  --theme-icon-core:
    radial-gradient(circle at 32% 28%, rgba(255, 248, 239, 0.72), rgba(255, 248, 239, 0.08) 18%, rgba(255, 248, 239, 0) 28%),
    linear-gradient(160deg, rgba(213, 180, 125, 0.96) 0%, rgba(186, 193, 170, 0.82) 46%, rgba(132, 182, 174, 0.94) 100%);
  --theme-icon-eclipse: rgba(17, 23, 20, 0.94);
  --theme-icon-eclipse-x: -3px;
  --theme-icon-eclipse-y: 1px;
  --theme-icon-eclipse-scale: 1.04;
  --theme-icon-glint-opacity: 0.16;
  --theme-icon-glint-scale: 0.68;
  --chart-area-start: rgba(124, 167, 159, 0.2);
  --chart-area-end: rgba(124, 167, 159, 0.04);
  --chart-node-plant: #b4c39c;
  --chart-node-liquid: #84b6ae;
  --chart-node-shell: rgba(255, 248, 239, 0.88);
  --chart-threshold: rgba(213, 180, 125, 0.62);
  --chart-glow-start: rgba(124, 167, 159, 0.24);
  --chart-glow-end: rgba(124, 167, 159, 0);
  --chart-plant: #b4c39c;
  --chart-liquid: #84b6ae;
  --particle-dark-rgb: 180, 195, 156;
  --particle-teal-rgb: 132, 182, 174;
  --particle-gold-rgb: 213, 180, 125;
  --particle-muted-rgb: 186, 194, 184;
  --particle-line-rgb: 122, 140, 130;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 320px;
  font-family: "Manrope", "Segoe UI Variable Text", "Segoe UI", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top left, var(--body-radial-left), transparent 28%),
    radial-gradient(circle at 85% 12%, var(--body-radial-right), transparent 24%),
    linear-gradient(180deg, var(--body-gradient-start) 0%, var(--body-gradient-mid) 42%, var(--body-gradient-end) 100%);
  line-height: 1.55;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 88%);
  pointer-events: none;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea,
select {
  font: inherit;
}

img {
  max-width: 100%;
  display: block;
}

.container {
  width: var(--container);
  margin: 0 auto;
}

.page-glow {
  position: fixed;
  width: 34rem;
  height: 34rem;
  border-radius: 999px;
  filter: blur(80px);
  opacity: 0.48;
  pointer-events: none;
  z-index: 0;
}

.page-glow-left {
  top: -10rem;
  left: -12rem;
  background: rgba(124, 167, 159, 0.24);
}

.page-glow-right {
  top: 30%;
  right: -12rem;
  background: rgba(207, 171, 110, 0.18);
}

.site-header,
.site-footer,
section {
  position: relative;
  z-index: 1;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  padding: 14px 0;
  border-bottom: 1px solid transparent;
  transition: background-color 180ms ease, backdrop-filter 180ms ease, border-color 180ms ease;
}

.site-header.is-scrolled {
  background: var(--header-scrolled-bg);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--header-scrolled-border);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 14px;
}

.brand-icon {
  width: 54px;
  height: 54px;
  object-fit: contain;
}

.brand-wordmark {
  height: 46px;
  width: auto;
  object-fit: contain;
}

.brand-icon-footer {
  width: 68px;
  height: 68px;
}

.brand-wordmark-footer {
  height: 56px;
}

.site-nav {
  display: inline-flex;
  align-items: center;
  gap: 22px;
  padding: 10px 18px;
  border: 1px solid var(--nav-border);
  border-radius: 999px;
  background: var(--nav-bg);
  backdrop-filter: blur(8px);
}

.header-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin-left: auto;
  flex-wrap: wrap;
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 46px;
  padding: 0 18px 0 14px;
  border-radius: 999px;
  border: 1px solid var(--toggle-border);
  background: var(--toggle-bg);
  color: var(--toggle-label);
  cursor: pointer;
  backdrop-filter: blur(12px);
  box-shadow: var(--toggle-shadow);
  isolation: isolate;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 180ms ease;
}

.theme-toggle:hover,
.theme-toggle:focus-visible {
  transform: translateY(-1px);
  border-color: var(--line-strong);
}

.theme-toggle-icon {
  position: relative;
  width: 26px;
  height: 26px;
  flex: none;
  border-radius: 999px;
  background: var(--theme-icon-core);
  box-shadow:
    inset 0 0 0 1px rgba(255, 248, 239, 0.18),
    0 8px 18px rgba(24, 34, 28, 0.1);
  overflow: hidden;
  will-change: transform;
  transition:
    transform 680ms cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 320ms ease;
}

.theme-toggle-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--theme-icon-eclipse);
  transform: translate(var(--theme-icon-eclipse-x), var(--theme-icon-eclipse-y))
    scale(var(--theme-icon-eclipse-scale));
  transform-origin: center;
  transition:
    transform 680ms cubic-bezier(0.22, 1, 0.36, 1),
    background-color 320ms ease,
    opacity 320ms ease;
}

.theme-toggle-icon::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: inherit;
  background:
    radial-gradient(circle at 34% 28%, rgba(255, 248, 239, 0.96), rgba(255, 248, 239, 0.36) 32%, rgba(255, 248, 239, 0) 64%);
  opacity: var(--theme-icon-glint-opacity);
  transform: scale(var(--theme-icon-glint-scale));
  transform-origin: 34% 28%;
  transition:
    transform 680ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 320ms ease;
}

.theme-toggle.is-transitioning .theme-toggle-icon {
  animation: themeToggleOrbSettle 820ms cubic-bezier(0.16, 1, 0.3, 1);
}

.site-nav a {
  color: var(--muted);
  font-size: 0.96rem;
  transition: color 160ms ease;
}

.site-nav a:hover,
.site-nav a:focus-visible {
  color: var(--ink);
}

.site-nav a[aria-current="page"] {
  color: var(--ink);
  font-weight: 700;
}

.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  background:
    linear-gradient(125deg, #344238, #55684a, #7ca79f, #ccb27a, #344238);
  background-size: 240% 240%;
  color: var(--white);
  font-weight: 700;
  letter-spacing: 0;
  min-width: 0;
  max-width: 100%;
  text-align: center;
  box-shadow: 0 16px 32px rgba(52, 65, 56, 0.18);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
  animation: buttonFlow 8s ease infinite;
  overflow: hidden;
  isolation: isolate;
}

.button::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    radial-gradient(circle at 22% 20%, rgba(255, 255, 255, 0.18), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(0, 0, 0, 0.08));
  z-index: -1;
}

.button::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 20%, rgba(255, 255, 255, 0.28) 48%, transparent 76%);
  transform: translateX(-120%);
  transition: transform 400ms ease;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 20px 36px rgba(52, 65, 56, 0.24);
}

.button:hover::after,
.button:focus-visible::after {
  transform: translateX(120%);
}

.button-secondary,
.button-ghost {
  color: var(--ink);
  border-color: var(--button-secondary-border);
  background: var(--button-secondary-bg);
  background-size: 220% 220%;
  box-shadow: none;
}

.button-small {
  min-height: 42px;
  padding: 0 18px;
}

body.home-opening-active {
  overflow: hidden;
}

.home-opening {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  min-width: 320px;
  place-items: center;
  overflow: hidden;
  color: #151715;
  isolation: isolate;
  --opening-ink: #151715;
  --opening-soft-ink: #4a4443;
  --opening-border: rgba(21, 23, 21, 0.22);
}

.home-opening::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(circle at top left, rgba(124, 167, 159, 0.24), transparent 28%),
    radial-gradient(circle at 85% 12%, rgba(204, 178, 122, 0.2), transparent 24%),
    linear-gradient(180deg, #f5efe4 0%, #efe8db 42%, #ebe3d3 100%);
  transition: opacity 760ms cubic-bezier(0.22, 1, 0.36, 1);
}

.home-opening::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(rgba(24, 34, 28, 0.028) 1px, transparent 1px),
    linear-gradient(90deg, rgba(24, 34, 28, 0.028) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.42), transparent 88%);
  pointer-events: none;
  transition: opacity 620ms ease;
}

.loader-wrapper {
  position: relative;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background-color: transparent;
  user-select: none;
  -webkit-mask-image: radial-gradient(circle, #000 0 76%, rgba(0, 0, 0, 0.72) 84%, transparent 96%);
  mask-image: radial-gradient(circle, #000 0 76%, rgba(0, 0, 0, 0.72) 84%, transparent 96%);
}

.loader {
  position: absolute;
  inset: 0;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background-color: transparent;
  animation: loader-rotate 2s linear infinite;
  box-shadow: 0 12px 28px rgba(71, 89, 63, 0.18);
}

.home-opening-globe {
  position: absolute;
  top: 50%;
  right: clamp(-390px, -22vw, -260px);
  z-index: 0;
  width: clamp(590px, 48vw, 860px);
  height: clamp(590px, 48vw, 860px);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transform: translate3d(28px, -50%, 0) scale(0.98);
  filter: saturate(0.98) contrast(1.02);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.45) 18%, #000 38%);
  mask-image: linear-gradient(90deg, transparent 0%, rgba(0, 0, 0, 0.45) 18%, #000 38%);
  animation: homeOpeningGlobeReveal 1200ms cubic-bezier(0.22, 1, 0.36, 1) 1300ms forwards;
}

.home-opening-globe::before {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 42% 48%, rgba(124, 167, 159, 0.18), transparent 44%),
    radial-gradient(circle at 66% 38%, rgba(204, 178, 122, 0.12), transparent 48%);
  filter: blur(24px);
  opacity: 0.8;
}

.home-opening-globe .home-opening-globe-canvas {
  width: 100%;
  height: 100%;
  min-height: 0;
}

.home-opening-stage {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(1180px, calc(100vw - 48px));
  min-height: min(720px, 100svh);
  place-items: center;
  align-content: center;
  gap: clamp(28px, 5vh, 50px);
  padding: clamp(28px, 6vw, 74px) 0;
}

@media (min-width: 781px) {
  .home-opening-identity {
    transform: translateX(clamp(-132px, -7vw, -78px));
  }
}

.home-opening-identity {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: clamp(18px, 3.5vw, 56px);
}

.home-opening-sigil {
  display: grid;
  width: clamp(260px, 43vmin, 470px);
  flex: 0 0 auto;
  aspect-ratio: 1;
  place-items: center;
  transform-origin: center;
}

.home-opening-sigil svg {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.home-opening-sigil path {
  vector-effect: non-scaling-stroke;
}

.home-opening-sigil svg path:not([fill]),
.home-opening-wordmark svg path:not([fill]) {
  fill: var(--opening-ink);
}

.home-opening-sigil .animated-part {
  transform-box: view-box;
  transform-origin: 50% 50%;
}

.home-opening-sigil .core-part {
  opacity: 0;
  animation: homeOpeningCoreGrow 820ms cubic-bezier(0.16, 0.9, 0.18, 1) 160ms forwards;
}

.home-opening-sigil .core-part > path {
  fill: #000000 !important;
  stroke: none !important;
}

.home-opening-sigil .branch-part {
  clip-path: circle(8% at 50% 50%);
  opacity: 0;
  filter: blur(2px);
  animation: homeOpeningBranchReveal 920ms cubic-bezier(0.28, 0.58, 0.18, 1) var(--branch-delay) forwards;
}

.home-opening-sigil .constellation-part {
  opacity: 0;
  transform: translate(var(--start-x, 0), var(--start-y, 0)) scale(0.94);
  transform-origin: var(--origin-x, 50%) var(--origin-y, 50%);
  animation:
    homeOpeningConstellationForm 560ms ease-out var(--constellation-delay) forwards,
    homeOpeningConstellationAlive var(--alive-speed, 5.8s) ease-in-out calc(var(--constellation-delay) + 640ms) infinite;
}

.home-opening-sigil .constellation-part path {
  fill: #111111 !important;
  stroke: #111111;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 0.9;
}

.home-opening-sigil .constellation-part path[fill="#fff"],
.home-opening-sigil .constellation-part path[fill="#ffffff"],
.home-opening-sigil .constellation-part path[fill="#fefefe"] {
  fill: #ffffff !important;
  stroke: #ffffff;
}

.home-opening-brand-name {
  position: relative;
  flex: 0 1 auto;
  width: clamp(330px, 44vw, 630px);
  max-width: min(630px, calc(100vw - 40px));
  margin: 0;
  overflow: hidden;
  color: var(--opening-ink);
  font: inherit;
  letter-spacing: 0;
  line-height: 1;
  opacity: 0;
  text-transform: uppercase;
  transform: translateX(-44px);
  transform-origin: center;
  white-space: nowrap;
  animation: homeOpeningNameReveal 920ms cubic-bezier(0.18, 0.82, 0.2, 1) 3.75s forwards;
}

.home-opening-wordmark {
  display: block;
  transform: translateX(-105%);
  animation: homeOpeningNameSlide 920ms cubic-bezier(0.18, 0.82, 0.2, 1) 3.75s forwards;
}

.home-opening-wordmark svg {
  display: block;
  width: 100%;
  height: auto;
}

.home-opening-fallback-art {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.home-opening-fallback-wordmark {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.home-opening-enter {
  min-width: 150px;
  border-color: var(--opening-border);
  background: rgba(255, 255, 255, 0.06);
  color: var(--opening-ink);
  opacity: 0;
  box-shadow: none;
  transform: translateY(14px);
  animation: none;
  transition:
    opacity 520ms ease,
    transform 520ms cubic-bezier(0.22, 1, 0.36, 1),
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 180ms ease;
}

.home-opening-enter::before {
  background: none;
}

.home-opening-enter::after {
  background: linear-gradient(110deg, transparent 20%, rgba(21, 23, 21, 0.08) 48%, transparent 76%);
}

.home-opening-enter:hover,
.home-opening-enter:focus-visible {
  border-color: rgba(21, 23, 21, 0.34);
  background: rgba(21, 23, 21, 0.035);
  box-shadow: none;
}

.home-opening-enter[disabled] {
  cursor: default;
  pointer-events: none;
}

.home-opening.is-ready .home-opening-enter {
  opacity: 1;
  transform: translateY(0);
}

.home-opening.is-ready .home-opening-brand-name,
.home-opening.is-ready .home-opening-wordmark {
  opacity: 1;
  transform: none;
}

.home-opening.is-transitioning {
  pointer-events: none;
}

.home-opening.is-transitioning::before,
.home-opening.is-transitioning::after {
  opacity: 0;
}

.home-opening.is-transitioning .home-opening-enter {
  opacity: 0;
  transform: translateY(12px);
}

.home-opening.is-transitioning .home-opening-globe {
  visibility: hidden;
  opacity: 0;
  animation: none;
  transition: none;
}

.home-opening.is-transitioning .home-opening-sigil,
.home-opening.is-transitioning .home-opening-brand-name {
  animation: homeOpeningDockPart 1080ms cubic-bezier(0.16, 1, 0.3, 1) forwards;
  will-change: transform;
}

.home-opening.is-transitioning .home-opening-brand-name {
  animation-delay: 45ms;
}

.home-opening.is-complete {
  visibility: hidden;
}

.site-header .brand.is-opening-docking {
  visibility: hidden;
}

@keyframes homeOpeningCoreGrow {
  0% {
    opacity: 0;
    transform: scale(0.02);
  }

  58% {
    opacity: 1;
    transform: scale(1.08);
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes homeOpeningBranchReveal {
  0% {
    clip-path: circle(8% at 50% 50%);
    opacity: 0;
    filter: blur(2px);
  }

  46% {
    clip-path: circle(68% at 50% 50%);
    opacity: 0.9;
    filter: blur(0.45px);
  }

  72%,
  100% {
    clip-path: circle(140% at 50% 50%);
    opacity: 1;
    filter: none;
  }
}

@keyframes homeOpeningConstellationForm {
  0% {
    opacity: 0;
    transform: translate(var(--start-x, 0), var(--start-y, 0)) scale(0.985);
  }

  45% {
    opacity: 1;
  }

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

@keyframes homeOpeningConstellationAlive {
  0%,
  100% {
    transform: translate(0, 0) rotate(0deg);
  }

  50% {
    transform: translate(var(--alive-x, 2px), var(--alive-y, -2px)) rotate(var(--alive-rotate, 1deg));
  }
}

@keyframes homeOpeningNameReveal {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes homeOpeningNameSlide {
  to {
    transform: translateX(0);
  }
}

@keyframes homeOpeningDockPart {
  to {
    transform: translate3d(var(--opening-dock-x, 0), var(--opening-dock-y, 0), 0)
      scale(var(--opening-dock-scale, 1));
  }
}

@keyframes homeOpeningGlobeReveal {
  to {
    opacity: 0.68;
    transform: translate3d(0, -50%, 0) scale(1);
  }
}

@keyframes loader-rotate {
  0% {
    transform: rotate(90deg);
    box-shadow:
      0 10px 20px 0 #fffaf2 inset,
      0 20px 30px 0 #ccb27a inset,
      0 60px 60px 0 #7ca79f inset,
      0 12px 28px rgba(71, 89, 63, 0.18);
  }
  50% {
    transform: rotate(270deg);
    box-shadow:
      0 10px 20px 0 #fffaf2 inset,
      0 20px 10px 0 #95aa8e inset,
      0 40px 60px 0 #47593f inset,
      0 12px 28px rgba(71, 89, 63, 0.18);
  }
  100% {
    transform: rotate(450deg);
    box-shadow:
      0 10px 20px 0 #fffaf2 inset,
      0 20px 30px 0 #ccb27a inset,
      0 60px 60px 0 #7ca79f inset,
      0 12px 28px rgba(71, 89, 63, 0.18);
  }
}

@media (max-width: 780px) {
  .home-opening-globe {
    display: none;
  }

  .home-opening-stage {
    width: min(100vw - 40px, 680px);
    min-height: 100svh;
    gap: 26px;
    padding: 20px 0;
  }

  .home-opening-identity {
    flex-direction: column;
    gap: 18px;
  }

  .home-opening-sigil {
    width: min(68vw, 300px);
  }

  .home-opening-brand-name {
    width: min(66vw, 260px);
    max-width: 86vw;
    transform: translateY(-16px);
    text-align: center;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-opening,
  .home-opening::before,
  .home-opening::after,
  .loader,
  .home-opening-globe,
  .home-opening-sigil .core-part,
  .home-opening-sigil .branch-part,
  .home-opening-sigil .constellation-part,
  .home-opening-brand-name,
  .home-opening-wordmark,
  .home-opening-enter {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 1ms !important;
  }

  .home-opening-sigil .core-part,
  .home-opening-sigil .branch-part,
  .home-opening-sigil .constellation-part,
  .home-opening-brand-name,
  .home-opening-wordmark,
  .home-opening-globe,
  .home-opening-enter {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .home-opening-globe {
    opacity: 0.68;
    transform: translate3d(0, -50%, 0) scale(1);
  }
}

.hero {
  padding: 42px 0 34px;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.03fr 0.97fr;
  gap: 48px;
  align-items: center;
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--olive);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.77rem;
}

h1,
h2,
h3 {
  margin: 0;
  font-family: "Sora", "Aptos Display", sans-serif;
  letter-spacing: 0;
  line-height: 1.02;
  text-wrap: balance;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: manual;
}

h1 {
  max-width: 10ch;
  font-size: clamp(3.4rem, 7vw, 6.4rem);
}

h2 {
  font-size: clamp(2.1rem, 4vw, 3.5rem);
  max-width: 15ch;
}

h3 {
  font-size: 1.36rem;
}

.hero-text,
.section-heading p,
.product-card p,
.platform-card p,
.problem-card p,
.process-track p,
.market-copy p,
.market-note,
.team-card p,
.site-footer p {
  color: var(--muted);
}

.hero-text {
  max-width: 58ch;
  margin: 22px 0 0;
  font-size: 1.08rem;
}

.hero-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.signal-list {
  list-style: none;
  padding: 0;
  margin: 30px 0 0;
  display: grid;
  gap: 12px;
}

.signal-list li {
  position: relative;
  padding-left: 22px;
  color: var(--muted);
}

.signal-list li::before {
  content: "";
  position: absolute;
  top: 0.68em;
  left: 0;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--teal), var(--sand));
  box-shadow: 0 0 0 5px rgba(124, 167, 159, 0.1);
}

.hero-visual {
  position: relative;
  min-height: 620px;
}

.dashboard-card {
  border: 1px solid var(--card-border);
  border-radius: var(--radius-xl);
  background: var(--panel-surface);
  box-shadow: var(--shadow-lg);
}

.dashboard-card-main {
  position: absolute;
  inset: 30px 34px 40px 0;
  padding: 28px;
  overflow: hidden;
}

.dashboard-card-main::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 14%, rgba(124, 167, 159, 0.22), transparent 30%),
    radial-gradient(circle at 88% 8%, rgba(204, 178, 122, 0.18), transparent 22%);
  pointer-events: none;
}

.dashboard-topline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--olive);
  margin-bottom: 26px;
}

.status-dot {
  position: relative;
  width: 11px;
  height: 11px;
  flex: none;
  border-radius: 999px;
  background: var(--olive-soft);
  box-shadow:
    0 0 0 8px rgba(102, 122, 88, 0.1),
    0 0 14px rgba(124, 167, 159, 0.14);
}

.status-dot::before,
.status-dot::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  border: 1px solid rgba(124, 167, 159, 0.42);
  opacity: 0;
  transform: scale(1);
  animation: statusDotRipple 4.2s cubic-bezier(0.22, 0.61, 0.36, 1) infinite;
}

.status-dot::after {
  animation-delay: 2.1s;
}

@keyframes statusDotRipple {
  0%,
  16% {
    opacity: 0;
    transform: scale(1);
  }

  22% {
    opacity: 0.45;
    transform: scale(1.08);
  }

  54% {
    opacity: 0;
    transform: scale(2.9);
  }

  100% {
    opacity: 0;
    transform: scale(2.9);
  }
}

.chart-shell {
  position: relative;
  height: 212px;
  border-radius: 24px;
  border: 1px solid var(--card-border);
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(231, 239, 230, 0.56));
}

.chart-grid-background {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 32px 32px;
}

.hero-chart-canvas {
  position: relative;
  width: 100%;
  height: 100%;
  display: block;
}

.metric-grid {
  margin-top: 24px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.metric-grid article {
  padding: 16px 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: var(--metric-surface);
}

.metric-label {
  display: block;
  color: var(--muted);
  font-size: 0.85rem;
}

.metric-grid strong {
  display: block;
  margin-top: 8px;
  font-size: 1.55rem;
  font-family: "Sora", "Aptos Display", sans-serif;
}

.metric-grid small {
  display: block;
  margin-top: 6px;
  color: var(--olive);
}

.dashboard-card-float {
  position: absolute;
  width: 260px;
  padding: 20px 22px;
  display: grid;
  gap: 8px;
  backdrop-filter: blur(12px);
  animation: sensorFloat 5.6s ease-in-out infinite;
}

.dashboard-card-float p,
.market-title,
.product-label {
  margin: 0;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--olive);
  font-weight: 800;
}

.dashboard-card-float strong {
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: 1.1rem;
}

.dashboard-card-float span {
  color: var(--muted);
  font-size: 0.96rem;
}

.dashboard-card-sunbul {
  top: 0;
  right: 0;
  animation-delay: -0.9s;
}

.dashboard-card-mai {
  right: 12px;
  bottom: 0;
  animation-delay: -2.1s;
}

.proof-strip {
  margin-top: 34px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.proof-strip article {
  padding: 22px 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: var(--proof-surface);
  box-shadow: var(--shadow-md);
}

.proof-strip strong {
  display: block;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: 1.8rem;
}

.proof-strip span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
}

.section {
  padding: 108px 0;
}

.section-heading {
  max-width: 62rem;
}

.section-heading p {
  max-width: 62ch;
  margin: 18px 0 0;
}

.section-problem {
  padding-top: 84px;
}

.problem-grid,
.product-grid,
.platform-grid,
.team-grid {
  display: grid;
  gap: 18px;
}

.problem-grid {
  margin-top: 36px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.problem-card,
.product-card,
.platform-card,
.team-card,
.market-card,
.process-track article {
  position: relative;
  padding: 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: var(--card-surface);
  box-shadow: var(--shadow-md);
}

.tile-card {
  transition:
    transform 220ms ease,
    box-shadow 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease;
  will-change: transform;
}

.tile-card:hover,
.tile-card:focus-within {
  transform: translateY(-8px);
  box-shadow: 0 28px 54px rgba(28, 34, 27, 0.14);
  border-color: var(--line-strong);
  background: var(--card-surface-strong);
}

.tile-card::after {
  content: "";
  position: absolute;
  inset: auto 16px 0;
  height: 2px;
  opacity: 0;
  background: linear-gradient(90deg, rgba(124, 167, 159, 0), rgba(124, 167, 159, 0.72), rgba(204, 178, 122, 0));
  transform: scaleX(0.65);
  transition: opacity 220ms ease, transform 220ms ease;
}

.tile-card:hover::after,
.tile-card:focus-within::after {
  opacity: 1;
  transform: scaleX(1);
}

.problem-card span {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: var(--pill-surface);
  color: var(--olive);
  font-weight: 800;
  font-family: "Sora", "Aptos Display", sans-serif;
  margin-bottom: 18px;
}

.problem-card p,
.platform-card p,
.team-school {
  margin: 14px 0 0;
}

.section-products {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(232, 225, 211, 0.3), rgba(232, 225, 211, 0)),
    transparent;
}

.section-products .container {
  position: relative;
  z-index: 1;
}

.product-grid {
  margin-top: 40px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.product-card {
  display: flex;
  flex-direction: column;
  padding-top: 68px;
  min-height: 100%;
}

.product-card p:not(.product-label) {
  margin-top: 14px;
}

.product-card ul,
.market-tags {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
}

.product-card ul {
  display: grid;
  gap: 12px;
}

.product-card li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
}

.product-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.68em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: var(--olive-soft);
}

.product-card-footer {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--detail-divider);
}

.product-inline-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  font-weight: 800;
  letter-spacing: -0.02em;
  transition: color 180ms ease, gap 180ms ease;
}

.product-inline-link::after {
  content: "->";
  color: var(--olive);
  transition: transform 180ms ease;
}

.product-inline-link:hover,
.product-inline-link:focus-visible {
  color: var(--olive);
  gap: 14px;
}

.product-inline-link:hover::after,
.product-inline-link:focus-visible::after {
  transform: translateX(2px);
}

.product-accent {
  position: absolute;
  top: 22px;
  left: 22px;
  width: 72px;
  height: 18px;
  border-radius: 999px;
}

.product-accent-sunbul {
  background: linear-gradient(90deg, rgba(124, 167, 159, 0.2), rgba(124, 167, 159, 0.75));
}

.product-accent-mai {
  background: linear-gradient(90deg, rgba(204, 178, 122, 0.18), rgba(204, 178, 122, 0.9));
}

.product-card-combined {
  background:
    radial-gradient(circle at top right, rgba(167, 191, 138, 0.18), transparent 36%),
    color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.combined-orb-shell {
  position: absolute;
  top: clamp(360px, 34vw, 460px);
  right: clamp(-252px, -13vw, -152px);
  z-index: 0;
  width: 180px;
  height: 180px;
  pointer-events: none;
  transform: scale(3.55);
  transform-origin: center;
  opacity: 0.78;
}

.combined-map {
  margin-top: 26px;
  min-height: 168px;
  position: relative;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background:
    radial-gradient(circle at center, rgba(124, 167, 159, 0.15), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.7), rgba(236, 243, 234, 0.4));
}

.combined-map span {
  position: absolute;
  padding: 10px 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--card-surface-strong) 96%, transparent);
  border: 1px solid var(--card-border);
  font-weight: 700;
  color: var(--olive);
}

.combined-map span:nth-child(1) {
  top: 20px;
  left: 20px;
}

.combined-map span:nth-child(2) {
  top: 20px;
  right: 20px;
}

.combined-map span:nth-child(3) {
  bottom: 20px;
  left: 20px;
}

.combined-map span:nth-child(4) {
  bottom: 20px;
  right: 20px;
}

.combined-map::before,
.combined-map::after {
  content: "";
  position: absolute;
  inset: 50%;
  width: 2px;
  height: calc(100% - 84px);
  transform: translate(-50%, -50%);
  background: linear-gradient(180deg, rgba(24, 34, 28, 0), rgba(24, 34, 28, 0.16), rgba(24, 34, 28, 0));
}

.combined-map::after {
  width: calc(100% - 84px);
  height: 2px;
  background: linear-gradient(90deg, rgba(24, 34, 28, 0), rgba(24, 34, 28, 0.16), rgba(24, 34, 28, 0));
}

.section-platform {
  position: relative;
  overflow: hidden;
  background: var(--focus-band-surface);
}

.section-platform::before {
  content: "";
  position: absolute;
  inset: 4% 2%;
  border-radius: 40px;
  background:
    radial-gradient(circle at 18% 24%, rgba(124, 167, 159, 0.36), transparent 30%),
    radial-gradient(circle at 82% 66%, rgba(204, 178, 122, 0.3), transparent 28%),
    radial-gradient(circle at 62% 18%, rgba(167, 191, 138, 0.28), transparent 24%);
  filter: blur(12px);
  opacity: 1;
  pointer-events: none;
  animation: sectionGradientMorph 18s ease-in-out infinite alternate;
}

.section-platform::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      circle at var(--pointer-x) var(--pointer-y),
      rgba(255, 255, 255, 0.42),
      rgba(204, 178, 122, 0.16) 14%,
      rgba(124, 167, 159, 0.08) 28%,
      rgba(124, 167, 159, 0) 42%
    ),
    linear-gradient(180deg, rgba(255, 250, 242, 0.14), rgba(255, 250, 242, 0.03));
  pointer-events: none;
  -webkit-mask-image: radial-gradient(circle at center, #000 54%, rgba(0, 0, 0, 0.82) 74%, transparent 100%);
  mask-image: radial-gradient(circle at center, #000 54%, rgba(0, 0, 0, 0.82) 74%, transparent 100%);
}

.section-platform .container {
  position: relative;
  z-index: 1;
}

.section-gradient-orb {
  position: absolute;
  top: 0;
  left: 0;
  width: min(36vw, 480px);
  aspect-ratio: 1;
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(204, 178, 122, 0.48) 0%, rgba(124, 167, 159, 0.38) 34%, rgba(124, 167, 159, 0.14) 58%, rgba(124, 167, 159, 0) 72%);
  filter: blur(42px);
  opacity: 1;
  pointer-events: none;
  transform: translate(calc(var(--orb-x) - 50%), calc(var(--orb-y) - 50%));
  z-index: 0;
}

.platform-layout {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 34px;
  align-items: start;
}

.platform-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.platform-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  color: var(--olive);
  font-weight: 800;
  margin-bottom: 16px;
}

.section-process {
  background:
    radial-gradient(circle at 84% 28%, rgba(124, 167, 159, 0.14), transparent 24%),
    radial-gradient(circle at 14% 76%, rgba(204, 178, 122, 0.12), transparent 24%),
    linear-gradient(180deg, rgba(255, 250, 242, 0.18), rgba(255, 250, 242, 0.52)),
    transparent;
}

.process-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(420px, 540px);
  gap: 42px;
  align-items: center;
}

.process-visual {
  position: relative;
  width: min(100%, 560px);
  justify-self: end;
  min-height: 430px;
  background: none;
  overflow: visible;
}

.process-visual::after {
  content: none;
}

.process-visual::before {
  content: none;
}

.particle-canvas,
.home-action-canvas {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  display: block;
}

.home-action-sphere {
  position: relative;
  width: min(100%, 560px);
  min-height: 430px;
  isolation: isolate;
}

.home-action-sphere::before {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.home-action-sphere::before {
  inset: 10% 12%;
  background:
    radial-gradient(circle at 50% 50%, rgba(124, 167, 159, 0.2), transparent 38%),
    radial-gradient(circle at 58% 42%, rgba(204, 178, 122, 0.16), transparent 46%);
  filter: blur(18px);
  opacity: 0.88;
}

.home-action-canvas {
  min-height: 430px;
}

.process-track {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.process-track article {
  padding: 26px 20px 20px;
}

.process-track strong {
  display: inline-block;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: 1rem;
  color: var(--olive);
}

.process-track h3 {
  margin-top: 16px;
}

.process-track p {
  margin-top: 10px;
}

.market-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: center;
}

.market-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.market-tags li {
  list-style: none;
}

.market-tags span {
  display: inline-flex;
  padding: 11px 16px;
  border-radius: 999px;
  background: var(--pill-surface);
  border: 1px solid var(--pill-border);
  color: var(--olive);
  font-weight: 700;
  transition:
    transform 220ms ease,
    border-color 220ms ease,
    background-color 220ms ease,
    box-shadow 220ms ease;
}

.market-tags span:hover {
  transform: translateY(-4px) scale(1.03);
  border-color: var(--line-strong);
  background: rgba(124, 167, 159, 0.12);
  box-shadow: 0 14px 28px rgba(28, 34, 27, 0.08);
}

.market-note {
  margin: 22px 0 0;
}

.section-intelligence-band {
  position: relative;
  overflow: hidden;
  padding: 96px 0 102px;
  background:
    linear-gradient(180deg, rgba(239, 232, 219, 0) 0%, rgba(242, 237, 228, 0.44) 14%, rgba(238, 234, 223, 0.52) 50%, rgba(242, 237, 228, 0.4) 86%, rgba(239, 232, 219, 0) 100%);
}

.section-intelligence-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 14% 24%, rgba(124, 167, 159, 0.36), transparent 26%),
    radial-gradient(circle at 84% 28%, rgba(204, 178, 122, 0.34), transparent 24%),
    radial-gradient(circle at 56% 78%, rgba(167, 191, 138, 0.22), transparent 24%);
  animation: sectionGradientMorph 20s ease-in-out infinite alternate;
  pointer-events: none;
}

.section-intelligence-band::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 26% 34%, rgba(255, 255, 255, 0.22), rgba(124, 167, 159, 0.1) 16%, rgba(124, 167, 159, 0) 34%),
    radial-gradient(circle at 72% 66%, rgba(255, 255, 255, 0.18), rgba(204, 178, 122, 0.08) 14%, rgba(204, 178, 122, 0) 30%);
  pointer-events: none;
  animation: intelligenceGlowDrift 18s ease-in-out infinite alternate;
}

.section-intelligence-band .section-gradient-orb {
  width: min(42vw, 560px);
  opacity: 1;
  background:
    radial-gradient(circle, rgba(124, 167, 159, 0.58) 0%, rgba(204, 178, 122, 0.34) 36%, rgba(124, 167, 159, 0.14) 62%, rgba(124, 167, 159, 0) 76%);
  animation: intelligenceOrbDrift 22s ease-in-out infinite alternate;
}

.intelligence-band-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 34px;
}

.intelligence-band-copy {
  max-width: 54rem;
}

.intelligence-band-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.intelligence-card {
  padding: 28px 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface) 88%, transparent);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-md);
}

.intelligence-card span {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  border: 1px solid var(--pill-border);
  color: var(--olive);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.intelligence-card p {
  margin: 14px 0 0;
  color: var(--muted);
}

.team-grid {
  margin-top: 38px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.team-card {
  display: grid;
  grid-template-columns: 208px minmax(0, 1fr);
  align-items: center;
  gap: 26px;
  padding: 28px 30px;
}

.team-card-media {
  display: flex;
  justify-content: center;
}

.team-card-copy {
  display: grid;
  align-content: center;
  gap: 10px;
}

.team-card h3 {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}

.team-chip {
  margin: 0;
  width: fit-content;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  border: 1px solid var(--pill-border);
  color: var(--olive);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.team-role {
  margin: 0;
  color: var(--ink);
  font-weight: 700;
  font-size: 1.1rem;
}

.team-school {
  color: var(--muted);
  font-weight: 600;
}

.team-photo-wrap {
  width: 204px;
  height: 204px;
  border-radius: 999px;
  padding: 7px;
  background: linear-gradient(140deg, rgba(124, 167, 159, 0.42), rgba(204, 178, 122, 0.4));
  box-shadow: 0 16px 28px rgba(28, 34, 27, 0.12);
}

.team-photo {
  width: 100%;
  height: 100%;
  border-radius: 999px;
  object-fit: cover;
  object-position: center 24%;
  filter: grayscale(1) contrast(1.08);
}

.team-photo-faizal {
  object-position: center 22%;
}

.section-cta {
  padding-top: 24px;
}

.cta-panel {
  position: relative;
  display: flex;
  justify-content: space-between;
  gap: 26px;
  align-items: center;
  padding: 34px;
  border-radius: calc(var(--radius-xl) + 4px);
  border: 1px solid var(--card-border);
  background:
    radial-gradient(circle at top left, rgba(124, 167, 159, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 250, 242, 0.84), rgba(237, 244, 235, 0.74));
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.cta-emblem {
  position: absolute;
  right: -4%;
  top: 50%;
  width: 230px;
  opacity: 0.08;
  transform: translateY(-50%) rotate(-10deg);
  pointer-events: none;
}

.cta-panel h2 {
  max-width: 16ch;
}

.cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.cta-copy {
  max-width: 48ch;
  margin: 18px 0 0;
  color: var(--muted);
}

.site-footer {
  padding: 44px 0 72px;
}

.footer-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 42px;
  align-items: start;
  border-top: 1px solid var(--detail-divider);
  padding-top: 26px;
}

.footer-brand {
  display: grid;
  gap: 18px;
  align-content: start;
}

.footer-inner p {
  max-width: 32rem;
  margin: 0;
}

.footer-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  align-items: start;
}

.footer-column {
  display: grid;
  align-content: start;
  gap: 12px;
}

.footer-heading {
  margin: 0;
  color: var(--olive);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.76rem;
}

.footer-column a {
  width: fit-content;
  color: var(--muted);
  transition: color 160ms ease, transform 160ms ease;
}

.footer-column a:hover,
.footer-column a:focus-visible,
.footer-column a[aria-current="page"] {
  color: var(--ink);
}

.footer-column a:hover,
.footer-column a:focus-visible {
  transform: translateX(3px);
}

body.inner-page {
  background:
    radial-gradient(circle at top left, rgba(124, 167, 159, 0.22), transparent 24%),
    radial-gradient(circle at 86% 14%, rgba(204, 178, 122, 0.18), transparent 22%),
    linear-gradient(180deg, var(--inner-body-gradient-start) 0%, var(--inner-body-gradient-mid) 42%, var(--inner-body-gradient-end) 100%);
}

.inner-page .site-header.is-scrolled {
  background: var(--header-scrolled-bg);
}

.inner-page-sunbul .page-glow-left {
  background: rgba(124, 167, 159, 0.28);
}

.inner-page-sunbul .page-glow-right {
  background: rgba(167, 191, 138, 0.16);
}

.inner-page-mai .page-glow-left {
  background: rgba(124, 167, 159, 0.18);
}

.inner-page-mai .page-glow-right {
  background: rgba(204, 178, 122, 0.22);
}

.inner-page-pilot .page-glow-left {
  background: rgba(167, 191, 138, 0.2);
}

.inner-page-pilot .page-glow-right {
  background: rgba(124, 167, 159, 0.22);
}

.inner-page-about .page-glow-left {
  background: rgba(124, 167, 159, 0.24);
}

.inner-page-about .page-glow-right {
  background: rgba(204, 178, 122, 0.18);
}

.inner-page-faq .page-glow-left {
  background: rgba(204, 178, 122, 0.2);
}

.inner-page-faq .page-glow-right {
  background: rgba(124, 167, 159, 0.24);
}

.inner-page-join {
  --join-progress: 0;
  background:
    radial-gradient(circle at 14% 10%, rgba(124, 167, 159, 0.16), transparent 22%),
    radial-gradient(circle at 86% 18%, rgba(204, 178, 122, 0.14), transparent 22%),
    linear-gradient(180deg, #141915 0%, #1b211c 18%, #e5ddcf 54%, #ece3d3 100%);
}

.inner-page-join .page-glow-left {
  background: rgba(124, 167, 159, 0.3);
}

.inner-page-join .page-glow-right {
  background: rgba(204, 178, 122, 0.22);
}

.join-breadcrumb {
  color: rgba(71, 89, 63, 0.72);
}

.join-breadcrumb a {
  color: var(--olive);
}

.join-hero {
  position: relative;
  min-height: calc(100vh - 32px);
  padding-top: 0;
  padding-bottom: 40px;
  overflow: hidden;
  isolation: isolate;
  background: #ffffff;
  --join-hero-ink: #18221c;
  --join-hero-muted: #5d675d;
  --join-hero-accent: #47593f;
}

.join-hero::before,
.join-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.join-hero::before {
  inset: -8% -6% 10%;
  background:
    radial-gradient(circle at 24% 20%, rgba(204, 178, 122, 0.1), transparent 22%),
    radial-gradient(circle at 76% 30%, rgba(124, 167, 159, 0.12), transparent 26%),
    radial-gradient(circle at 62% 54%, rgba(167, 191, 138, 0.08), transparent 22%),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.42) 0%,
      rgba(255, 255, 255, 0.14) 36%,
      rgba(255, 255, 255, 0) 72%
    );
  opacity: calc(0.96 - (var(--join-progress) * 0.46));
  transform: translateY(calc(var(--join-progress) * 14px));
}

.join-hero::after {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06) 0%,
      rgba(255, 255, 255, 0.24) 42%,
      rgba(255, 255, 255, 0.92) 100%
    );
  opacity: calc(0.16 + (var(--join-progress) * 0.82));
}

.join-hero-stage {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
  align-items: start;
  gap: 0;
  margin-top: 0;
  min-height: 0;
  overflow: clip;
  z-index: 1;
}

.join-hero-stage::after {
  display: none;
}

.join-hero-media {
  position: relative;
  min-height: clamp(620px, 72vw, 900px);
  margin-right: clamp(-120px, -8vw, -56px);
  z-index: 0;
}

.join-hero-media::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: clamp(120px, 14vw, 220px);
  height: 100%;
  pointer-events: none;
  z-index: 1;
  background:
    linear-gradient(
      to right,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.18) 44%,
      rgba(255, 255, 255, 0.68) 70%,
      rgba(255, 255, 255, 0.98) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.12) 58%,
      rgba(255, 255, 255, 0.54) 80%,
      rgba(255, 255, 255, 0.98) 100%
    );
}

.join-hero-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left center;
  filter: contrast(1.02) brightness(0.98) saturate(0.9);
}

.join-hero-copy-shell {
  position: relative;
  z-index: 3;
  width: 100%;
  padding:
    clamp(28px, 5vw, 64px)
    clamp(18px, 3.6vw, 64px)
    0
    clamp(72px, 7vw, 126px);
}

.join-hero-copy {
  min-width: 0;
  width: min(100%, 35rem);
  max-width: 100%;
}

.join-hero .eyebrow {
  color: var(--join-hero-accent);
}

.join-hero-copy h1 {
  max-width: 8ch;
  font-size: clamp(3.2rem, 5.9vw, 5.8rem);
  color: var(--join-hero-ink);
  text-wrap: balance;
}

.join-page-intro {
  max-width: 58ch;
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  color: var(--join-hero-muted);
}

.join-hero-note {
  max-width: 46ch;
  margin: 18px 0 0;
  color: var(--join-hero-muted);
}

.join-stat-grid .page-stat {
  border-color: rgba(255, 250, 242, 0.26);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.82), rgba(246, 239, 229, 0.74)),
    rgba(255, 250, 242, 0.74);
  box-shadow: 0 20px 50px rgba(28, 34, 27, 0.12);
  backdrop-filter: blur(14px);
}

.join-stat-grid .page-stat strong {
  color: var(--join-hero-ink);
}

.join-stat-grid .page-stat span {
  color: var(--join-hero-muted);
}

.join-stat-grid .page-stat small {
  color: var(--join-hero-accent);
}

.join-stat-grid .page-stat:hover,
.join-stat-grid .page-stat:focus-within {
  border-color: rgba(255, 250, 242, 0.4);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.92), rgba(248, 241, 232, 0.82)),
    rgba(255, 250, 242, 0.82);
  box-shadow: 0 28px 56px rgba(28, 34, 27, 0.14);
}

.join-hero-visual {
  position: relative;
  min-height: 700px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.join-hero-visual::before {
  content: "";
  position: absolute;
  inset: 10% 8%;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 250, 242, 0.18), rgba(255, 250, 242, 0) 58%);
  filter: blur(26px);
  opacity: calc(0.72 - (var(--join-progress) * 0.24));
}

.join-orb-stage {
  position: relative;
  width: min(100%, 600px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
}

.join-orb-halo {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.join-orb-halo-outer {
  inset: 4%;
  border: 1px solid rgba(255, 250, 242, 0.12);
  opacity: calc(0.78 - (var(--join-progress) * 0.32));
}

.join-orb-halo-inner {
  inset: 15%;
  border: 1px solid rgba(124, 167, 159, 0.14);
  opacity: calc(0.64 - (var(--join-progress) * 0.22));
}

.join-orb-surface {
  position: absolute;
  inset: 16%;
  overflow: hidden;
  border-radius: 50%;
  background:
    linear-gradient(180deg, rgba(232, 224, 211, 0.98), rgba(213, 204, 189, 0.98));
  box-shadow:
    0 42px 120px rgba(8, 10, 9, 0.24),
    inset 0 1px 0 rgba(255, 250, 242, 0.72),
    inset 0 -36px 52px rgba(24, 34, 28, 0.14);
  transform: translateY(calc(var(--join-progress) * 20px))
    scale(calc(1 - (var(--join-progress) * 0.05)));
  filter: saturate(calc(1.06 - (var(--join-progress) * 0.18)));
}

.join-orb-surface::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background:
    radial-gradient(circle at 32% 28%, rgba(255, 250, 242, 0.84), rgba(255, 250, 242, 0) 18%),
    linear-gradient(145deg, rgba(255, 250, 242, 0.12), rgba(255, 250, 242, 0) 34%);
  pointer-events: none;
}

.join-orb-blob,
.join-orb-shine,
.join-orb-vignette {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  pointer-events: none;
}

.join-orb-blob {
  filter: blur(42px);
  opacity: calc(0.88 - (var(--join-progress) * 0.18));
}

.join-orb-blob-sand {
  inset: auto auto -10% -6%;
  width: 72%;
  height: 72%;
  background:
    radial-gradient(circle, rgba(204, 178, 122, 0.92) 0%, rgba(204, 178, 122, 0.22) 56%, rgba(204, 178, 122, 0) 74%);
  animation: joinOrbDriftSand 18s ease-in-out infinite alternate;
}

.join-orb-blob-teal {
  inset: 10% -8% auto auto;
  width: 68%;
  height: 68%;
  background:
    radial-gradient(circle, rgba(124, 167, 159, 0.96) 0%, rgba(124, 167, 159, 0.22) 58%, rgba(124, 167, 159, 0) 76%);
  animation: joinOrbDriftTeal 22s ease-in-out infinite alternate;
}

.join-orb-blob-sage {
  inset: auto 14% 8% auto;
  width: 44%;
  height: 44%;
  background:
    radial-gradient(circle, rgba(167, 191, 138, 0.56) 0%, rgba(167, 191, 138, 0) 72%);
  animation: joinOrbDriftSage 16s ease-in-out infinite alternate;
}

.join-orb-blob-mist {
  inset: -8% auto auto 18%;
  width: 60%;
  height: 60%;
  background:
    radial-gradient(circle, rgba(255, 250, 242, 0.84) 0%, rgba(220, 230, 220, 0.24) 46%, rgba(220, 230, 220, 0) 72%);
  mix-blend-mode: screen;
  animation: joinOrbDriftMist 20s ease-in-out infinite alternate;
}

.join-orb-shine {
  background:
    radial-gradient(circle at 34% 26%, rgba(255, 250, 242, 0.88), rgba(255, 250, 242, 0.12) 16%, rgba(255, 250, 242, 0) 30%),
    linear-gradient(150deg, rgba(255, 250, 242, 0.16), rgba(255, 250, 242, 0) 42%, rgba(24, 34, 28, 0.08) 100%);
  opacity: calc(0.9 - (var(--join-progress) * 0.2));
}

.join-orb-vignette {
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 250, 242, 0) 38%, rgba(93, 103, 93, 0.18) 78%, rgba(24, 34, 28, 0.26) 100%);
}

.career-label {
  margin: 0;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(204, 178, 122, 0.9);
  font-weight: 800;
}

.join-settle-section {
  background:
    linear-gradient(180deg, rgba(229, 221, 207, 0.42), rgba(229, 221, 207, 0));
}

.join-focus-band::before {
  background:
    radial-gradient(circle at 18% 24%, rgba(124, 167, 159, 0.28), transparent 30%),
    radial-gradient(circle at 82% 66%, rgba(204, 178, 122, 0.22), transparent 28%),
    radial-gradient(circle at 62% 18%, rgba(167, 191, 138, 0.18), transparent 24%);
}

.join-focus-band {
  margin-top: -36px;
  padding-top: 132px;
}

.page-breadcrumb {
  margin: 0 0 24px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 0.96rem;
}

.page-breadcrumb a {
  color: var(--olive);
  font-weight: 700;
}

.page-hero {
  padding-top: 42px;
  padding-bottom: 56px;
}

.page-hero.join-hero {
  padding-top: 0;
  padding-bottom: 40px;
}

.inner-page-contact main {
  position: relative;
  overflow: hidden;
  --ink: #18221c;
  --muted: #5d675d;
  --olive: #47593f;
  --line: rgba(24, 34, 28, 0.1);
  --card-border: rgba(24, 34, 28, 0.08);
  --input-border: rgba(24, 34, 28, 0.12);
  --input-bg: rgba(255, 250, 242, 0.82);
  --input-bg-focus: rgba(255, 252, 247, 0.96);
  --contact-grid-line: rgba(24, 34, 28, 0.032);
  --contact-panel-border: rgba(24, 34, 28, 0.08);
  --contact-panel-surface:
    linear-gradient(180deg, rgba(255, 252, 247, 0.9), rgba(239, 234, 223, 0.8)),
    rgba(255, 250, 242, 0.8);
  --contact-panel-shadow: 0 28px 70px rgba(28, 34, 27, 0.12);
  --contact-field-label: rgba(24, 34, 28, 0.86);
  --contact-placeholder: rgba(24, 34, 28, 0.46);
  --contact-planet-opacity: 0.96;
  --contact-planet-filter: saturate(1.04) contrast(1.2) brightness(0.9);
  color: var(--ink);
  background:
    radial-gradient(circle at 76% 34%, rgba(204, 178, 122, 0.24), transparent 31%),
    radial-gradient(circle at 38% 72%, rgba(124, 167, 159, 0.22), transparent 34%),
    linear-gradient(180deg, rgba(248, 243, 232, 0.98), rgba(237, 228, 213, 0.98));
}

.inner-page-contact main::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(var(--contact-grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--contact-grid-line) 1px, transparent 1px);
  background-size: 110px 110px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.84), rgba(0, 0, 0, 0.28));
}

.inner-page-contact .page-hero,
.inner-page-contact .page-focus-band {
  position: relative;
  z-index: 1;
  background: transparent;
}

.inner-page-contact [data-reveal] {
  opacity: 1;
  transform: none;
}

.inner-page-contact .page-hero {
  padding-bottom: 22px;
}

.inner-page-contact .page-hero-grid {
  grid-template-columns: minmax(0, 0.94fr) minmax(340px, 0.78fr);
  align-items: start;
  min-height: 0;
}

.inner-page-contact .page-focus-band {
  margin-top: clamp(-210px, -14vw, -150px);
  padding-top: 0;
}

.inner-page-contact .page-focus-band::before,
.inner-page-contact .page-focus-band::after,
.inner-page-contact .section-gradient-orb {
  display: none;
}

.inner-page-contact .section-heading {
  padding-top: 28px;
}

.inner-page-contact .section-heading .eyebrow {
  margin-bottom: 18px;
}

.inner-page-contact .page-breadcrumb,
.inner-page-contact .page-intro,
.inner-page-contact .section-heading p {
  color: var(--muted);
}

.inner-page-contact .page-hero-copy h1,
.inner-page-contact .section-heading h2 {
  color: var(--ink);
}

.inner-page-contact .eyebrow,
.inner-page-contact .page-breadcrumb a {
  color: var(--olive);
}

.inner-page-contact .pilot-form-shell {
  border-color: var(--contact-panel-border);
  background: var(--contact-panel-surface);
  box-shadow: var(--contact-panel-shadow);
}

.inner-page-contact .field label {
  color: var(--contact-field-label);
}

.inner-page-contact .field input,
.inner-page-contact .field select,
.inner-page-contact .field textarea {
  color: var(--ink);
}

.inner-page-contact .field textarea::placeholder {
  color: var(--contact-placeholder);
}

.contact-planet-visual {
  position: relative;
  min-width: 0;
  width: min(100%, 500px);
  justify-self: center;
  display: grid;
  place-items: center;
  margin-top: -26px;
  pointer-events: none;
  isolation: isolate;
}

.contact-planet-visual::before,
.contact-planet-visual::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.contact-planet-visual::before {
  inset: 12%;
  background:
    radial-gradient(circle, rgba(124, 167, 159, 0.2), rgba(96, 104, 96, 0.08) 42%, transparent 68%);
  filter: blur(22px);
}

.contact-planet-visual::after {
  inset: 20% 10% auto auto;
  width: 42%;
  aspect-ratio: 1;
  background:
    radial-gradient(circle, rgba(204, 178, 122, 0.24), rgba(204, 178, 122, 0) 68%);
  filter: blur(18px);
}

.contact-planet-shell {
  position: relative;
  z-index: 1;
  width: min(100%, clamp(320px, 31vw, 500px));
  aspect-ratio: 1;
  opacity: var(--contact-planet-opacity);
  filter: var(--contact-planet-filter);
  transform: translate3d(0, -2%, 0);
}

.contact-planet-shell canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

html[data-theme="dark"] .inner-page-contact main {
  --ink: #fff8ef;
  --muted: rgba(255, 248, 239, 0.72);
  --olive: #b4c39c;
  --line: rgba(255, 248, 239, 0.12);
  --card-border: rgba(255, 248, 239, 0.1);
  --input-border: rgba(255, 248, 239, 0.14);
  --input-bg: rgba(7, 13, 10, 0.72);
  --input-bg-focus: rgba(12, 20, 16, 0.9);
  --contact-grid-line: rgba(255, 248, 239, 0.035);
  --contact-panel-border: rgba(255, 248, 239, 0.1);
  --contact-panel-surface:
    linear-gradient(180deg, rgba(13, 22, 18, 0.88), rgba(9, 16, 13, 0.76)),
    rgba(13, 22, 18, 0.82);
  --contact-panel-shadow: 0 28px 70px rgba(0, 0, 0, 0.22);
  --contact-field-label: rgba(255, 248, 239, 0.9);
  --contact-placeholder: rgba(255, 248, 239, 0.42);
  --contact-planet-opacity: 0.9;
  --contact-planet-filter: saturate(0.9) brightness(1.06);
  background:
    radial-gradient(circle at 76% 34%, rgba(204, 178, 122, 0.18), transparent 30%),
    radial-gradient(circle at 38% 72%, rgba(124, 167, 159, 0.2), transparent 34%),
    linear-gradient(180deg, rgba(14, 22, 18, 0.98), rgba(13, 23, 19, 0.98));
}

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

  .contact-planet-visual {
    justify-self: start;
    margin-top: -18px;
  }

  .contact-planet-shell {
    width: min(100%, 420px);
  }

  .inner-page-contact .page-focus-band {
    margin-top: -90px;
  }
}

@media (max-width: 760px) {
  .contact-planet-visual {
    display: none;
  }

  .inner-page-contact .page-focus-band {
    margin-top: 0;
    padding-top: 22px;
  }

  .inner-page-contact .section-heading {
    padding-top: 0;
  }
}

.page-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(500px, 0.98fr);
  gap: clamp(40px, 4vw, 56px);
  align-items: start;
}

.page-hero-copy h1 {
  max-width: 15.75ch;
  font-size: clamp(3rem, 5vw, 5rem);
  line-height: 0.91;
  word-break: keep-all;
}

.page-intro {
  max-width: 60ch;
  margin: 22px 0 0;
  color: var(--muted);
  font-size: 1.08rem;
}

body.not-found-page {
  --not-found-bg: #fbfaf6;
  --not-found-ink: #111713;
  --not-found-muted: #5e665f;
  --not-found-soft: rgba(24, 34, 28, 0.08);
  --ink: var(--not-found-ink);
  --muted: var(--not-found-muted);
  --grid-line: rgba(24, 34, 28, 0.032);
  background: #ffffff;
  color: var(--not-found-ink);
}

body.not-found-page::before,
.not-found-page .page-glow {
  display: none;
}

.not-found-page .site-header {
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(24, 34, 28, 0.08);
}

.not-found-page .header-inner {
  flex-direction: row;
  align-items: center;
}

.not-found-page .site-nav {
  display: none;
}

.not-found-page .header-actions {
  width: auto;
  margin-left: 0;
  justify-content: flex-end;
}

.not-found-main {
  display: grid;
  align-items: start;
  overflow: hidden;
  min-height: calc(100svh - 84px);
  padding: 0;
}

.container.not-found-shell {
  width: 100%;
  min-height: calc(100svh - 84px);
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: minmax(0, 65vw) minmax(420px, 1fr);
  gap: clamp(12px, 1.8vw, 34px);
  align-items: center;
}

.not-found-media {
  position: relative;
  display: grid;
  place-items: center start;
  min-width: 0;
  height: calc(100svh - 84px);
  min-height: 560px;
  margin-left: 0;
  overflow: hidden;
  isolation: isolate;
}

.not-found-media::after {
  content: "";
  position: absolute;
  inset: 0 -1px 0 auto;
  width: clamp(120px, 14vw, 260px);
  background: linear-gradient(to right, rgba(255, 255, 255, 0), #ffffff 92%);
  pointer-events: none;
  z-index: 2;
}

.not-found-loop {
  display: block;
  position: relative;
  z-index: 1;
  width: auto;
  max-width: none;
  height: min(100%, calc(100svh - 84px));
  aspect-ratio: 16 / 9;
  max-height: none;
  min-height: 0;
  background: url("Photo/404 Page/Frame 1.png") center / contain no-repeat;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 28px 44px rgba(24, 34, 28, 0.1));
}

.not-found-code {
  position: absolute;
  top: clamp(-18px, 2vw, 22px);
  right: clamp(10px, 7vw, 98px);
  z-index: 0;
  margin: 0;
  color: rgba(24, 34, 28, 0.055);
  font-family: "Sora", "Manrope", sans-serif;
  font-size: clamp(5rem, 12vw, 11.5rem);
  font-weight: 700;
  line-height: 0.82;
  pointer-events: none;
}

.not-found-copy {
  position: relative;
  z-index: 3;
  width: min(100%, 29rem);
  justify-self: start;
}

.not-found-logo {
  display: block;
  width: clamp(240px, 22vw, 370px);
  margin: 0 0 clamp(34px, 5vh, 54px);
}

.not-found-copy h1 {
  max-width: 9.5ch;
  margin: 0;
  color: var(--not-found-ink);
  font-size: clamp(3rem, 5.4vw, 5.7rem);
  line-height: 1.02;
}

.not-found-copy h1 span {
  display: block;
}

.not-found-copy p:not(.eyebrow) {
  max-width: 34ch;
  margin: 20px 0 0;
  color: var(--not-found-muted);
  font-size: clamp(1rem, 1.08vw, 1.12rem);
  line-height: 1.58;
}

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

.not-found-page .button-ghost,
.not-found-actions .button-secondary {
  color: var(--not-found-ink);
  border-color: rgba(24, 34, 28, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.66), rgba(232, 237, 229, 0.76)),
    rgba(24, 34, 28, 0.06);
  box-shadow: none;
}

html[data-theme="dark"] body.not-found-page {
  color-scheme: light;
  --not-found-bg: #fbfaf6;
  --not-found-ink: #111713;
  --not-found-muted: #5e665f;
  --ink: var(--not-found-ink);
  --muted: var(--not-found-muted);
  --grid-line: rgba(24, 34, 28, 0.032);
  background: #ffffff;
}

html[data-theme="dark"] .not-found-page .site-header {
  background: rgba(255, 255, 255, 0.96);
  border-bottom-color: rgba(24, 34, 28, 0.08);
}

@media (max-width: 1120px) {
  .not-found-main {
    align-items: start;
    overflow: visible;
    padding-top: clamp(18px, 4vw, 34px);
  }

  .container.not-found-shell {
    width: var(--container);
    min-height: auto;
    padding: 0 0 clamp(38px, 8vw, 76px);
    grid-template-columns: 1fr;
    gap: clamp(18px, 4vw, 36px);
  }

  .not-found-media {
    height: auto;
    min-height: 0;
    margin-left: 0;
  }

  .not-found-loop {
    height: min(44svh, 520px);
    min-height: 280px;
  }

  .not-found-media::after {
    display: none;
  }

  .not-found-copy {
    width: min(100%, 42rem);
    padding: 0 24px;
    justify-self: start;
  }

  .not-found-copy h1 {
    max-width: 13ch;
  }
}

@media (max-width: 640px) {
  .not-found-page .header-actions {
    display: none;
  }

  .not-found-main {
    min-height: auto;
    padding-top: 22px;
  }

  .not-found-media {
    min-height: 0;
  }

  .not-found-loop {
    width: 100%;
    height: auto;
    min-height: 0;
  }

  .not-found-code {
    display: none;
  }

  .not-found-logo {
    width: min(210px, 68vw);
    margin-bottom: 24px;
  }

  .not-found-copy h1 {
    max-width: 100%;
    font-size: clamp(2.55rem, 12vw, 3.45rem);
  }

  .not-found-actions .button {
    width: 100%;
  }
}

.about-cinema {
  position: relative;
  width: 100%;
  margin-inline: 0;
  overflow: clip;
  z-index: 2;
  isolation: isolate;
  --about-cinema-progress: 0;
  --about-cinema-header-offset: 96px;
  --about-cinema-copy-reserve: clamp(360px, 31vw, 500px);
}

.about-cinema::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #ffffff;
  z-index: 0;
}

.about-cinema-track {
  position: relative;
  width: 100%;
  height: 170svh;
  z-index: 1;
}

.about-cinema-stage {
  position: sticky;
  top: var(--about-cinema-header-offset);
  width: 100%;
  height: calc(100svh - var(--about-cinema-header-offset));
  min-height: 600px;
  overflow: hidden;
  background: #ffffff;
}

.about-cinema-stage::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: clamp(90px, 16vh, 220px);
  pointer-events: none;
  z-index: 2;
  background:
    linear-gradient(
      to bottom,
      rgba(237, 228, 213, 0) 0%,
      rgba(237, 228, 213, 0.2) 35%,
      rgba(237, 228, 213, 0.55) 70%,
      #ede4d5 100%
    );
}

.about-cinema-media {
  position: absolute;
  inset: 0 calc(var(--about-cinema-copy-reserve) - clamp(28px, 3vw, 56px)) 0 0;
  background: #ffffff;
  z-index: 0;
}

.about-cinema-media::after {
  content: "";
  position: absolute;
  top: 0;
  right: -1px;
  width: clamp(92px, 13vw, 180px);
  height: 100%;
  pointer-events: none;
  z-index: 1;
  background:
    linear-gradient(
      to right,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.18) 56%,
      rgba(255, 255, 255, 0.46) 82%,
      #ffffff 100%
    );
}

.about-cinema-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
  background: #ffffff;
  display: block;
  opacity: 0;
  transition: none;
  will-change: opacity;
  backface-visibility: hidden;
  transform: translateZ(0);
}

.about-cinema-frame.is-active {
  opacity: 1;
}

.about-cinema-copy-shell {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, var(--about-cinema-copy-reserve));
  align-items: start;
  pointer-events: none;
  width: 100%;
  max-width: none;
  margin: 0;
  padding:
    clamp(36px, 8svh, 92px)
    clamp(18px, 3.6vw, 64px)
    0
    clamp(20px, 2.4vw, 40px);
}

.about-cinema-copy {
  grid-column: 2;
  width: min(100%, 19.5rem);
  justify-self: start;
  margin: 0 0 0 clamp(84px, 8vw, 136px);
  color: #0b120e;
  pointer-events: auto;
  transform: translate3d(0, calc((0.5 - var(--about-cinema-progress)) * 18px), 0);
  opacity: calc(1 - (var(--about-cinema-progress) * 0.16));
  transition: transform 180ms ease, opacity 180ms ease;
}

.about-cinema-copy h1 {
  max-width: 8.4ch;
  color: #060a08;
  font-size: clamp(1.9rem, 3vw, 3.1rem);
  line-height: 0.94;
}

.about-cinema-subcopy {
  max-width: 18.5ch;
  margin: 18px 0 0;
  color: rgba(11, 18, 14, 0.72);
  font-size: clamp(0.92rem, 1vw, 1.04rem);
  line-height: 1.48;
}

.about-cinema-divider {
  display: none;
}

.about-manifesto-strip {
  position: relative;
  z-index: 1;
  padding: clamp(28px, 4svh, 42px) 0 clamp(28px, 4.6svh, 44px);
  background:
    linear-gradient(
      90deg,
      #ede4d5 0%,
      color-mix(in srgb, #ede4d5 92%, #f5efe4 8%) 48%,
      color-mix(in srgb, #ede4d5 82%, #ccb27a 18%) 100%
    );
}

.about-manifesto-strip-copy {
  margin: 0;
  max-width: 44ch;
  color: var(--ink);
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: clamp(1.08rem, 1.4vw, 1.44rem);
  letter-spacing: -0.03em;
  line-height: 1.24;
}

.about-detail-grid {
  grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
}

.detail-panel-split {
  display: grid;
  gap: 16px;
}

.about-build-card {
  padding: 22px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.about-build-card + .about-build-card {
  margin-top: 0;
}

.about-build-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  color: var(--olive);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.about-build-card h3 {
  margin-top: 18px;
  max-width: 18ch;
}

.about-build-card p {
  margin-top: 12px;
}

.page-stat-grid {
  margin-top: 30px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.page-stat-grid > :last-child {
  grid-column: 1 / -1;
}

.page-stat {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 152px;
  padding: 20px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface) 96%, transparent);
  box-shadow: var(--shadow-md);
}

.page-stat strong {
  display: block;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: clamp(0.98rem, 1.02vw, 1.08rem);
  line-height: 1.1;
  text-wrap: pretty;
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}

.page-stat span {
  display: block;
  margin-top: 0;
  color: var(--muted);
}

.page-stat small {
  display: block;
  margin-top: 0;
  color: var(--olive);
  font-weight: 700;
}

.sensor-stage {
  position: relative;
  padding: 28px;
  border-radius: calc(var(--radius-xl) + 4px);
  border: 1px solid var(--card-border);
  background: var(--sensor-stage-surface);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}

.sensor-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.sensor-stage > * {
  position: relative;
  z-index: 1;
}

.sensor-stage-sunbul::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.26), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(167, 191, 138, 0.2), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(204, 178, 122, 0.18), transparent 24%);
}

.sensor-stage-mai::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.18), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.24), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(124, 167, 159, 0.18), transparent 24%);
}

.pilot-stage::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(167, 191, 138, 0.2), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.22), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(124, 167, 159, 0.16), transparent 24%);
}

.sensor-stage-about::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.24), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.18), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(167, 191, 138, 0.18), transparent 24%);
}

.sensor-stage-faq::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(204, 178, 122, 0.22), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(124, 167, 159, 0.22), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(167, 191, 138, 0.16), transparent 24%);
}

.sensor-stage-topline {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 26px;
  color: var(--olive);
  font-weight: 800;
  line-height: 1.15;
}

.sensor-stage-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.sensor-stage-card {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 186px;
  padding: 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 88%, transparent);
  backdrop-filter: blur(14px);
}

.sensor-stage-card strong {
  display: block;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: clamp(0.96rem, 1vw, 1.08rem);
  line-height: 1.1;
  text-wrap: pretty;
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}

.sensor-stage-card span {
  display: block;
  margin-top: 0;
  color: var(--muted);
  line-height: 1.5;
}

.sensor-stage-card small {
  display: block;
  margin-top: 0;
  color: var(--olive);
  font-weight: 700;
  line-height: 1.45;
}

.sensor-stage-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.sensor-stage-flow span {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--pill-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
  color: var(--olive);
  font-weight: 700;
}

.sensor-stage-note {
  margin: 20px 0 0;
  max-width: 52ch;
  color: var(--muted);
}

.story-grid,
.deployment-grid,
.fit-grid {
  display: grid;
  gap: 18px;
}

.story-grid {
  margin-top: 38px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.story-card,
.deployment-step,
.fit-card,
.pilot-form-shell,
.pilot-sidebar,
.detail-panel {
  position: relative;
  min-width: 0;
  padding: 28px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: var(--card-surface);
  box-shadow: var(--shadow-md);
}

.story-card {
  display: grid;
  align-content: start;
  gap: 20px;
  min-height: 272px;
}

.story-card span,
.fit-card span,
.deployment-step strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  color: var(--olive);
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 0.76rem;
  justify-self: start;
  width: fit-content;
  max-width: 100%;
}

.story-card h3,
.deployment-step h3 {
  margin: 0;
  text-wrap: pretty;
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
  line-height: 1.02;
}

.story-card h3 {
  margin-top: 2px;
}

.story-card p,
.fit-card p,
.deployment-step p,
.pilot-form-shell p,
.pilot-sidebar p,
.detail-panel p {
  margin: 14px 0 0;
  color: var(--muted);
}

.story-card p {
  margin: 0;
}

.page-focus-band {
  position: relative;
  overflow: hidden;
  padding: 92px 0 96px;
  background: var(--focus-band-surface);
}

.page-focus-band::before {
  content: "";
  position: absolute;
  inset: 4% 2%;
  border-radius: 40px;
  background:
    radial-gradient(circle at 18% 24%, rgba(124, 167, 159, 0.34), transparent 30%),
    radial-gradient(circle at 82% 66%, rgba(204, 178, 122, 0.28), transparent 28%),
    radial-gradient(circle at 62% 18%, rgba(167, 191, 138, 0.22), transparent 24%);
  filter: blur(12px);
  animation: sectionGradientMorph 18s ease-in-out infinite alternate;
  pointer-events: none;
}

.page-focus-band::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      circle at var(--pointer-x) var(--pointer-y),
      rgba(255, 255, 255, 0.4),
      rgba(204, 178, 122, 0.16) 14%,
      rgba(124, 167, 159, 0.08) 28%,
      rgba(124, 167, 159, 0) 42%
    ),
    linear-gradient(180deg, rgba(255, 250, 242, 0.12), rgba(255, 250, 242, 0.03));
  pointer-events: none;
  -webkit-mask-image: radial-gradient(circle at center, #000 54%, rgba(0, 0, 0, 0.82) 74%, transparent 100%);
  mask-image: radial-gradient(circle at center, #000 54%, rgba(0, 0, 0, 0.82) 74%, transparent 100%);
}

.page-focus-band .container {
  position: relative;
  z-index: 1;
}

.page-focus-band .section-gradient-orb {
  width: min(40vw, 520px);
  opacity: 0.94;
}

.detail-grid,
.pilot-layout {
  display: grid;
  gap: 22px;
  align-items: start;
}

.detail-grid {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
}

.detail-panel h3,
.pilot-form-shell h3,
.pilot-sidebar h3 {
  max-width: 18ch;
}

.detail-list,
.pilot-sidebar ul {
  list-style: none;
  padding: 0;
  margin: 20px 0 0;
  display: grid;
  gap: 14px;
}

.detail-list li,
.pilot-sidebar li {
  position: relative;
  padding-left: 20px;
  color: var(--muted);
}

.detail-list li::before,
.pilot-sidebar li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.68em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--teal), var(--sand));
}

.signal-board {
  margin-top: 22px;
  display: grid;
  gap: 16px;
}

.signal-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 92%, transparent);
}

.signal-copy strong {
  display: block;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: 1rem;
}

.signal-copy span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
}

.signal-meter {
  position: relative;
  height: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--pill-surface) 92%, transparent);
  overflow: hidden;
}

.signal-meter-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--fill, 50%);
  border-radius: inherit;
  background: linear-gradient(90deg, var(--teal), var(--sand));
}

.detail-panel-note {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--detail-divider);
  color: var(--olive);
  font-weight: 700;
}

.page-hero-grid > *,
.story-grid > *,
.detail-grid > *,
.page-stat,
.sensor-stage-card,
.story-card,
.detail-panel,
.deployment-step {
  min-width: 0;
}

.page-stat strong,
.sensor-stage-card strong,
.story-card h3,
.deployment-step h3 {
  text-wrap: balance;
}

.keyword-panel {
  display: grid;
  align-content: start;
}

.keyword-panel.is-active > h3 {
  display: none;
}

.keyword-panel [data-keyword-list] {
  display: grid;
  gap: 18px;
  align-content: start;
}

.keyword-panel [data-keyword-list][hidden] {
  display: none;
}

.keyword-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}

.keyword-trigger {
  padding: 0;
  border: 0;
  background: none;
  color: color-mix(in srgb, var(--ink) 30%, transparent);
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: clamp(1.7rem, 3.2vw, 3.1rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
  text-align: left;
  cursor: pointer;
  transition: color 180ms ease, transform 180ms ease;
}

.keyword-trigger:hover,
.keyword-trigger:focus-visible {
  color: var(--ink);
  transform: translateX(8px) scale(1.03);
}

.keyword-stage {
  display: grid;
  gap: 16px;
  align-content: start;
}

.keyword-stage[hidden] {
  display: none;
}

.keyword-stage-top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.keyword-stage-top .keyword-active-title {
  flex: 0 1 auto;
  min-width: 0;
}

.keyword-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  padding: 0;
  border: 1px solid var(--card-border-strong);
  border-radius: 999px;
  background: color-mix(in srgb, var(--card-surface-strong) 94%, transparent);
  color: var(--olive);
  cursor: pointer;
  transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease,
    box-shadow 180ms ease;
}

.keyword-back::before {
  content: "";
  width: 10px;
  height: 10px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateX(1px);
}

.keyword-back:hover,
.keyword-back:focus-visible {
  color: var(--ink);
  transform: translateX(-2px);
  border-color: var(--line-strong);
  background: color-mix(in srgb, var(--card-surface-strong) 98%, transparent);
  box-shadow: 0 10px 22px rgba(28, 34, 27, 0.08);
}

.keyword-active-title {
  display: inline-block;
  margin: 0;
  width: fit-content;
  max-width: 100%;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 0.96;
  background: linear-gradient(125deg, #344238, #55684a, #7ca79f, #ccb27a, #344238);
  background-size: 240% 240%;
  background-repeat: no-repeat;
  color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: buttonFlow 4.5s linear infinite;
  text-wrap: balance;
}

.keyword-active-copy {
  margin: 0;
  max-width: 30ch;
  color: var(--muted);
  font-size: 1.08rem;
}

.keyword-panel.is-active .keyword-stage {
  animation: keywordStageReveal 220ms ease both;
}

.deployment-grid {
  margin-top: 36px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.deployment-step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  grid-template-areas:
    "step spacer icon"
    "title title title"
    "copy copy copy";
  align-content: start;
  gap: 14px 16px;
  min-height: 248px;
  overflow: hidden;
}

.deployment-step strong {
  grid-area: step;
  align-self: start;
  width: fit-content;
}

.deployment-step h3 {
  grid-area: title;
  margin-top: 0;
}

.deployment-step p {
  grid-area: copy;
  margin: 0;
  max-width: 26ch;
}

.deployment-icon-shell {
  grid-area: icon;
  position: relative;
  width: 56px;
  height: 56px;
  display: inline-grid;
  place-items: center;
  justify-self: end;
  align-self: start;
  isolation: isolate;
  pointer-events: none;
}

.deployment-icon-shell::before {
  content: "";
  position: absolute;
  inset: -14px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.96), rgba(231, 239, 230, 0.54) 48%, rgba(231, 239, 230, 0) 74%);
  opacity: 0.62;
  transform: scale(0.92);
  filter: blur(2px);
  transition: opacity 220ms ease, transform 220ms ease, filter 220ms ease;
  z-index: -1;
}

.deployment-icon-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0.94;
  filter: brightness(0.96) saturate(0.96) drop-shadow(0 6px 12px rgba(28, 34, 27, 0.08));
  transition: transform 240ms ease, filter 220ms ease, opacity 220ms ease;
}

.deployment-step:hover .deployment-icon-shell::before,
.deployment-step:focus-within .deployment-icon-shell::before {
  opacity: 1;
  transform: scale(1.12);
  filter: blur(1px);
}

.deployment-step:hover .deployment-icon-image,
.deployment-step:focus-within .deployment-icon-image {
  opacity: 1;
  transform: translateY(-2px) scale(1.05);
  filter: brightness(1.03) saturate(1.04) drop-shadow(0 12px 18px rgba(124, 167, 159, 0.18));
}

.fit-grid {
  margin-top: 38px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.pilot-layout {
  margin-top: 40px;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
}

.contact-form-layout {
  max-width: 780px;
}

.career-grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.career-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 28px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: var(--card-surface);
  box-shadow: var(--shadow-md);
}

.career-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.career-status {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  color: var(--olive);
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.career-card h3 {
  margin-top: 18px;
}

.career-card > p {
  margin: 14px 0 0;
  color: var(--muted);
}

.career-points {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
  display: grid;
  gap: 12px;
}

.career-points li {
  position: relative;
  padding-left: 18px;
  color: var(--muted);
}

.career-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.68em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--teal), var(--sand));
}

.career-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}

.career-meta span {
  display: inline-flex;
  align-items: center;
  padding: 9px 12px;
  border-radius: 999px;
  background: var(--pill-surface);
  border: 1px solid var(--pill-border);
  color: var(--olive);
  font-weight: 700;
  font-size: 0.92rem;
}

.career-card .product-card-footer {
  margin-top: auto;
}

.join-form-helper {
  margin: 16px 0 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--card-border);
  background: rgba(124, 167, 159, 0.08);
  color: var(--olive);
  font-size: 0.95rem;
  font-weight: 600;
}

.join-form-helper[hidden] {
  display: none;
}

.faq-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.38fr) minmax(0, 0.62fr);
  gap: 22px;
  align-items: start;
}

.faq-sidebar h2,
.faq-group h3 {
  max-width: none;
}

.faq-nav {
  margin-top: 22px;
  display: grid;
  gap: 12px;
}

.faq-nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 92%, transparent);
  color: var(--ink);
  font-weight: 700;
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    background-color 180ms ease,
    box-shadow 180ms ease;
}

.faq-nav a::after {
  content: "->";
  color: var(--olive);
}

.faq-nav a:hover,
.faq-nav a:focus-visible {
  transform: translateY(-2px);
  border-color: var(--line-strong);
  background: color-mix(in srgb, var(--card-surface-strong) 98%, transparent);
  box-shadow: 0 12px 24px rgba(28, 34, 27, 0.08);
}

.faq-stack {
  display: grid;
  gap: 18px;
}

.faq-group {
  display: grid;
  gap: 18px;
}

.faq-group > p {
  margin: 0;
}

.faq-item {
  padding: 0;
  overflow: hidden;
  background: var(--faq-item-surface);
}

.faq-item summary {
  list-style: none;
  position: relative;
  cursor: pointer;
  padding: 24px 72px 24px 24px;
  font-family: "Sora", "Aptos Display", sans-serif;
  font-size: 1.12rem;
  letter-spacing: -0.03em;
  line-height: 1.12;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+";
  position: absolute;
  top: 50%;
  right: 24px;
  width: 32px;
  height: 32px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  background: var(--pill-surface);
  color: var(--olive);
  font-family: "Manrope", "Segoe UI Variable Text", "Segoe UI", sans-serif;
  font-size: 1.4rem;
  font-weight: 700;
  transform: translateY(-50%);
}

.faq-item[open] summary::after {
  content: "-";
}

.faq-answer {
  padding: 0 24px 24px;
  border-top: 1px solid var(--detail-divider);
}

.faq-answer p {
  margin: 0;
  color: var(--muted);
}

.faq-answer p + p {
  margin-top: 14px;
}

.pilot-form {
  margin-top: 22px;
  display: grid;
  gap: 16px;
}

.form-honeypot {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.field {
  display: grid;
  gap: 8px;
}

.field-full {
  grid-column: 1 / -1;
}

.field label {
  font-weight: 700;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--ink);
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, background-color 160ms ease;
}

.field textarea {
  min-height: 132px;
  resize: vertical;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: rgba(71, 89, 63, 0.34);
  box-shadow: 0 0 0 4px rgba(124, 167, 159, 0.12);
  background: var(--input-bg-focus);
}

.pilot-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}

.pilot-status {
  margin: 18px 0 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(124, 167, 159, 0.24);
  background: rgba(124, 167, 159, 0.12);
  color: var(--ink);
}

.pilot-status[hidden] {
  display: none;
}

html[data-theme="dark"] .chart-shell {
  background: linear-gradient(180deg, rgba(18, 25, 21, 0.86), rgba(11, 16, 14, 0.94));
}

html[data-theme="dark"] .site-header {
  background:
    linear-gradient(180deg, rgba(51, 62, 56, 0.92), rgba(41, 51, 46, 0.74));
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255, 248, 239, 0.08);
}

html[data-theme="dark"] .site-footer {
  background:
    linear-gradient(180deg, rgba(39, 48, 43, 0.8), rgba(50, 60, 54, 0.94));
}

html[data-theme="dark"] .tile-card:hover,
html[data-theme="dark"] .tile-card:focus-within {
  box-shadow: 0 28px 54px rgba(0, 0, 0, 0.24);
}

html[data-theme="dark"] .section-products {
  background:
    linear-gradient(180deg, rgba(17, 23, 20, 0.36), rgba(17, 23, 20, 0)),
    transparent;
}

html[data-theme="dark"] .section-platform::after {
  background:
    radial-gradient(
      circle at var(--pointer-x) var(--pointer-y),
      rgba(255, 248, 239, 0.14),
      rgba(204, 178, 122, 0.12) 14%,
      rgba(124, 167, 159, 0.08) 28%,
      rgba(124, 167, 159, 0) 42%
    ),
    linear-gradient(180deg, rgba(255, 248, 239, 0.04), rgba(255, 248, 239, 0.01));
}

html[data-theme="dark"] .combined-map {
  background:
    radial-gradient(circle at center, rgba(124, 167, 159, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(18, 25, 21, 0.82), rgba(11, 16, 14, 0.88));
}

html[data-theme="dark"] .combined-map::before,
html[data-theme="dark"] .combined-map::after {
  background:
    linear-gradient(
      180deg,
      rgba(255, 248, 239, 0),
      rgba(255, 248, 239, 0.14),
      rgba(255, 248, 239, 0)
    );
}

html[data-theme="dark"] .combined-map::after {
  background:
    linear-gradient(
      90deg,
      rgba(255, 248, 239, 0),
      rgba(255, 248, 239, 0.14),
      rgba(255, 248, 239, 0)
    );
}

html[data-theme="dark"] .cta-panel {
  background:
    radial-gradient(circle at top left, rgba(124, 167, 159, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(22, 29, 25, 0.88), rgba(14, 19, 17, 0.8));
}

html[data-theme="dark"] .section-process {
  background:
    radial-gradient(circle at 84% 28%, rgba(124, 167, 159, 0.08), transparent 24%),
    radial-gradient(circle at 14% 76%, rgba(204, 178, 122, 0.08), transparent 24%),
    linear-gradient(180deg, rgba(18, 25, 21, 0.18), rgba(18, 25, 21, 0.4)),
    transparent;
}

html[data-theme="dark"] .home-action-sphere::before {
  background:
    radial-gradient(circle at 50% 50%, rgba(132, 182, 174, 0.18), transparent 38%),
    radial-gradient(circle at 58% 42%, rgba(213, 180, 125, 0.1), transparent 46%);
}

html[data-theme="dark"] .section-intelligence-band {
  background:
    linear-gradient(
      180deg,
      rgba(16, 22, 19, 0) 0%,
      rgba(18, 25, 21, 0.44) 14%,
      rgba(20, 27, 24, 0.5) 50%,
      rgba(18, 25, 21, 0.42) 86%,
      rgba(16, 22, 19, 0) 100%
    );
}

html[data-theme="dark"] .team-photo-wrap {
  background: linear-gradient(140deg, rgba(124, 167, 159, 0.28), rgba(204, 178, 122, 0.26));
  box-shadow: 0 16px 28px rgba(0, 0, 0, 0.24);
}

html[data-theme="dark"] .page-focus-band::after {
  background:
    radial-gradient(
      circle at var(--pointer-x) var(--pointer-y),
      rgba(255, 248, 239, 0.12),
      rgba(204, 178, 122, 0.12) 14%,
      rgba(124, 167, 159, 0.08) 28%,
      rgba(124, 167, 159, 0) 42%
    ),
    linear-gradient(180deg, rgba(255, 248, 239, 0.03), rgba(255, 248, 239, 0.01));
}

html[data-theme="dark"] .about-build-card {
  background:
    linear-gradient(180deg, rgba(24, 32, 28, 0.9), rgba(18, 24, 21, 0.82)),
    rgba(21, 28, 24, 0.86);
}

html[data-theme="dark"] .keyword-active-title {
  background: none;
  color: var(--white);
  -webkit-text-fill-color: currentColor;
  animation: none;
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.16);
}

html[data-theme="dark"] .keyword-back:hover,
html[data-theme="dark"] .keyword-back:focus-visible,
html[data-theme="dark"] .faq-nav a:hover,
html[data-theme="dark"] .faq-nav a:focus-visible {
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.2);
}

html[data-theme="dark"] .inner-page-join {
  background:
    radial-gradient(circle at 14% 10%, rgba(124, 167, 159, 0.12), transparent 22%),
    radial-gradient(circle at 86% 18%, rgba(204, 178, 122, 0.1), transparent 22%),
    linear-gradient(180deg, #0f1512 0%, #141b17 18%, #111713 54%, #0d120f 100%);
}

html[data-theme="dark"] .join-hero::before {
  background:
    radial-gradient(circle at 24% 20%, rgba(204, 178, 122, 0.1), transparent 22%),
    radial-gradient(circle at 76% 30%, rgba(124, 167, 159, 0.12), transparent 26%),
    radial-gradient(circle at 62% 54%, rgba(167, 191, 138, 0.08), transparent 22%),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.42) 0%,
      rgba(255, 255, 255, 0.14) 36%,
      rgba(255, 255, 255, 0) 72%
    );
}

html[data-theme="dark"] .join-hero::after {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06) 0%,
      rgba(255, 255, 255, 0.24) 42%,
      rgba(255, 255, 255, 0.92) 100%
    );
}

html[data-theme="dark"] .join-hero {
  background: #ffffff;
  --join-hero-ink: #18221c;
  --join-hero-muted: #5d675d;
  --join-hero-accent: #47593f;
}

html[data-theme="dark"] .join-breadcrumb {
  color: rgba(71, 89, 63, 0.72);
}

html[data-theme="dark"] .join-breadcrumb a,
html[data-theme="dark"] .join-hero .eyebrow {
  color: var(--join-hero-accent);
}

html[data-theme="dark"] .join-page-intro,
html[data-theme="dark"] .join-hero-note {
  color: var(--join-hero-muted);
}

html[data-theme="dark"] .join-stat-grid .page-stat {
  border-color: rgba(24, 34, 28, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.82), rgba(246, 239, 229, 0.74)),
    rgba(255, 250, 242, 0.74);
  box-shadow: 0 20px 50px rgba(28, 34, 27, 0.12);
}

html[data-theme="dark"] .join-stat-grid .page-stat strong {
  color: var(--join-hero-ink);
}

html[data-theme="dark"] .join-stat-grid .page-stat span {
  color: var(--join-hero-muted);
}

html[data-theme="dark"] .join-stat-grid .page-stat small {
  color: var(--join-hero-accent);
}

html[data-theme="dark"] .join-stat-grid .page-stat:hover,
html[data-theme="dark"] .join-stat-grid .page-stat:focus-within {
  border-color: rgba(24, 34, 28, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.92), rgba(248, 241, 232, 0.82)),
    rgba(255, 250, 242, 0.82);
  box-shadow: 0 28px 56px rgba(28, 34, 27, 0.14);
}

html[data-theme="dark"] .join-hero-media::after {
  background:
    linear-gradient(
      to right,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.18) 44%,
      rgba(255, 255, 255, 0.68) 70%,
      rgba(255, 255, 255, 0.96) 100%
    ),
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.12) 58%,
      rgba(255, 255, 255, 0.54) 80%,
      rgba(255, 255, 255, 0.98) 100%
    );
}

html[data-theme="dark"] .join-settle-section {
  background:
    linear-gradient(180deg, rgba(12, 17, 14, 0.42), rgba(12, 17, 14, 0));
}

.inner-page-login .page-glow-left {
  background: rgba(124, 167, 159, 0.26);
}

.inner-page-login .page-glow-right {
  background: rgba(204, 178, 122, 0.2);
}

.inner-page-portal .page-glow-left {
  background: rgba(124, 167, 159, 0.24);
}

.inner-page-portal .page-glow-right {
  background: rgba(167, 191, 138, 0.18);
}

.inner-page-mai-dashboard .page-glow-left {
  background: rgba(124, 167, 159, 0.22);
}

.inner-page-mai-dashboard .page-glow-right {
  background: rgba(204, 178, 122, 0.22);
}

.inner-page-login .site-header,
.inner-page-portal .site-header {
  background: rgba(245, 239, 228, 0.76);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(24, 34, 28, 0.08);
}

html[data-theme="dark"] .inner-page-login .site-header,
html[data-theme="dark"] .inner-page-portal .site-header {
  background: rgba(45, 56, 50, 0.9);
  border-bottom-color: rgba(255, 248, 239, 0.08);
}

.inner-page-login main,
.inner-page-portal main {
  min-height: calc(100vh - 250px);
}

.inner-page-login .site-footer,
.inner-page-portal .site-footer {
  margin-top: 0;
}

.portal-hero {
  padding-top: 42px;
  padding-bottom: 48px;
}

.portal-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(420px, 0.95fr);
  gap: clamp(34px, 4vw, 56px);
  align-items: start;
}

.portal-hero-grid-login {
  align-items: center;
}

.portal-copy h1 {
  max-width: 12ch;
  font-size: clamp(3rem, 5vw, 5.1rem);
  line-height: 0.92;
}

.portal-panel,
.sensor-card,
.portal-stat-card,
.mai-kpi-card,
.mai-panel {
  position: relative;
  min-width: 0;
  overflow: hidden;
}

.portal-panel,
.sensor-card,
.mai-panel {
  padding: 30px;
  border-radius: calc(var(--radius-xl) + 2px);
  border: 1px solid var(--card-border);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.76), rgba(242, 236, 226, 0.54)),
    var(--card-surface);
  box-shadow: var(--shadow-lg);
}

.portal-panel::before,
.sensor-card::before,
.mai-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.portal-panel > *,
.sensor-card > *,
.mai-panel > * {
  position: relative;
  z-index: 1;
}

.portal-panel::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.2), transparent 30%),
    radial-gradient(circle at 80% 10%, rgba(204, 178, 122, 0.16), transparent 24%);
}

.sensor-card::before {
  background:
    radial-gradient(circle at 12% 18%, rgba(124, 167, 159, 0.16), transparent 28%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.18), transparent 22%);
}

.mai-panel::before {
  background:
    radial-gradient(circle at 14% 18%, rgba(124, 167, 159, 0.18), transparent 28%),
    radial-gradient(circle at 84% 14%, rgba(204, 178, 122, 0.2), transparent 22%),
    radial-gradient(circle at 78% 82%, rgba(167, 191, 138, 0.12), transparent 24%);
}

.portal-label {
  margin: 0 0 12px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--pill-surface);
  border: 1px solid var(--pill-border);
  color: var(--olive);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.portal-panel h2,
.sensor-card h3,
.mai-panel h2,
.mai-panel h3 {
  margin: 0;
  text-wrap: pretty;
}

.portal-panel h2,
.mai-panel h2 {
  font-size: clamp(1.74rem, 2.2vw, 2.28rem);
}

.portal-panel-copy,
.sensor-card p,
.portal-stat-card p,
.activity-item p,
.alert-item p,
.timeline-copy span {
  margin: 0;
  color: var(--muted);
}

.portal-panel-copy strong {
  color: var(--ink);
}

.portal-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.portal-chip {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--pill-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
  color: var(--olive);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 250, 242, 0.32);
}

.auth-panel {
  margin-top: 30px;
}

.auth-form {
  display: grid;
  gap: 16px;
  margin-top: 22px;
}

.auth-field {
  display: grid;
  gap: 8px;
}

.auth-field span {
  color: var(--olive);
  font-size: 0.92rem;
  font-weight: 700;
}

.auth-field input {
  min-height: 56px;
  padding: 0 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--ink);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease;
}

.auth-field input.is-invalid {
  border-color: #b55f54;
  box-shadow: 0 0 0 4px rgba(181, 95, 84, 0.12);
}

.auth-password-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.auth-password-wrap input {
  width: 100%;
  padding-right: 92px;
}

.auth-password-toggle {
  position: absolute;
  right: 10px;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--pill-border);
  border-radius: 50%;
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
  color: var(--olive);
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.auth-password-toggle:hover,
.auth-password-toggle:focus-visible {
  color: var(--ink);
  border-color: var(--line-strong);
}

.auth-password-eye {
  width: 18px;
  height: 18px;
  display: inline-flex;
}

.auth-password-eye svg {
  width: 100%;
  height: 100%;
}

.auth-password-eye-off {
  opacity: 0.95;
}

.auth-password-toggle.is-revealed .auth-password-eye-off {
  opacity: 0;
}

.auth-field input::placeholder {
  color: color-mix(in srgb, var(--muted) 80%, transparent);
}

.auth-field input:focus {
  outline: none;
  border-color: var(--line-strong);
  background: var(--input-bg-focus);
  box-shadow: 0 0 0 4px rgba(124, 167, 159, 0.12);
}

.auth-submit {
  width: fit-content;
  min-width: min(100%, 280px);
}

.auth-feedback {
  min-height: 1.4rem;
  margin: -2px 0 0;
  color: var(--muted);
  font-size: 0.92rem;
}

.auth-feedback.is-error {
  color: #b55f54;
}

.auth-feedback.is-success {
  color: var(--olive);
}

.auth-form.is-submitting .auth-submit {
  opacity: 0.78;
  pointer-events: none;
}

.auth-switch {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 0.96rem;
}

.auth-switch a {
  color: var(--olive);
  font-weight: 700;
}

.auth-switch a:hover,
.auth-switch a:focus-visible {
  color: var(--ink);
}

.auth-note {
  display: grid;
  gap: 8px;
  margin-top: 18px;
  padding: 18px 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.auth-note strong {
  font-size: 0.96rem;
  line-height: 1.45;
}

.auth-stage {
  padding-top: 28px;
  padding-bottom: 76px;
}

.auth-panel-compact {
  width: min(560px, 100%);
  margin: 0 auto;
  padding: 34px;
}

.auth-panel-compact h1 {
  max-width: 12ch;
  font-size: clamp(2.7rem, 4.8vw, 4.2rem);
  line-height: 0.94;
}

.auth-panel-compact .portal-panel-copy {
  max-width: 34ch;
  margin-top: 14px;
}

.auth-form-compact {
  margin-top: 24px;
}

.selector-stage {
  padding-top: 28px;
  padding-bottom: 76px;
}

.dashboard-select-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.dashboard-select-shell {
  flex: 1 1 680px;
  display: grid;
  gap: 10px;
  max-width: 680px;
  min-width: 0;
}

.dashboard-select-shell h1 {
  max-width: none;
  font-size: clamp(2.8rem, 5vw, 4.8rem);
  line-height: 0.94;
}

.dashboard-register-button {
  min-height: 64px;
  padding: 0 24px 0 20px;
  gap: 14px;
  align-self: flex-start;
}

.dashboard-register-button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.16);
  font-size: 1.15rem;
  font-weight: 800;
  flex: none;
}

.dashboard-register-button-copy {
  display: grid;
  gap: 2px;
  text-align: left;
}

.dashboard-register-button-title {
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.1;
}

.dashboard-register-button-meta {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.88;
}

.dashboard-select-shell .page-intro {
  margin-top: 0;
}

.portal-inline-feedback {
  min-height: 1.4rem;
  margin: 0;
}

.sensor-library-select {
  margin-top: 32px;
}

.sensor-library-select .sensor-card {
  min-height: 0;
}

.sensor-card-muted {
  opacity: 0.92;
}

.sensor-card-empty {
  border-style: dashed;
}

.sensor-card-cta {
  cursor: pointer;
}

.sensor-card-link.is-locked:hover,
.sensor-card-link.is-locked:focus-visible {
  transform: translateY(-2px);
  border-color: var(--card-border-strong);
  box-shadow: 0 28px 56px rgba(28, 34, 27, 0.16);
}

.sensor-card-link.is-locked .sensor-card-note {
  color: var(--ink);
}

.sensor-device-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sensor-device-chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--button-secondary-border);
  background: color-mix(in srgb, var(--card-surface-strong) 88%, transparent);
  color: var(--olive);
  font-size: 0.82rem;
  font-weight: 700;
}

.portal-modal-open {
  overflow: hidden;
}

.portal-modal {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(18, 25, 21, 0.42);
  backdrop-filter: blur(12px);
}

.portal-modal[hidden] {
  display: none;
}

.portal-modal-dialog {
  width: min(100%, 520px);
  padding: 28px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.96), rgba(242, 236, 226, 0.94)),
    var(--card-surface);
  box-shadow: var(--shadow-lg);
}

.portal-modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.portal-modal-header .eyebrow {
  margin-bottom: 10px;
}

.portal-modal-header h2 {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1;
}

.portal-modal-close {
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid var(--button-secondary-border);
  border-radius: 50%;
  background: var(--button-secondary-bg);
  color: var(--ink);
  font-size: 1.45rem;
  line-height: 1;
  cursor: pointer;
}

.portal-modal-form {
  display: grid;
  gap: 16px;
  margin-top: 24px;
}

.portal-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}

.portal-modal-form.is-submitting button[type="submit"] {
  opacity: 0.78;
  pointer-events: none;
}

.sensor-stage-portal::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.24), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.2), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(167, 191, 138, 0.18), transparent 24%);
}

.sensor-stage-portal-home::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.22), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(167, 191, 138, 0.2), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(204, 178, 122, 0.18), transparent 24%);
}

.sensor-stage-mai-dashboard::before {
  background:
    radial-gradient(circle at 18% 18%, rgba(124, 167, 159, 0.22), transparent 30%),
    radial-gradient(circle at 82% 14%, rgba(204, 178, 122, 0.24), transparent 24%),
    radial-gradient(circle at 70% 74%, rgba(124, 167, 159, 0.18), transparent 24%);
}

.portal-stat-grid {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.portal-stat-card,
.mai-kpi-card {
  padding: 20px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
  box-shadow: var(--shadow-md);
}

.portal-stat-card {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 170px;
}

.portal-stat-card span,
.mai-kpi-card span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--olive);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.portal-stat-card strong,
.mai-kpi-card strong,
.sensor-card-metric strong,
.trend-summary-item strong {
  display: block;
  font-family: "Sora", "Aptos Display", sans-serif;
  letter-spacing: -0.04em;
}

.portal-stat-card strong {
  font-size: clamp(1.24rem, 1.55vw, 1.82rem);
  line-height: 1.08;
}

.sensor-library {
  margin-top: 38px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.sensor-card {
  display: grid;
  align-content: start;
  gap: 20px;
}

.sensor-card-link,
.sensor-card-cta {
  transition:
    transform 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.sensor-card-link:hover,
.sensor-card-link:focus-visible,
.sensor-card-cta:hover,
.sensor-card-cta:focus-visible {
  transform: translateY(-2px);
  border-color: var(--card-border-strong);
  box-shadow: 0 28px 56px rgba(28, 34, 27, 0.16);
}

.sensor-card-mai::before {
  background:
    radial-gradient(circle at 12% 18%, rgba(124, 167, 159, 0.22), transparent 30%),
    radial-gradient(circle at 86% 14%, rgba(204, 178, 122, 0.22), transparent 22%);
}

.sensor-card-coming::before {
  background:
    radial-gradient(circle at 12% 18%, rgba(167, 191, 138, 0.16), transparent 30%),
    radial-gradient(circle at 86% 14%, rgba(204, 178, 122, 0.14), transparent 22%);
}

.sensor-card-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.sensor-card-label,
.sensor-card-status,
.mai-panel-chip,
.alert-severity {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sensor-card-label,
.mai-panel-chip {
  border: 1px solid var(--pill-border);
  background: var(--pill-surface);
  color: var(--olive);
}

.sensor-card-status {
  border: 1px solid rgba(102, 122, 88, 0.2);
  background: rgba(102, 122, 88, 0.08);
  color: var(--olive);
}

.sensor-card-status-muted {
  border-color: var(--pill-border);
  background: color-mix(in srgb, var(--card-surface-strong) 88%, transparent);
  color: var(--muted);
}

.sensor-card h3 {
  font-size: clamp(1.58rem, 2vw, 2.18rem);
}

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

.sensor-card-metric,
.trend-summary-item {
  padding: 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 88%, transparent);
}

.sensor-card-metric strong {
  font-size: clamp(1rem, 1.18vw, 1.2rem);
  line-height: 1.1;
}

.sensor-card-metric span,
.trend-summary-item span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
}

.sensor-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.sensor-card-note {
  color: var(--olive);
  font-weight: 700;
}

.sensor-card-disabled {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--button-secondary-border);
  background: var(--button-secondary-bg);
  color: var(--muted);
  font-weight: 700;
}

.portal-insight-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 18px;
}

.activity-list,
.support-list,
.alert-list,
.event-timeline {
  list-style: none;
  padding: 0;
  margin: 22px 0 0;
}

.activity-list,
.alert-list,
.event-timeline {
  display: grid;
  gap: 14px;
}

.activity-item,
.alert-item {
  display: grid;
  gap: 10px;
  padding: 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.activity-item strong,
.alert-item strong,
.timeline-copy strong {
  display: block;
  line-height: 1.38;
}

.activity-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.activity-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--card-surface-strong) 88%, transparent);
  color: var(--olive);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.support-list {
  display: grid;
  gap: 12px;
}

.support-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px 18px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.support-item span {
  color: var(--muted);
}

.support-item strong {
  color: var(--ink);
  text-align: right;
}

.mai-hero-copy h1 {
  max-width: 13ch;
}

.mai-kpi-grid {
  margin-top: 30px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.mai-kpi-card {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 176px;
}

.mai-kpi-card strong {
  font-size: clamp(1.6rem, 2.6vw, 2.42rem);
  line-height: 1;
}

.mai-kpi-card p {
  margin: 0;
  color: var(--muted);
}

.mai-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(300px, 0.88fr);
  gap: 18px;
  align-items: start;
}

.mai-panel-wide {
  min-height: 100%;
}

.mai-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.trend-stage,
.route-stage {
  margin-top: 22px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--card-border);
  background:
    linear-gradient(180deg, rgba(255, 252, 247, 0.58), rgba(242, 236, 226, 0.2)),
    color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
}

.trend-stage {
  padding: 18px;
}

.trend-svg {
  width: 100%;
  height: auto;
  display: block;
}

.trend-grid-line {
  stroke: var(--line);
  stroke-width: 1;
}

.trend-area {
  fill: url(#maiTrendArea);
}

.trend-line-primary,
.trend-line-secondary {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.trend-line-primary {
  stroke: var(--teal);
  stroke-width: 4;
}

.trend-line-secondary {
  stroke: var(--sand);
  stroke-width: 3;
  stroke-dasharray: 10 8;
}

.trend-marker {
  fill: var(--white);
  stroke: var(--teal);
  stroke-width: 3;
}

.trend-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.trend-summary-item strong {
  font-size: clamp(1rem, 1.2vw, 1.24rem);
  line-height: 1.08;
}

.route-stage {
  position: relative;
  min-height: 330px;
  padding: 22px;
  overflow: hidden;
}

.route-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 64px 64px;
  opacity: 0.8;
  pointer-events: none;
}

.route-path {
  position: absolute;
  inset: 24px;
}

.route-path svg {
  width: 100%;
  height: 100%;
}

.route-line {
  fill: none;
  stroke: var(--teal);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 10 8;
}

.route-node {
  stroke-width: 3;
}

.route-node-start,
.route-node-end {
  fill: var(--white);
  stroke: var(--sand);
}

.route-node-mid {
  fill: var(--white);
  stroke: var(--teal);
}

.route-point {
  position: absolute;
  display: grid;
  gap: 4px;
  max-width: 150px;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-surface-strong) 94%, transparent);
  box-shadow: var(--shadow-md);
}

.route-point strong {
  font-size: 0.92rem;
  line-height: 1.22;
}

.route-point span {
  color: var(--muted);
  font-size: 0.8rem;
}

.route-point-start {
  left: 10%;
  bottom: 16%;
}

.route-point-mid {
  left: 34%;
  top: 38%;
}

.route-point-end {
  right: 10%;
  top: 10%;
}

.route-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.route-legend span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--pill-border);
  background: color-mix(in srgb, var(--card-surface-strong) 90%, transparent);
  color: var(--olive);
  font-weight: 700;
}

.alert-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.alert-severity {
  border: 1px solid transparent;
}

.alert-severity-watch {
  background: rgba(204, 178, 122, 0.12);
  border-color: rgba(204, 178, 122, 0.22);
  color: #8a6a2b;
}

.alert-severity-info {
  background: rgba(124, 167, 159, 0.12);
  border-color: rgba(124, 167, 159, 0.22);
  color: #476d68;
}

.alert-severity-resolved {
  background: rgba(167, 191, 138, 0.14);
  border-color: rgba(167, 191, 138, 0.26);
  color: #597049;
}

.health-list {
  display: grid;
  gap: 16px;
  margin-top: 22px;
}

.health-meter {
  display: grid;
  gap: 8px;
}

.health-meter-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.health-meter-top span {
  color: var(--muted);
  font-weight: 700;
}

.health-meter-top strong {
  color: var(--ink);
}

.health-bar {
  height: 10px;
  border-radius: 999px;
  background: rgba(124, 167, 159, 0.12);
  overflow: hidden;
}

.health-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--olive), var(--teal), var(--sand));
}

.event-timeline {
  gap: 16px;
}

.timeline-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
}

.timeline-marker {
  width: 12px;
  height: 12px;
  margin-top: 0.35rem;
  border-radius: 999px;
  background: var(--teal);
  box-shadow: 0 0 0 6px rgba(124, 167, 159, 0.12);
}

html[data-theme="dark"] .portal-panel,
html[data-theme="dark"] .sensor-card,
html[data-theme="dark"] .mai-panel {
  background:
    linear-gradient(180deg, rgba(24, 32, 28, 0.94), rgba(16, 22, 19, 0.88)),
    rgba(21, 28, 24, 0.9);
}

html[data-theme="dark"] .portal-stat-card,
html[data-theme="dark"] .mai-kpi-card,
html[data-theme="dark"] .sensor-card-metric,
html[data-theme="dark"] .trend-summary-item,
html[data-theme="dark"] .activity-item,
html[data-theme="dark"] .alert-item,
html[data-theme="dark"] .support-item,
html[data-theme="dark"] .route-point,
html[data-theme="dark"] .auth-note,
html[data-theme="dark"] .trend-stage,
html[data-theme="dark"] .route-stage {
  background:
    linear-gradient(180deg, rgba(28, 37, 32, 0.92), rgba(19, 26, 23, 0.84)),
    rgba(21, 28, 24, 0.84);
}

html[data-theme="dark"] .portal-chip,
html[data-theme="dark"] .route-legend span,
html[data-theme="dark"] .sensor-card-disabled,
html[data-theme="dark"] .activity-meta span {
  background: rgba(255, 248, 239, 0.06);
}

html[data-theme="dark"] .sensor-device-chip,
html[data-theme="dark"] .portal-modal-close {
  border-color: rgba(255, 248, 239, 0.14);
}

html[data-theme="dark"] .portal-modal-dialog {
  background:
    linear-gradient(180deg, rgba(24, 32, 28, 0.96), rgba(15, 21, 18, 0.94)),
    var(--card-surface);
}

html[data-theme="dark"] .alert-severity-watch {
  color: #e0c48d;
}

html[data-theme="dark"] .alert-severity-info {
  color: #a9d3cc;
}

html[data-theme="dark"] .alert-severity-resolved {
  color: #bdd49e;
}

html[data-theme="dark"] .trend-marker,
html[data-theme="dark"] .route-node-start,
html[data-theme="dark"] .route-node-end,
html[data-theme="dark"] .route-node-mid {
  fill: rgba(16, 22, 19, 0.96);
}

@media (max-width: 1120px) {
  .portal-hero-grid,
  .portal-insight-grid,
  .mai-dashboard-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 860px) {
  .dashboard-select-hero {
    flex-direction: column;
    align-items: stretch;
  }

  .dashboard-register-button {
    width: 100%;
    justify-content: flex-start;
  }

  .portal-stat-grid,
  .sensor-library,
  .mai-kpi-grid,
  .trend-summary {
    grid-template-columns: 1fr;
  }

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

  .portal-panel,
  .sensor-card,
  .mai-panel {
    padding: 24px;
  }

  .route-stage {
    min-height: 300px;
  }
}

@media (max-width: 640px) {
  .portal-hero {
    padding-top: 28px;
  }

  .portal-modal {
    padding: 16px;
  }

  .portal-modal-dialog {
    padding: 22px;
  }

  .auth-submit {
    width: 100%;
  }

  .route-stage {
    min-height: 280px;
    padding: 18px;
  }

  .route-point {
    max-width: 120px;
    padding: 10px 12px;
  }

  .route-point-start {
    left: 6%;
    bottom: 14%;
  }

  .route-point-mid {
    left: 28%;
    top: 42%;
  }

  .portal-modal-actions .button {
    width: 100%;
  }

  .route-point-end {
    right: 6%;
    top: 12%;
  }

  .support-item {
    align-items: flex-start;
    flex-direction: column;
  }

  .support-item strong {
    text-align: left;
  }
}

html.reveal-effects-enabled [data-reveal] {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 700ms ease, transform 700ms ease;
}

html.reveal-effects-enabled [data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1120px) {
  .hero-grid,
  .page-hero-grid,
  .platform-layout,
  .market-grid,
  .intelligence-band-grid,
  .cta-panel,
  .process-hero,
  .detail-grid,
  .pilot-layout,
  .footer-inner,
  .faq-layout {
    grid-template-columns: 1fr;
  }

  .hero-visual {
    min-height: 560px;
  }

  .dashboard-card-main {
    inset: 36px 70px 40px 0;
  }

  .process-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .process-visual {
    width: min(100%, 620px);
    justify-self: start;
  }

  .home-action-sphere {
    width: min(100%, 620px);
  }

  .page-stat-grid,
  .story-grid,
  .fit-grid,
  .career-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .deployment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .cta-panel {
    align-items: flex-start;
  }

  .cta-actions {
    justify-content: flex-start;
  }

  .join-hero-stage {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .join-hero-media {
    min-height: clamp(420px, 58vw, 640px);
    margin-right: 0;
  }

  .join-hero-media::after {
    top: auto;
    right: 0;
    bottom: -1px;
    left: 0;
    width: auto;
    height: clamp(96px, 16vw, 160px);
    background:
      linear-gradient(
        to bottom,
        rgba(18, 24, 21, 0) 0%,
        rgba(18, 24, 21, 0.16) 54%,
        rgba(18, 24, 21, 0.74) 100%
      );
  }

  .join-hero-copy-shell {
    padding: 24px 24px 0;
  }

  .join-hero-copy {
    width: min(100%, 42rem);
  }
}

@media (max-width: 860px) {
  :root {
    --container: min(100vw - 28px, 720px);
  }

  .header-inner,
  .footer-inner {
    align-items: flex-start;
  }

  .header-inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .header-actions {
    width: 100%;
    justify-content: flex-start;
    margin-left: 0;
  }

  .site-nav {
    display: flex;
    width: 100%;
    max-width: 100%;
    flex-wrap: wrap;
    box-sizing: border-box;
  }

  .footer-links {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .proof-strip,
  .problem-grid,
  .product-grid,
  .platform-grid,
  .intelligence-band-grid,
  .team-grid,
  .process-track,
  .page-stat-grid,
  .story-grid,
  .deployment-grid,
  .fit-grid,
  .career-grid,
  .about-detail-grid,
  .field-grid {
    grid-template-columns: 1fr;
  }

  .hero {
    padding-top: 28px;
  }

  .hero-visual {
    min-height: 640px;
  }

  .dashboard-card-main {
    position: relative;
    inset: auto;
  }

  .dashboard-card-sunbul,
  .dashboard-card-mai {
    position: absolute;
  }

  .dashboard-card-sunbul {
    top: 16px;
    right: 14px;
  }

  .dashboard-card-mai {
    left: 14px;
    bottom: 14px;
  }

  .cta-emblem {
    width: 180px;
    right: -8%;
  }

  .team-card {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .signal-row {
    grid-template-columns: 1fr;
  }

  .keyword-active-copy {
    max-width: none;
  }

  .page-stat-grid > :last-child {
    grid-column: auto;
  }

  .team-card-media {
    justify-content: flex-start;
  }

  .join-hero-copy-shell {
    padding: 24px 0 0;
  }

  .join-hero-copy {
    width: 100%;
  }
}

@media (max-width: 640px) {
  .site-header {
    position: static;
    padding-bottom: 0;
  }

  .site-nav {
    gap: 10px;
    padding: 10px 12px;
  }

  .site-nav a {
    font-size: 0.88rem;
  }

  .header-actions {
    gap: 10px;
  }

  .hero-actions,
  .cta-actions,
  .not-found-actions,
  .portal-modal-actions {
    width: 100%;
  }

  .hero-actions .button,
  .cta-actions .button,
  .not-found-actions .button,
  .portal-modal-actions .button {
    flex: 1 1 min(100%, 220px);
  }

  .pilot-form .button,
  .auth-submit {
    width: 100%;
  }

  .theme-toggle {
    padding-right: 14px;
  }

  h1,
  h2,
  h3,
  .page-hero-copy h1,
  .section-heading h2,
  .join-hero-copy h1 {
    max-width: none;
    overflow-wrap: anywhere;
    word-break: normal;
  }

  h1 {
    max-width: none;
  }

  .about-build-card {
    padding: 20px;
  }

  .hero-visual {
    min-height: auto;
    display: grid;
    gap: 16px;
  }

  .dashboard-card-main,
  .dashboard-card-sunbul,
  .dashboard-card-mai {
    position: relative;
    inset: auto;
    width: auto;
  }

  .dashboard-card-main {
    padding: 22px;
  }

  .metric-grid {
    grid-template-columns: 1fr;
  }

  .section {
    padding: 82px 0;
  }

  .cta-panel,
  .problem-card,
  .product-card,
  .platform-card,
  .team-card,
  .market-card,
  .process-track article {
    padding: 22px;
  }

  .sensor-stage,
  .story-card,
  .detail-panel,
  .deployment-step,
  .fit-card,
  .pilot-form-shell,
  .pilot-sidebar,
  .page-stat,
  .career-card {
    padding: 22px;
  }

  .sensor-stage-grid {
    grid-template-columns: 1fr;
  }

  .page-stat,
  .sensor-stage-card,
  .story-card,
  .deployment-step {
    min-height: 0;
  }

  .keyword-trigger {
    font-size: clamp(1.55rem, 9vw, 2.4rem);
  }

  .keyword-stage {
    min-height: 0;
  }

  .page-hero-copy h1 {
    max-width: none;
  }

  .inner-page-contact .page-hero-copy,
  .inner-page-contact .page-intro {
    max-width: 100%;
    width: 100%;
  }

  .inner-page-contact .page-intro {
    width: min(100%, 31ch);
  }

  .process-visual {
    min-height: 360px;
  }

  .home-action-sphere,
  .home-action-canvas {
    min-height: 360px;
  }

  .page-hero.join-hero {
    padding-top: 0;
    padding-bottom: 84px;
    min-height: auto;
  }

  .join-hero-media {
    min-height: clamp(300px, 86vw, 420px);
  }

  .brand-icon {
    width: 42px;
    height: 42px;
  }

  .brand-wordmark {
    height: 38px;
  }

  .team-photo-wrap {
    width: 158px;
    height: 158px;
  }

  .brand-icon-footer {
    width: 54px;
    height: 54px;
  }

  .brand-wordmark-footer {
    height: 46px;
  }

  .footer-links {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .cta-emblem {
    display: none;
  }
}

@media (max-width: 1120px) {
  .about-cinema {
    --about-cinema-copy-reserve: clamp(320px, 31vw, 410px);
  }

  .about-cinema-copy {
    width: min(100%, 17rem);
    margin-left: clamp(40px, 4.8vw, 80px);
  }

  .about-cinema-copy h1 {
    max-width: 8.8ch;
    font-size: clamp(1.75rem, 2.7vw, 2.7rem);
  }
}

@media (max-width: 860px) {
  .about-cinema {
    --about-cinema-copy-reserve: 0px;
  }

  .about-cinema-track {
    height: 125svh;
  }

  .about-cinema-stage {
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    min-height: 0;
  }

  .about-cinema-media {
    position: relative;
    inset: auto;
    min-height: 0;
  }

  .about-cinema-frame {
    object-position: center top;
  }

  .about-cinema-copy-shell {
    position: relative;
    inset: auto;
    display: block;
    padding: 22px 24px 28px;
    background: #ffffff;
  }

  .about-cinema-copy {
    width: auto;
    margin: 0;
    color: #0b120e;
    opacity: 1;
    transform: none;
  }

  .about-cinema-copy h1 {
    max-width: none;
    font-size: clamp(2.15rem, 7.1vw, 3.4rem);
  }

  .about-cinema-subcopy {
    max-width: 34ch;
    font-size: 0.96rem;
  }
}

@media (max-width: 640px) {
  .about-cinema-track {
    height: 125svh;
  }

  .about-cinema-stage {
    height: calc(100svh - var(--about-cinema-header-offset));
  }

  .about-cinema-copy-shell {
    padding: 18px 0 24px;
  }

  .about-cinema-copy h1 {
    font-size: clamp(2.2rem, 10vw, 3.5rem);
  }

  .about-cinema-subcopy {
    max-width: none;
  }

  .about-manifesto-strip {
    padding: 24px 0 14px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .button,
  .theme-toggle,
  .theme-toggle-icon,
  .theme-toggle-icon::before,
  .theme-toggle-icon::after,
  .dashboard-card-float,
  .tile-card,
  [data-reveal],
  .status-dot::before,
  .status-dot::after,
  .join-hero::before,
  .join-orb-blob,
  .join-orb-shine {
    animation: none !important;
    transition: none !important;
  }

  .about-cinema-track {
    height: auto;
  }

  .about-cinema-stage {
    position: relative;
    top: auto;
    height: calc(100svh - var(--about-cinema-header-offset));
  }

  .about-cinema-copy {
    opacity: 1 !important;
    transform: none !important;
  }
}

@media (prefers-reduced-motion: reduce) and (max-width: 860px) {
  .about-cinema-stage {
    height: auto;
  }
}

html[data-theme="dark"] .about-cinema-stage::after {
  height: clamp(120px, 18vh, 260px);
  background:
    linear-gradient(
      to bottom,
      rgba(16, 21, 16, 0) 0%,
      rgba(16, 21, 16, 0.12) 28%,
      rgba(16, 21, 16, 0.35) 58%,
      #101510 100%
    );
}

html[data-theme="dark"] .about-manifesto-strip {
  background: #101510;
}

@keyframes themeToggleOrbSettle {
  0% {
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
  34% {
    transform: translate3d(0, -1px, 0) scale(1.1) rotate(-10deg);
  }
  62% {
    transform: translate3d(0, 0, 0) scale(0.96) rotate(5deg);
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1) rotate(0deg);
  }
}

@keyframes sensorFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -10px, 0);
  }
}

@keyframes buttonFlow {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes sectionGradientMorph {
  0% {
    transform: translate3d(-1.5%, -1%, 0) scale(1);
  }
  50% {
    transform: translate3d(1.8%, 1.2%, 0) scale(1.04);
  }
  100% {
    transform: translate3d(-1.2%, 1.6%, 0) scale(0.98);
  }
}

@keyframes joinOrbDriftSand {
  0% {
    transform: translate3d(-8%, 6%, 0) scale(0.94);
  }
  50% {
    transform: translate3d(4%, -3%, 0) scale(1.02);
  }
  100% {
    transform: translate3d(10%, 2%, 0) scale(0.98);
  }
}

@keyframes joinOrbDriftTeal {
  0% {
    transform: translate3d(6%, -8%, 0) scale(0.96);
  }
  50% {
    transform: translate3d(-4%, 4%, 0) scale(1.04);
  }
  100% {
    transform: translate3d(-10%, 10%, 0) scale(0.98);
  }
}

@keyframes joinOrbDriftSage {
  0% {
    transform: translate3d(0, 0, 0) scale(0.92);
  }
  50% {
    transform: translate3d(-10%, -6%, 0) scale(1.08);
  }
  100% {
    transform: translate3d(8%, 8%, 0) scale(0.96);
  }
}

@keyframes joinOrbDriftMist {
  0% {
    transform: translate3d(-2%, -8%, 0) scale(0.96);
  }
  50% {
    transform: translate3d(8%, 2%, 0) scale(1.04);
  }
  100% {
    transform: translate3d(-6%, 8%, 0) scale(0.98);
  }
}

@keyframes intelligenceOrbDrift {
  0% {
    transform: translate(30%, 12%) scale(0.94);
  }
  50% {
    transform: translate(52%, 18%) scale(1.06);
  }
  100% {
    transform: translate(68%, 36%) scale(0.98);
  }
}

@keyframes intelligenceGlowDrift {
  0% {
    opacity: 0.72;
    transform: translate3d(-2%, -1%, 0) scale(1);
  }
  50% {
    opacity: 0.92;
    transform: translate3d(2%, 1.5%, 0) scale(1.03);
  }
  100% {
    opacity: 0.76;
    transform: translate3d(-1%, 2%, 0) scale(0.99);
  }
}

@keyframes keywordStageReveal {
  0% {
    opacity: 0;
    transform: translateY(12px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
