:root {
  --ivory: #f6efe2;
  --ivory-2: #e8dac7;
  --ink: #101318;
  --muted: #60625d;
  --navy: #071019;
  --navy-2: #111d2a;
  --forest: #2f5c54;
  --amber: #c3823a;
  --red: #9f3e38;
  --stone: #b9aa94;
  --white: #fffaf1;
  --line: rgba(16, 19, 24, .16);
  --radius: 8px;
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 40px;
  --space-5: 72px;
  --space-6: 120px;
  color-scheme: light;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ivory);
  color: var(--ink);
}
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }

.opening {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 45%, rgba(255, 250, 241, .96), rgba(246, 239, 226, .96) 52%, #e7d9c4),
    var(--ivory);
  animation: opener-exit 1.1s cubic-bezier(.76, 0, .24, 1) 15.2s forwards;
}
.opening::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .12;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(16, 19, 24, .12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(16, 19, 24, .08) 1px, transparent 1px);
  background-size: 5px 5px, 7px 7px;
  mix-blend-mode: multiply;
}
.opening-wordmark {
  position: absolute;
  z-index: 4;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: clamp(18px, 4vw, 44px);
  width: min(780px, 92vw);
  color: rgba(16, 19, 24, .88);
  animation: wordmark-dim 1s ease 3s forwards;
}
.opening-word {
  display: inline-block;
  line-height: .9;
}
.opening-left {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(50px, 9vw, 112px);
  font-weight: 700;
  animation: opening-left 1.65s cubic-bezier(.76, 0, .24, 1) 1.05s forwards;
}
.opening-right {
  font-size: clamp(28px, 5vw, 62px);
  font-weight: 800;
  letter-spacing: 0;
  animation: opening-right 1.65s cubic-bezier(.76, 0, .24, 1) 1.05s forwards;
}
.opening-frame {
  position: relative;
  z-index: 2;
  width: min(760px, 86vw);
  aspect-ratio: 1200 / 720;
  opacity: 0;
  clip-path: inset(45% 46% 45% 46%);
  transform: scale(.42);
  animation:
    frame-arrive 1.7s cubic-bezier(.76, 0, .24, 1) 1.55s forwards,
    frame-zoom 3.35s cubic-bezier(.7, 0, .18, 1) 11.35s forwards;
}
.opening-frame::before,
.opening-frame::after {
  content: "";
  position: absolute;
  z-index: 5;
  width: 36px;
  height: 36px;
  border: solid var(--ink);
  opacity: .85;
}
.opening-frame::before {
  top: -8px;
  left: -8px;
  border-width: 3px 0 0 3px;
}
.opening-frame::after {
  right: -8px;
  bottom: -8px;
  border-width: 0 3px 3px 0;
}
.opening-frame .scene {
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 0;
}
.opening-frame .question-cloud .message-bubble {
  opacity: .7;
}
.opening-frame .question-cloud .bubble-float {
  scale: .68;
  transform-origin: 0 0;
}
.opening-frame .question-cloud .q1 {
  transform: translate(82px, 182px);
}
.opening-frame .question-cloud .q2 {
  transform: translate(868px, 142px);
}
.opening-frame .question-cloud .q3 {
  transform: translate(112px, 510px);
}
.opening-frame .question-cloud .q4 {
  transform: translate(828px, 500px);
}
.opening-frame .question-cloud .q5 {
  transform: translate(456px, 54px);
  opacity: .5;
}
.opening-lines,
.opening-final {
  position: absolute;
  z-index: 6;
  width: min(960px, 88vw);
  text-align: center;
  color: var(--white);
  pointer-events: none;
}
.opening-lines {
  top: 50%;
  left: 50%;
  height: clamp(96px, 12vw, 154px);
  transform: translate(-50%, -50%);
  text-shadow: 0 3px 34px rgba(7, 16, 25, .95), 0 1px 3px rgba(7, 16, 25, .9);
}
.opening-lines span {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  display: block;
  opacity: 0;
  transform: translateY(calc(-50% + 18px));
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(30px, 4.6vw, 66px);
  line-height: 1.02;
  text-wrap: balance;
  animation: opening-line 1.45s ease forwards;
}
.opening-lines span:nth-child(1) { animation-delay: 3.2s; }
.opening-lines span:nth-child(2) { animation-delay: 4.55s; }
.opening-lines span:nth-child(3) { animation-delay: 5.9s; }
.opening-lines span:nth-child(4) { animation-delay: 7.25s; }
.opening-lines span:nth-child(5) { animation-delay: 8.6s; }
.opening-lines span:nth-child(6) { animation-delay: 9.95s; }
.opening-final {
  top: 50%;
  left: 50%;
  display: grid;
  gap: 12px;
  opacity: 0;
  transform: translate(-50%, calc(-50% + 18px));
  animation: final-line 1.15s ease 11.65s forwards;
  text-shadow: 0 3px 36px rgba(7, 16, 25, .95), 0 1px 4px rgba(7, 16, 25, .9);
}
.opening-final span {
  color: rgba(255, 250, 241, .78);
  font-size: clamp(18px, 2vw, 25px);
}
.opening-final strong {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(42px, 6.6vw, 96px);
  font-weight: 400;
  line-height: .92;
  letter-spacing: 0;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 30;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding: 18px clamp(18px, 4vw, 62px);
  color: var(--white);
  background: linear-gradient(180deg, rgba(7, 16, 25, .72), rgba(7, 16, 25, 0));
  pointer-events: none;
}
.brand, nav, .actions, .button { display: flex; align-items: center; }
.brand, nav a { pointer-events: auto; }
.brand {
  gap: 10px;
  font-weight: 800;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 36px;
  height: 44px;
  background: var(--forest);
  color: var(--white);
  clip-path: polygon(0 0, 100% 0, 100% 82%, 50% 100%, 0 82%);
  font-size: 12px;
  letter-spacing: 0;
}
nav {
  gap: clamp(14px, 3vw, 34px);
  color: rgba(255, 250, 241, .78);
  font-size: 14px;
}

.hero-story {
  position: relative;
  min-height: 112vh;
  overflow: hidden;
  display: grid;
  align-items: end;
  padding: min(18vh, 150px) clamp(18px, 6vw, 84px) clamp(46px, 8vw, 92px);
  background: var(--navy);
  color: var(--white);
}
.hero-art,
.final-art {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-art .scene,
.final-art .scene {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
  border-radius: 0;
  transform: scale(calc(1.02 + var(--progress, 0) * .12));
}
.hero-shade {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 70% 45%, transparent, rgba(7, 16, 25, .62) 48%, rgba(7, 16, 25, .92)),
    linear-gradient(90deg, rgba(7, 16, 25, .95), rgba(7, 16, 25, .44) 52%, rgba(7, 16, 25, .8));
}
.hero-copy {
  position: relative;
  z-index: 4;
  max-width: 980px;
}
.kicker {
  margin: 0 0 14px;
  color: var(--amber);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .09em;
  text-transform: uppercase;
}
h1, h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 400;
  line-height: .94;
  letter-spacing: 0;
}
h1 { max-width: 1080px; font-size: clamp(54px, 9.8vw, 132px); }
h2 { max-width: 1040px; font-size: clamp(42px, 7.2vw, 94px); }
p {
  color: inherit;
  font-size: clamp(17px, 1.45vw, 21px);
  line-height: 1.55;
}
.hero-copy p:not(.kicker),
.story-copy > p,
.panorama-copy p,
.capability-copy p,
.final-copy > p:not(.final-pre) {
  max-width: 720px;
  color: color-mix(in srgb, currentColor 70%, transparent);
}
.actions {
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 34px;
}
.button {
  min-height: 48px;
  gap: 10px;
  padding: 13px 20px;
  border-radius: 999px;
  border: 1px solid currentColor;
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
}
.button.primary {
  background: var(--white);
  color: var(--ink);
  border-color: var(--white);
}
.button.ghost {
  color: var(--white);
  background: rgba(255, 250, 241, .08);
}
.icon {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.hero-question-stack {
  position: absolute;
  z-index: 3;
  inset: 0;
  pointer-events: none;
}
.hero-question-stack span,
.call-advocate-chip {
  position: absolute;
  display: block;
  border: 1px solid rgba(255, 250, 241, .32);
  border-radius: 999px;
  background: rgba(255, 250, 241, .09);
  color: rgba(255, 250, 241, .82);
  padding: 12px 18px;
  backdrop-filter: blur(10px);
  transform: translateY(calc((1 - var(--progress, 0)) * 28px));
  opacity: calc(.18 + var(--progress, 0) * .74);
}
.hero-question-stack span:nth-child(1) { left: 8vw; top: 26vh; }
.hero-question-stack span:nth-child(2) { right: 11vw; top: 22vh; }
.hero-question-stack span:nth-child(3) { right: 6vw; top: 48vh; }
.hero-question-stack span:nth-child(4) { left: 12vw; top: 62vh; }
.hero-question-stack span:nth-child(5) { left: 44vw; top: 17vh; }
.hero-question-stack span:nth-child(6) { right: 22vw; bottom: 18vh; }
.call-advocate-chip {
  right: clamp(22px, 8vw, 120px);
  bottom: clamp(30px, 7vw, 90px);
  z-index: 5;
  background: var(--forest);
  border-color: rgba(255, 250, 241, .18);
  color: var(--white);
  font-weight: 900;
  opacity: var(--progress, 0);
  transform: scale(calc(.84 + var(--progress, 0) * .16));
}

.story-section,
.panorama-section,
.capability-section,
.final-section {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  padding: clamp(74px, 10vw, 142px) clamp(18px, 6vw, 84px);
}
.story-section {
  display: grid;
  grid-template-columns: minmax(300px, .8fr) minmax(0, 1.2fr);
  gap: clamp(34px, 6vw, 92px);
  align-items: center;
}
.story-section.light,
.capability-section {
  background: var(--ivory);
  color: var(--ink);
}
.story-section.warm,
.panorama-section {
  background: linear-gradient(180deg, #f5ecde, #dfccb1);
  color: var(--ink);
}
.story-section.dark {
  background: radial-gradient(circle at 62% 40%, #22334a, var(--navy) 62%);
  color: var(--white);
}
.story-section.deep,
.final-section {
  background: var(--navy);
  color: var(--white);
}
.story-section.split {
  background: linear-gradient(90deg, #111821 0 50%, #efe4d4 50% 100%);
  color: var(--white);
}
.support-section .story-copy { color: var(--white); }
.story-copy {
  position: relative;
  z-index: 2;
  max-width: 720px;
}
.story-copy > *,
.panorama-copy > *,
.capability-copy > *,
.final-copy > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .7s ease, transform .7s ease;
}
.is-visible .story-copy > *,
.is-visible .panorama-copy > *,
.is-visible .capability-copy > *,
.is-visible .final-copy > * {
  opacity: 1;
  transform: translateY(0);
}
.story-visual {
  min-width: 0;
  transform: translateY(calc((.5 - var(--progress, .5)) * 34px));
}
.pressure-section {
  min-height: 86vh;
  grid-template-columns: minmax(300px, .92fr) minmax(0, 1.08fr);
  padding-top: clamp(62px, 7vw, 104px);
  padding-bottom: clamp(62px, 7vw, 104px);
}
.pressure-section .story-visual {
  justify-self: center;
  width: min(100%, 920px);
}
.pressure-section .scene {
  max-height: 520px;
  aspect-ratio: 16 / 9;
}
.scene {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1200 / 720;
  border: 1px solid rgba(16, 19, 24, .14);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--ivory-2);
}
.dark .scene,
.deep .scene {
  border-color: rgba(255, 250, 241, .14);
}

.panorama-section {
  display: grid;
  align-content: center;
  gap: 42px;
  min-height: 78vh;
  padding-top: clamp(52px, 6vw, 88px);
  padding-bottom: clamp(52px, 6vw, 88px);
}
.panorama-copy {
  position: relative;
  z-index: 3;
  max-width: 980px;
}
.panorama-window {
  position: relative;
  width: min(100%, 1040px);
  justify-self: center;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid rgba(16, 19, 24, .16);
  background: #111b25;
}
.panorama-track {
  width: 120%;
  transform: translateX(calc(var(--progress, 0) * -16%));
  transition: transform .08s linear;
}
.panorama-track .scene {
  width: 100%;
  aspect-ratio: 1600 / 510;
  border: 0;
  border-radius: 0;
}
.situation-caption {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 18px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--white);
  font-size: 13px;
}
.situation-caption span {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(7, 16, 25, .62);
  backdrop-filter: blur(12px);
}

.quick-flow,
.status-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  max-width: 680px;
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}
.quick-flow li,
.status-list li,
.trust-points span,
.prompt-strip span {
  border: 1px solid color-mix(in srgb, currentColor 20%, transparent);
  border-radius: 999px;
  padding: 10px 14px;
  color: color-mix(in srgb, currentColor 78%, transparent);
  background: color-mix(in srgb, currentColor 8%, transparent);
}
.prompt-strip,
.trust-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.capability-section {
  display: grid;
  grid-template-columns: minmax(300px, .8fr) minmax(0, 1.2fr);
  gap: clamp(34px, 6vw, 90px);
  align-items: center;
}
.capability-stage {
  position: relative;
}
.capability-stage ol {
  position: absolute;
  right: 18px;
  top: 18px;
  bottom: 18px;
  display: grid;
  align-content: center;
  gap: 12px;
  width: min(330px, 42%);
  margin: 0;
  padding: 0;
  list-style: none;
}
.capability-stage li {
  display: grid;
  gap: 4px;
  padding: 14px;
  border-radius: var(--radius);
  background: rgba(255, 250, 241, .86);
  border: 1px solid rgba(16, 19, 24, .14);
}
.capability-stage li strong {
  color: var(--forest);
}
.capability-stage li span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.final-section {
  min-height: 112vh;
  display: grid;
  align-items: center;
}
.final-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 68% 44%, rgba(7, 16, 25, .08), rgba(7, 16, 25, .76) 52%, rgba(7, 16, 25, .96)),
    linear-gradient(90deg, rgba(7, 16, 25, .95), rgba(7, 16, 25, .34));
}
.final-copy {
  position: relative;
  z-index: 2;
  max-width: 960px;
}
.final-pre {
  color: rgba(255, 250, 241, .76);
  font-size: clamp(22px, 3vw, 36px);
}
.waitlist-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 280px));
  gap: 12px;
  margin-top: 34px;
  max-width: 720px;
}
.waitlist-form label {
  display: grid;
  gap: 6px;
  color: rgba(255, 250, 241, .78);
  font-size: 13px;
  font-weight: 800;
}
.waitlist-form input,
.waitlist-form select {
  width: 100%;
  min-height: 48px;
  padding: 0 14px;
  border-radius: var(--radius);
  border: 1px solid rgba(255, 250, 241, .26);
  background: rgba(255, 250, 241, .1);
  color: var(--white);
}
.waitlist-form option { color: var(--ink); }
.waitlist-form .consent {
  grid-column: 1 / -1;
  grid-template-columns: 18px 1fr;
  align-items: start;
  font-weight: 600;
  line-height: 1.35;
}
.consent input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}
.waitlist-form button {
  width: fit-content;
}
.form-result {
  grid-column: 1 / -1;
  margin: 0;
  color: rgba(255, 250, 241, .84);
  font-size: 15px;
}
.footer {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 30px clamp(18px, 6vw, 84px);
  background: #070b10;
  color: rgba(255, 250, 241, .62);
  font-size: 13px;
}
.footer p { margin: 0; font-size: 13px; }

/* SVG language */
.texture { filter: url(#ordinary-evening-interrupted-by-a-station-message-grain); opacity: .45; }
.city-layer path,
.city-layer rect { fill: rgba(255, 250, 241, .08); stroke: rgba(255, 250, 241, .12); stroke-width: 2; }
.warm-sky, .day-sky { fill: rgba(195, 130, 58, .22); }
.road-perspective, .long-road, .city-road, .quiet-road { fill: rgba(14, 20, 27, .58); }
.light-cone { fill: url(#ordinary-evening-interrupted-by-a-station-message-lamp); opacity: .54; }
.street-lights path { fill: none; stroke: rgba(255, 250, 241, .34); stroke-width: 5; }
.street-lights circle { fill: rgba(255, 216, 137, .38); }
.human circle,
.human path,
.advocate circle,
.advocate path { fill: #080d13; }
.human.hero-human circle,
.human.hero-human path,
.human.pressure-human circle,
.human.pressure-human path { fill: #05080d; }
.human.supported-person circle,
.human.supported-person path,
.human.calm-person circle,
.human.calm-person path { fill: var(--forest); }
.advocate .advocate-band { fill: rgba(255, 250, 241, .24); }
.phone-shell > rect:first-child,
.held-phone-large rect:first-child { fill: #070b10; }
.phone-screen,
.held-phone-large rect:last-child { fill: #f2d08a; }
.phone-speaker, .phone-dot { fill: rgba(255, 250, 241, .65); }
.message-card rect,
.message-bubble rect {
  fill: rgba(255, 250, 241, .92);
  stroke: rgba(16, 19, 24, .16);
  stroke-width: 2;
}
.message-card path,
.message-bubble path { fill: rgba(255, 250, 241, .92); }
.message-card text {
  fill: var(--ink);
  font: 900 22px Inter, sans-serif;
}
.message-card.urgent rect { fill: #fff4df; }
.message-pulse {
  fill: none !important;
  stroke: var(--red);
  stroke-width: 5;
  stroke-linecap: round;
  animation: pulse-stroke 1.8s infinite ease;
}
.message-bubble text {
  fill: var(--ink);
  font: 800 22px Inter, sans-serif;
}
.question-cloud .bubble-float {
  animation: drift 5.2s infinite ease-in-out;
}
.question-cloud .q2 .bubble-float,
.question-cloud .q4 .bubble-float { animation-delay: .7s; }
.doc path:first-child {
  fill: url(#document-review-during-live-support-paper);
  stroke: rgba(16, 19, 24, .7);
  stroke-width: 3;
}
.doc path:not(:first-child) {
  fill: none;
  stroke: rgba(16, 19, 24, .62);
  stroke-width: 3;
  stroke-linecap: round;
}
.station-env rect,
.station-env path,
.hostel rect,
.hostel path,
.shop rect,
.shop path,
.car-scene path {
  fill: rgba(255, 250, 241, .1);
  stroke: rgba(255, 250, 241, .36);
  stroke-width: 4;
}
.car-scene circle { fill: #0b1118; stroke: rgba(255, 250, 241, .36); stroke-width: 4; }
.pressure-floor { fill: rgba(0, 0, 0, .44); }
.pressure-item,
.pressure-note {
  animation: pressure-pulse 5.6s ease-in-out infinite alternate;
}
.item-b, .item-e, .item-g { animation-delay: .5s; }
.item-c, .item-h { animation-delay: .9s; }
.clock circle,
.unlock rect {
  fill: rgba(255, 250, 241, .1);
  stroke: rgba(255, 250, 241, .44);
  stroke-width: 4;
}
.clock path,
.unlock path {
  fill: none;
  stroke: rgba(255, 250, 241, .72);
  stroke-width: 5;
  stroke-linecap: round;
}
.closing-ring {
  fill: none;
  stroke: rgba(159, 62, 56, .52);
  stroke-width: 3;
  stroke-dasharray: 12 18;
}
.relief-field { fill: rgba(47, 92, 84, .18); }
.app-button rect { fill: var(--forest); }
.app-button circle,
.app-button path { fill: none; stroke: var(--white); stroke-width: 5; stroke-linecap: round; }
.request-steps path,
.route-line,
.connect-route,
.active-route {
  fill: none;
  stroke: var(--amber);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: draw 3s ease forwards;
}
.request-steps circle { fill: var(--forest); }
.video-ambient { fill: rgba(47, 92, 84, .18); }
.video-device {
  fill: rgba(255, 250, 241, .055);
  stroke: rgba(255, 250, 241, .5);
  stroke-width: 2.5;
}
.video-pane {
  fill: rgba(8, 17, 29, .72);
  stroke: rgba(255, 250, 241, .2);
  stroke-width: 2;
}
.user-pane { fill: rgba(12, 22, 34, .78); }
.advocate-pane { fill: rgba(255, 250, 241, .075); }
.video-split {
  fill: none;
  stroke: rgba(255, 250, 241, .22);
  stroke-width: 2;
}
.station-light { fill: rgba(242, 208, 138, .08); }
.waiting-bench rect,
.call-context rect,
.live-chip rect {
  fill: rgba(255, 250, 241, .12);
  stroke: rgba(255, 250, 241, .22);
  stroke-width: 2;
}
.waiting-bench path,
.station-corridor path,
.live-chip path,
.call-context path {
  fill: none;
  stroke: rgba(255, 250, 241, .4);
  stroke-width: 3;
  stroke-linecap: round;
}
.station-corridor path:first-child {
  fill: rgba(255, 250, 241, .035);
  stroke: rgba(255, 250, 241, .12);
}
.distant-station rect,
.distant-station path {
  fill: rgba(255, 250, 241, .16);
  stroke: rgba(255, 250, 241, .5);
}
.human.video-user circle,
.human.video-user path {
  fill: #03070c;
  stroke: rgba(255, 250, 241, .16);
  stroke-width: 2;
}
.advocate.calm-advocate circle,
.advocate.calm-advocate path:not(.advocate-band) {
  fill: #071019;
  stroke: rgba(255, 250, 241, .18);
  stroke-width: 2;
}
.advocate.calm-advocate .advocate-band {
  fill: rgba(242, 208, 138, .38);
  stroke: rgba(255, 250, 241, .34);
  stroke-width: 2;
}
.live-chip circle,
.call-context circle { fill: var(--forest); }
.user-phone-glow rect:first-child { fill: #05090e; }
.user-phone-glow rect:last-child {
  fill: var(--amber);
  filter: drop-shadow(0 0 18px rgba(242, 208, 138, .38));
}
.advocate-halo { fill: rgba(47, 92, 84, .2); }
.advocate-desk path:first-child {
  fill: rgba(255, 250, 241, .1);
  stroke: rgba(255, 250, 241, .22);
  stroke-width: 2;
}
.advocate-desk path:not(:first-child),
.advocate-prompt path,
.review-mark,
.next-steps path {
  fill: none;
  stroke: rgba(255, 250, 241, .58);
  stroke-width: 4;
  stroke-linecap: round;
}
.advocate-prompt rect,
.shared-document rect,
.next-steps rect {
  fill: rgba(255, 250, 241, .12);
  stroke: rgba(255, 250, 241, .24);
  stroke-width: 2;
}
.shared-document rect {
  fill: rgba(7, 16, 25, .82);
  stroke: rgba(242, 208, 138, .42);
}
.shared-document {
  filter: drop-shadow(0 18px 34px rgba(0, 0, 0, .35));
}
.shared-document .active-doc path:first-child {
  fill: #fff0cf;
  stroke: rgba(255, 250, 241, .9);
}
.call-connection {
  fill: none;
  stroke: var(--amber);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-dasharray: 12 14;
  animation: draw 2.4s ease forwards;
}
.call-controls circle {
  fill: rgba(255, 250, 241, .14);
  stroke: rgba(255, 250, 241, .34);
  stroke-width: 2;
}
.call-controls .end { fill: var(--red); }
.call-controls path {
  fill: none;
  stroke: rgba(255, 250, 241, .82);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.next-steps circle { fill: var(--forest); }
.review-table { fill: rgba(47, 92, 84, .14); }
.review-focus rect { fill: rgba(47, 92, 84, .18); stroke: var(--forest); stroke-width: 3; }
.review-focus path { stroke: var(--forest); stroke-width: 6; stroke-linecap: round; }
.review-focus circle { fill: var(--forest); }
.split-line { stroke: rgba(255, 250, 241, .4); stroke-width: 4; }
.service-zone {
  fill: rgba(47, 92, 84, .22);
  stroke: rgba(255, 250, 241, .34);
  stroke-width: 3;
}
.map-grid path { fill: none; stroke: rgba(255, 250, 241, .14); stroke-width: 2; }
.location-marker path { fill: var(--amber); }
.location-marker circle { fill: var(--white); }
.location-marker.advocate-pin path,
.location-marker.city-pin path { fill: var(--forest); }
.timeline-panel rect { fill: rgba(255, 250, 241, .78); stroke: rgba(16, 19, 24, .12); stroke-width: 3; }
.timeline-panel > path { stroke: rgba(16, 19, 24, .18); stroke-width: 5; }
.timeline-node { opacity: 0; animation: node-in .55s ease forwards; }
.timeline-node.n2 { animation-delay: .12s; }
.timeline-node.n3 { animation-delay: .24s; }
.timeline-node.n4 { animation-delay: .36s; }
.timeline-node.n5 { animation-delay: .48s; }
.timeline-node.n6 { animation-delay: .6s; }
.timeline-node.n7 { animation-delay: .72s; }
.timeline-node circle { fill: var(--forest); }
.timeline-node text { fill: var(--ink); font: 800 20px Inter, sans-serif; }
.trust-orbit circle {
  fill: none;
  stroke: rgba(255, 250, 241, .18);
  stroke-width: 3;
}
.trust-orbit > path {
  fill: none;
  stroke: rgba(195, 130, 58, .45);
  stroke-width: 4;
  stroke-dasharray: 10 14;
}
.trust-orbit > circle:nth-of-type(n+3) { fill: var(--forest); stroke: rgba(255, 250, 241, .24); }
.calm-ring { fill: none; stroke: rgba(255, 250, 241, .36); stroke-width: 4; stroke-linecap: round; }

@keyframes opening-left {
  to { transform: translateX(clamp(-240px, -24vw, -120px)); }
}
@keyframes opening-right {
  to { transform: translateX(clamp(120px, 24vw, 240px)); }
}
@keyframes wordmark-dim {
  to { opacity: 0; transform: scale(.94); }
}
@keyframes frame-arrive {
  0% { opacity: 0; transform: scale(.42); clip-path: inset(48% 48% 48% 48%); }
  45% { opacity: 1; }
  100% { opacity: 1; transform: scale(1); clip-path: inset(0 0 0 0); }
}
@keyframes opening-line {
  0% { opacity: 0; transform: translateY(calc(-50% + 18px)); }
  18%, 76% { opacity: 1; transform: translateY(-50%); }
  100% { opacity: 0; transform: translateY(calc(-50% - 18px)); }
}
@keyframes frame-zoom {
  0% { opacity: 1; transform: scale(1); }
  70% { opacity: 1; transform: scale(2.45); }
  100% { opacity: 1; transform: scale(8.6); }
}
@keyframes final-line {
  to { opacity: 1; transform: translate(-50%, -50%); }
}
@keyframes opener-exit {
  to { opacity: 0; visibility: hidden; pointer-events: none; }
}
@keyframes drift {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-14px); }
}
@keyframes pulse-stroke {
  0%, 100% { opacity: .35; }
  50% { opacity: 1; }
}
@keyframes pressure-pulse {
  to { opacity: .72; }
}
@keyframes draw { to { stroke-dashoffset: 0; } }
@keyframes node-in {
  from { opacity: 0; transform: translateX(-14px); }
  to { opacity: 1; transform: translateX(0); }
}

@media (max-width: 1060px) {
  .story-section,
  .capability-section {
    grid-template-columns: 1fr;
  }
  .story-section.split {
    background: linear-gradient(180deg, #111821 0 52%, #efe4d4 52% 100%);
  }
}
@media (max-width: 720px) {
  .site-header {
    position: absolute;
    padding: 16px;
  }
  nav { display: none; }
  .hero-story,
  .story-section,
  .panorama-section,
  .capability-section,
  .final-section {
    min-height: auto;
    padding: 92px 16px 58px;
  }
  h1 { font-size: clamp(48px, 15vw, 72px); }
  h2 { font-size: clamp(38px, 13vw, 58px); }
  .hero-question-stack { display: none; }
  .call-advocate-chip {
    position: relative;
    right: auto;
    bottom: auto;
    width: fit-content;
    margin-top: 24px;
    opacity: 1;
  }
  .panorama-track {
    width: 220%;
    transform: translateX(calc(var(--progress, 0) * -54%));
  }
  .situation-caption {
    position: static;
    display: grid;
    padding: 12px;
    background: #111b25;
  }
  .quick-flow,
  .status-list,
  .waitlist-form {
    grid-template-columns: 1fr;
  }
  .capability-stage ol {
    position: static;
    width: auto;
    margin-top: 12px;
  }
  .waitlist-form button { width: 100%; justify-content: center; }
  .footer { flex-direction: column; }
  .opening-frame { width: 86vw; }
  .opening-lines {
    top: 65%;
    height: 112px;
    color: var(--ink);
    text-shadow: none;
  }
  .opening-lines span {
    font-size: clamp(28px, 9vw, 42px);
    line-height: 1.04;
  }
  .opening-final {
    width: 92vw;
  }
  .opening-final strong {
    font-size: clamp(38px, 11vw, 58px);
  }
  .opening-left { animation-name: opening-left-mobile; }
  .opening-right { animation-name: opening-right-mobile; }
}
@keyframes opening-left-mobile {
  to { transform: translateX(-84px); }
}
@keyframes opening-right-mobile {
  to { transform: translateX(84px); }
}
@media (prefers-reduced-motion: reduce) {
  .opening { display: none; }
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}
