:root {
  color-scheme: dark;
  --bg: #030303;
  --ink: #f8f2e8;
  --muted: rgba(248, 242, 232, 0.66);
  --line: rgba(248, 242, 232, 0.15);
  --warm: #f5d8a7;
  --cyan: #9bdfff;
  --rose: #ffb79d;
  --scroll: 0;
  --hero-progress: 0;
  --space-warp: 0;
  --planet-opacity: 1;
  --mouse-x: 0;
  --mouse-y: 0;
  --signature-opacity: 0;
  --signature-y: 74vh;
  --signature-scale: 0.86;
  --signature-mask-offset: 1;
  --signature-flourish-offset: 1;
  --signature-flourish-opacity: 0;
  --signature-fill: 0;
  --signature-glow: 0;
  --robot-x: 67vw;
  --robot-y: 50vh;
  --robot-scale: 1;
  --robot-tilt: 0deg;
  --robot-flight: 0;
  --trail-x: 50vw;
  --trail-y: 50vh;
  --trail-angle: 0deg;
  --trail-opacity: 0;
  --beam-x: 50vw;
  --beam-y: 50vh;
  --beam-length: 0px;
  --beam-angle: 0deg;
  --beam-opacity: 0;
  --scan-x: 50vw;
  --scan-y: 50vh;
  --scan-size: 120px;
  --scan-opacity: 0;
  --cursor-x: 50vw;
  --cursor-y: 50vh;
  --cursor-opacity: 0;
  --cursor-lock: 0;
  --foreground-opacity: 1;
  --portrait-particles-opacity: 0.52;
  --hero-dim: 0;
}

/* Global world layer: the starship portrait is now the site's continuous base scene. */
.world-backdrop {
  position: fixed;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100svh;
  object-fit: cover;
  object-position: center;
  pointer-events: none;
  opacity: calc(0.08 + var(--hero-progress) * 0.26);
  filter: saturate(0.76) contrast(1.08) brightness(0.58);
  transform:
    translate3d(
      calc(var(--mouse-x) * -5px),
      calc(var(--mouse-y) * -3px),
      0
    )
    scale(1.035);
  transform-origin: center;
}

.hero-image {
  z-index: 1;
}

.hero::before,
.hero::after,
.space-depth {
  z-index: 3;
}

.section-about,
.section-thinking,
.section-ai,
.section-contact {
  background: transparent !important;
  isolation: isolate;
}

.section-thinking::before,
.section-ai::before,
.section-contact::before {
  opacity: 0.34 !important;
  mix-blend-mode: screen;
}

.section-thinking::after,
.section-ai::after,
.section-contact::after {
  opacity: 1 !important;
  background:
    radial-gradient(ellipse 54% 58% at 50% 50%, rgba(1, 3, 6, 0.18), rgba(1, 3, 6, 0.54) 68%, rgba(1, 3, 6, 0.84) 100%),
    linear-gradient(90deg, rgba(1, 3, 6, 0.72), rgba(1, 3, 6, 0.32) 28%, rgba(1, 3, 6, 0.44) 70%, rgba(1, 3, 6, 0.76));
  mix-blend-mode: normal;
}

.section-thinking::after {
  background:
    radial-gradient(circle at var(--project-focus-x, 50%) var(--project-focus-y, 52%), rgba(1, 3, 6, 0.18), rgba(1, 3, 6, 0.46) 48%, rgba(1, 3, 6, 0.78) 84%),
    linear-gradient(180deg, rgba(1, 3, 6, 0.54), rgba(1, 3, 6, 0.32) 42%, rgba(1, 3, 6, 0.76));
}

.section-ai::after {
  background:
    radial-gradient(ellipse 46% 58% at 50% 52%, rgba(155, 223, 255, 0.035), rgba(1, 3, 6, 0.46) 58%, rgba(1, 3, 6, 0.84) 100%),
    linear-gradient(90deg, rgba(1, 3, 6, 0.76), rgba(1, 3, 6, 0.36) 34%, rgba(1, 3, 6, 0.44) 66%, rgba(1, 3, 6, 0.78));
}

.contact-minimal::after {
  background:
    radial-gradient(ellipse 34% 56% at 50% 52%, rgba(1, 2, 4, 0.12), rgba(1, 2, 4, 0.5) 76%, rgba(1, 2, 4, 0.78)),
    linear-gradient(90deg, rgba(1, 2, 4, 0.38), rgba(1, 2, 4, 0.2) 28%, rgba(1, 2, 4, 0.44) 64%, rgba(1, 2, 4, 0.7));
}

.contact-minimal .contact-hero-backdrop {
  display: none;
}

/* Confirmed direction: #thinking as one cinematic black-hole project field. */
.section-thinking {
  --project-focus-x: 50%;
  --project-focus-y: 52%;
  align-content: center;
  justify-items: center;
  min-height: 100svh;
  padding: clamp(44px, 4.6vw, 72px) clamp(18px, 5vw, 78px);
  overflow: hidden;
  background:
    radial-gradient(circle at var(--project-focus-x) var(--project-focus-y), rgba(255, 237, 202, 0.09), transparent 290px),
    radial-gradient(ellipse 76% 52% at 50% 48%, rgba(255, 255, 255, 0.04), transparent 64%),
    linear-gradient(180deg, rgba(5, 8, 11, 0.96), rgba(1, 2, 4, 1) 78%);
}

.section-thinking::before {
  opacity: 0.72;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.8) 0 0.7px, transparent 1.6px),
    radial-gradient(circle, rgba(155, 223, 255, 0.5) 0 0.55px, transparent 1.4px),
    linear-gradient(112deg, transparent 0 20%, rgba(255, 255, 255, 0.22) 20.1% 20.25%, transparent 20.7%),
    linear-gradient(68deg, transparent 0 69%, rgba(255, 255, 255, 0.16) 69.08% 69.2%, transparent 69.8%);
  background-size: 38px 38px, 76px 76px, 100% 100%, 100% 100%;
  background-position: 0 0, 19px 17px, 0 0, 0 0;
  mask-image: radial-gradient(ellipse 70% 58% at 50% 48%, #000 0 62%, transparent 100%);
}

.section-thinking::after {
  opacity: 0.86;
  background:
    radial-gradient(ellipse 86% 64% at 50% 53%, transparent 0 54%, rgba(0, 0, 0, 0.62) 78%, rgba(0, 0, 0, 0.94) 100%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.62), transparent 26% 74%, rgba(0, 0, 0, 0.62));
  mix-blend-mode: normal;
}

.blackhole-archive {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  justify-items: center;
  align-content: center;
  gap: clamp(10px, 1.2vw, 16px);
  width: min(1280px, 92vw);
  min-height: min(780px, calc(100svh - 80px));
}

.thinking-copy {
  position: relative;
  z-index: 5;
  display: grid;
  justify-items: center;
  gap: 8px;
  text-align: center;
}

.thinking-copy .section-kicker {
  color: rgba(248, 242, 232, 0.72);
  letter-spacing: 0;
}

.thinking-copy h2 {
  max-width: min(980px, 82vw);
  margin: 0;
  color: rgba(250, 246, 236, 0.98);
  font-size: clamp(58px, 7.3vw, 112px);
  line-height: 0.84;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
  text-shadow:
    0 22px 48px rgba(0, 0, 0, 0.76),
    0 0 34px rgba(255, 244, 220, 0.16);
}

.section-thinking .project-archive-status {
  z-index: 6;
  grid-template-columns: minmax(92px, auto) minmax(0, 1fr) auto;
  grid-template-areas:
    "index title state"
    "index body state";
  width: min(1040px, 82vw);
  min-height: 62px;
  margin: 0;
  padding: 11px 16px;
  border-color: rgba(255, 244, 220, 0.24);
  background:
    linear-gradient(90deg, rgba(255, 247, 229, 0.11), rgba(255, 203, 154, 0.055), rgba(155, 223, 255, 0.035)),
    rgba(3, 5, 8, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 22px 70px rgba(0, 0, 0, 0.34),
    0 0 44px rgba(255, 244, 220, 0.08);
}

.section-thinking .project-archive-status::before {
  background: linear-gradient(90deg, rgba(255, 255, 248, 0.82), rgba(255, 198, 145, 0.34), transparent);
}

.section-thinking .project-archive-status::after {
  background: linear-gradient(90deg, transparent, rgba(255, 244, 220, 0.2), transparent);
}

.section-thinking .project-archive-status span,
.section-thinking .project-archive-status em {
  color: rgba(180, 224, 245, 0.9);
  letter-spacing: 0;
}

.section-thinking .project-archive-status strong {
  color: rgba(255, 249, 238, 0.98);
}

.section-thinking .project-archive-status p {
  color: rgba(248, 242, 232, 0.66);
}

.section-thinking .project-event-field {
  position: relative;
  width: min(1180px, 88vw);
  height: clamp(430px, 45vw, 560px);
  margin-top: clamp(-24px, -1.6vw, -12px);
}

.project-black-hole {
  position: absolute;
  left: 50%;
  top: 48%;
  width: min(1120px, 96vw);
  height: min(520px, 46vw);
  pointer-events: none;
  transform: translate(-50%, -50%);
  filter:
    drop-shadow(0 0 34px rgba(255, 244, 220, 0.16))
    drop-shadow(0 0 74px rgba(0, 0, 0, 0.86));
}

.project-black-hole::before,
.project-black-hole::after,
.project-black-hole i {
  position: absolute;
  content: "";
  pointer-events: none;
}

.project-black-hole::before {
  left: -8%;
  right: -8%;
  top: 48%;
  height: 24%;
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent 0 4%, rgba(63, 37, 28, 0.34) 10%, rgba(255, 192, 128, 0.7) 25%, rgba(255, 255, 245, 0.98) 41%, rgba(255, 251, 230, 0.94) 52%, rgba(192, 111, 65, 0.46) 70%, rgba(25, 17, 16, 0.86) 88%, transparent 100%),
    radial-gradient(ellipse at center, rgba(255, 255, 252, 0.95) 0 16%, rgba(255, 207, 151, 0.38) 36%, transparent 72%);
  filter: blur(0.6px);
  transform: translateY(-50%) rotate(-1.6deg) scaleY(0.62);
}

.project-black-hole::after {
  left: 0;
  right: 0;
  top: 54%;
  height: 31%;
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.42) 17%, rgba(0, 0, 0, 0.9) 48% 58%, rgba(0, 0, 0, 0.62) 76%, transparent),
    radial-gradient(ellipse at center, rgba(35, 24, 20, 0.64), transparent 68%);
  filter: blur(10px);
  transform: translateY(-50%) rotate(-1.8deg) scaleY(0.34);
}

.event-horizon {
  left: 50%;
  top: 51%;
  z-index: 5;
  width: clamp(158px, 17vw, 244px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 48% 44%, rgba(255, 255, 255, 0.04), transparent 0 16%),
    radial-gradient(circle, #020202 0 58%, rgba(0, 0, 0, 0.98) 62%, rgba(15, 14, 15, 0.94) 68%, transparent 72%);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.96),
    0 0 46px rgba(0, 0, 0, 0.96),
    0 0 82px rgba(255, 244, 220, 0.16);
  transform: translate(-50%, -50%);
}

.gravity-lens {
  left: 50%;
  top: 47%;
  z-index: 2;
  width: clamp(360px, 42vw, 610px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, transparent 0 42%, rgba(255, 255, 247, 0.72) 46%, rgba(255, 212, 166, 0.32) 52%, transparent 62%),
    conic-gradient(from 196deg, transparent 0 18%, rgba(255, 255, 248, 0.55), rgba(255, 214, 170, 0.24), transparent 44% 100%);
  filter: blur(6px);
  opacity: 0.82;
  transform: translate(-50%, -50%) rotate(-4deg) scaleY(0.72);
}

.accretion {
  left: 50%;
  top: 49%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.accretion-front {
  z-index: 6;
  width: min(1160px, 100vw);
  height: clamp(72px, 8vw, 116px);
  background:
    linear-gradient(90deg, transparent 0 8%, rgba(255, 188, 126, 0.44) 20%, rgba(255, 255, 244, 0.98) 38%, rgba(255, 251, 232, 0.92) 50%, rgba(159, 82, 48, 0.42) 67%, rgba(13, 11, 12, 0.88) 86%, transparent 100%);
  filter: blur(1px);
  opacity: 0.95;
  transform: translate(-50%, -50%) rotate(-1.8deg) scaleY(0.38);
}

.accretion-back {
  z-index: 1;
  width: clamp(430px, 52vw, 760px);
  height: clamp(240px, 27vw, 380px);
  background:
    radial-gradient(ellipse at center, transparent 0 43%, rgba(255, 255, 246, 0.72) 46%, rgba(255, 202, 154, 0.26) 53%, transparent 66%);
  filter: blur(4px);
  opacity: 0.76;
  transform: translate(-50%, -62%) rotate(-4deg) scaleY(0.72);
}

.particle-stream {
  z-index: 7;
  width: 52%;
  height: 30%;
  opacity: 0.7;
  background:
    repeating-linear-gradient(100deg, transparent 0 14px, rgba(255, 255, 255, 0.34) 15px 17px, transparent 18px 72px);
  filter: blur(0.4px);
}

.stream-one {
  right: -3%;
  top: 10%;
  transform: rotate(-13deg);
  mask-image: linear-gradient(90deg, transparent, #000 18%, transparent 92%);
}

.stream-two {
  left: -5%;
  bottom: 10%;
  transform: rotate(12deg);
  opacity: 0.36;
  mask-image: linear-gradient(90deg, transparent, #000 24%, transparent 88%);
}

.section-thinking .signal-list {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  max-width: none;
  margin: 0;
  pointer-events: none;
}

.section-thinking .signal-list::before,
.section-thinking .signal-list::after {
  display: none;
}

.section-thinking .signal-list article {
  --project-card-wake: 0;
  position: absolute;
  z-index: 8;
  display: grid;
  gap: 6px;
  width: clamp(178px, 17vw, 238px);
  min-height: 0;
  padding: 11px 13px;
  pointer-events: auto;
  border: 1px solid rgba(255, 244, 220, 0.16);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.08), rgba(155, 223, 255, 0.04)),
    rgba(3, 5, 8, 0.46);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(12px);
  cursor: pointer;
  transform: translateY(calc(var(--project-card-wake) * -4px));
}

.section-thinking .signal-list article:first-child {
  grid-row: auto;
  min-height: 0;
  padding: 11px 13px;
  border-color: rgba(255, 244, 220, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.08), rgba(155, 223, 255, 0.04)),
    rgba(3, 5, 8, 0.46);
}

.section-thinking .signal-list article::before {
  left: 12px;
  top: 12px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 244, 220, 0.9);
  box-shadow:
    0 0 14px rgba(255, 244, 220, 0.48),
    0 0 24px rgba(255, 178, 113, 0.24);
  opacity: 0.86;
  transform: none;
}

.section-thinking .signal-list article::after {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: -1px;
  height: 1px;
  border-radius: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 244, 220, 0.58), rgba(155, 223, 255, 0.18), transparent);
  opacity: calc(0.2 + var(--project-card-wake) * 0.62);
  mix-blend-mode: screen;
}

.section-thinking .signal-list span {
  display: block;
  padding-left: 16px;
  color: rgba(180, 224, 245, 0.9);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.section-thinking .signal-list h3 {
  margin: 0;
  color: rgba(255, 249, 238, 0.97);
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.06;
}

.section-thinking .signal-list article:first-child h3 {
  max-width: none;
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.06;
}

.section-thinking .signal-list p {
  margin: 0;
  color: rgba(248, 242, 232, 0.66);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
}

.section-thinking .signal-list article:first-child p {
  max-width: none;
  color: rgba(248, 242, 232, 0.66);
}

.project-node-one {
  left: 2%;
  top: 58%;
}

.project-node-two {
  left: 10%;
  top: 19%;
}

.project-node-three {
  right: 5%;
  top: 19%;
}

.project-node-four {
  left: 18%;
  bottom: 5%;
}

.project-node-five {
  right: 15%;
  bottom: 6%;
}

.section-thinking .signal-list article:hover,
.section-thinking .signal-list article.is-active {
  --project-card-wake: 1;
  border-color: rgba(255, 244, 220, 0.54);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.14), rgba(255, 189, 132, 0.05), rgba(155, 223, 255, 0.06)),
    rgba(5, 7, 10, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 0 34px rgba(255, 244, 220, 0.13),
    0 20px 54px rgba(0, 0, 0, 0.42);
}

.section-thinking .signal-list article:focus-visible {
  outline: 1px solid rgba(255, 244, 220, 0.72);
  outline-offset: 4px;
}

@media (max-width: 980px) {
  .blackhole-archive {
    width: 100%;
    min-height: auto;
  }

  .section-thinking .project-archive-status {
    width: 100%;
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "index"
      "title"
      "body"
      "state";
    gap: 8px;
  }

  .section-thinking .project-archive-status p {
    white-space: normal;
  }

  .section-thinking .project-archive-status em {
    justify-self: start;
  }

  .section-thinking .project-event-field {
    width: 100%;
    height: auto;
    min-height: 0;
    padding-top: clamp(360px, 56vw, 480px);
  }

  .project-black-hole {
    top: clamp(170px, 28vw, 235px);
    width: min(980px, 118vw);
    height: clamp(330px, 54vw, 470px);
  }

  .section-thinking .signal-list {
    position: relative;
    display: grid;
    gap: 12px;
    pointer-events: auto;
  }

  .section-thinking .signal-list article {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    min-height: 0;
  }
}

@media (max-width: 760px) {
  .section-thinking {
    padding: 72px 20px;
  }

  .thinking-copy h2 {
    font-size: clamp(42px, 15vw, 62px);
    line-height: 0.92;
  }

  .section-thinking .project-event-field {
    padding-top: 300px;
  }

  .project-black-hole {
    top: 142px;
    width: 690px;
    max-width: none;
    height: 330px;
  }

  .event-horizon {
    width: 134px;
  }

  .gravity-lens {
    width: 330px;
  }

  .section-thinking .signal-list article {
    padding: 14px 16px;
  }
}

.section-thinking .signal-list article:first-child {
  grid-row: auto;
  min-height: 0;
  padding: 11px 13px;
  border-color: rgba(255, 244, 220, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.08), rgba(155, 223, 255, 0.04)),
    rgba(3, 5, 8, 0.46);
}

.section-thinking .signal-list article:first-child h3 {
  max-width: none;
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.06;
}

.section-thinking .signal-list article:first-child p {
  max-width: none;
  color: rgba(248, 242, 232, 0.66);
}

@media (max-width: 760px) {
  .section-thinking .signal-list article:first-child {
    padding: 14px 16px;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: hidden;
  background: var(--bg);
  color: var(--ink);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    "Microsoft YaHei", sans-serif;
}

body::selection {
  background: rgba(155, 223, 255, 0.28);
}

button {
  font: inherit;
}

.space-webgl {
  position: fixed;
  inset: 0;
  z-index: 6;
  width: 100%;
  height: 100svh;
  pointer-events: none;
  mix-blend-mode: screen;
}

.space-cursor {
  position: fixed;
  left: var(--cursor-x);
  top: var(--cursor-y);
  z-index: 42;
  width: calc(28px + var(--cursor-lock) * 10px);
  height: calc(28px + var(--cursor-lock) * 10px);
  border: 1px solid rgba(248, 242, 232, calc(0.32 + var(--cursor-lock) * 0.44));
  border-radius: 50%;
  pointer-events: none;
  opacity: calc(var(--cursor-opacity) * (1 - var(--hero-progress)));
  transform: translate(-50%, -50%) scale(calc(1 + var(--cursor-lock) * 0.1));
  transition:
    border-color 160ms ease,
    height 160ms ease,
    opacity 160ms linear,
    width 160ms ease;
}

.space-cursor::before,
.space-cursor::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  background: rgba(248, 242, 232, calc(0.5 + var(--cursor-lock) * 0.32));
  box-shadow: 0 0 12px rgba(155, 223, 255, calc(0.12 + var(--cursor-lock) * 0.24));
  transform: translate(-50%, -50%);
}

.space-cursor::before {
  width: 42px;
  height: 1px;
}

.space-cursor::after {
  width: 1px;
  height: 42px;
}

.robot-trail {
  position: fixed;
  left: var(--trail-x);
  top: var(--trail-y);
  pointer-events: none;
  transform-origin: 0 50%;
}

.robot-pointer {
  position: fixed;
  left: var(--beam-x);
  top: var(--beam-y);
  pointer-events: none;
  transform-origin: 0 50%;
}

.robot-scan {
  position: fixed;
  left: var(--scan-x);
  top: var(--scan-y);
  z-index: 32;
  width: var(--scan-size);
  height: var(--scan-size);
  border: 1px solid rgba(155, 223, 255, 0.34);
  border-radius: 50%;
  pointer-events: none;
  opacity: var(--scan-opacity);
  transform: translate(-50%, -50%) scale(0.82);
  animation: scanPulse 1.55s ease-out infinite;
}

.robot-scan::before,
.robot-scan::after {
  content: "";
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  border: 1px solid rgba(248, 242, 232, 0.26);
}

.robot-scan::after {
  inset: 44%;
  background: rgba(248, 242, 232, 0.72);
  border: 0;
  opacity: var(--scan-core-opacity, 1);
  box-shadow:
    0 0 16px rgba(248, 242, 232, 0.54),
    0 0 34px rgba(155, 223, 255, 0.34);
}

.robot-trail {
  z-index: 33;
  width: 112px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(155, 223, 255, 0.52), rgba(245, 216, 167, 0.34), transparent);
  filter: blur(0.2px) drop-shadow(0 0 14px rgba(155, 223, 255, 0.3));
  opacity: var(--trail-opacity);
  transform: translate(-12px, -50%) rotate(var(--trail-angle));
}

.robot-pointer {
  z-index: 33;
  width: var(--beam-length);
  height: 1px;
  background: linear-gradient(90deg, rgba(248, 242, 232, 0), rgba(248, 242, 232, 0.75), rgba(155, 223, 255, 0));
  box-shadow: 0 0 16px rgba(155, 223, 255, 0.32);
  opacity: var(--beam-opacity);
  transform: translate(0, -50%) rotate(var(--beam-angle)) scaleX(calc(0.92 + var(--beam-opacity) * 0.12));
  transition: opacity 120ms linear;
}

.robot-pointer::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(248, 242, 232, 0.95);
  box-shadow:
    0 0 12px rgba(248, 242, 232, 0.78),
    0 0 24px rgba(155, 223, 255, 0.38);
  opacity: var(--beam-dot-opacity, 1);
  transform: translate(50%, -50%);
}

.robot-companion {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 34;
  width: clamp(78px, 7.2vw, 132px);
  max-width: 18vw;
  height: auto;
  pointer-events: none;
  filter:
    drop-shadow(0 0 18px rgba(245, 216, 167, 0.34))
    drop-shadow(0 16px 28px rgba(0, 0, 0, 0.42));
  opacity: 0.98;
  transform:
    translate3d(var(--robot-x), var(--robot-y), 0)
    translate(-50%, -50%)
    scale(var(--robot-scale))
    rotate(var(--robot-tilt));
  transform-origin: 50% 58%;
  transition: opacity 160ms ease;
}

.robot-companion.is-flying {
  filter:
    drop-shadow(0 0 24px rgba(155, 223, 255, 0.5))
    drop-shadow(0 18px 32px rgba(0, 0, 0, 0.46));
}

.robot-face {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 35;
  width: clamp(78px, 7.2vw, 132px);
  max-width: 18vw;
  aspect-ratio: 820 / 704;
  pointer-events: none;
  opacity: 0.96;
  transform:
    translate3d(var(--robot-x), var(--robot-y), 0)
    translate(-50%, -50%)
    scale(var(--robot-scale))
    rotate(var(--robot-tilt));
  transform-origin: 50% 58%;
}

.robot-eye {
  position: absolute;
  top: 34.4%;
  width: 7.4%;
  height: 12.4%;
  border-radius: 2px;
  background:
    linear-gradient(180deg, rgba(2, 2, 2, 0.98), rgba(12, 10, 8, 0.94));
  box-shadow: inset 0 0 5px rgba(245, 216, 167, 0.08);
  opacity: 0;
  transform: scaleY(0);
  transform-origin: center top;
  animation: robotBlink 4.7s infinite;
}

.robot-eye-left {
  left: 31.7%;
}

.robot-eye-right {
  left: 52.4%;
  animation-delay: 0.04s;
}

.robot-companion.is-flying + .robot-face .robot-eye {
  animation-duration: 2.4s;
}

.hero {
  position: relative;
  min-height: 152svh;
  overflow: hidden;
  isolation: isolate;
  background: #030303;
}

.hero-image,
.hero-foreground {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100svh;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.06) contrast(1.08) brightness(0.98);
  transform:
    translate3d(
      calc(var(--mouse-x) * -8px),
      calc(var(--scroll) * -0.052px + var(--mouse-y) * -5px + var(--space-warp) * -28px),
      0
    )
    scale(calc(1.015 + var(--hero-progress) * 0.038 + var(--space-warp) * 0.035));
}

.hero-image {
  z-index: 0;
}

.hero-foreground {
  z-index: 18;
  pointer-events: none;
  opacity: var(--foreground-opacity);
  filter: saturate(1.04) contrast(1.07) brightness(0.82);
  -webkit-mask-image:
    radial-gradient(ellipse 18% 42% at 51% 56%, #000 0 62%, rgba(0, 0, 0, 0.78) 72%, transparent 88%),
    linear-gradient(180deg, transparent 0 56%, #000 74% 100%);
  -webkit-mask-position: center;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-image:
    radial-gradient(ellipse 18% 42% at 51% 56%, #000 0 62%, rgba(0, 0, 0, 0.78) 72%, transparent 88%),
    linear-gradient(180deg, transparent 0 56%, #000 74% 100%);
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}

.portrait-particles {
  position: fixed;
  inset: 0;
  z-index: 19;
  width: 100%;
  height: 100svh;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: calc(var(--portrait-particles-opacity) * var(--foreground-opacity));
  -webkit-mask-image:
    radial-gradient(ellipse 15% 38% at 51% 55%, #000 0 56%, rgba(0, 0, 0, 0.72) 68%, transparent 88%),
    linear-gradient(180deg, transparent 0 42%, #000 56% 86%, transparent 100%);
  -webkit-mask-position: center;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-image:
    radial-gradient(ellipse 15% 38% at 51% 55%, #000 0 56%, rgba(0, 0, 0, 0.72) 68%, transparent 88%),
    linear-gradient(180deg, transparent 0 42%, #000 56% 86%, transparent 100%);
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}

.hero::before,
.hero::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.hero::before {
  background:
    radial-gradient(circle at 50% 38%, transparent 30%, rgba(0, 0, 0, calc(0.22 + var(--hero-dim) * 0.18)) 80%),
    linear-gradient(180deg, rgba(0, 0, 0, calc(0.1 + var(--hero-dim) * 0.18)), transparent 32%, rgba(0, 0, 0, calc(0.62 + var(--hero-dim) * 0.22)));
}

.hero::after {
  background:
    repeating-linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.026) 0,
      rgba(255, 255, 255, 0.026) 1px,
      transparent 1px,
      transparent 11px
    );
  opacity: calc(0.18 + var(--space-warp) * 0.12);
  transform: translateY(calc(var(--space-warp) * -18px)) scaleY(calc(1 + var(--space-warp) * 0.18));
}

.space-depth {
  position: fixed;
  inset: 0;
  z-index: 3;
  overflow: hidden;
  pointer-events: none;
  opacity: calc(1 - var(--space-warp) * 0.28);
  transform:
    translateY(calc(var(--space-warp) * -28px))
    scale(calc(1 + var(--space-warp) * 0.06));
  transition: opacity 120ms linear;
}

.nebula {
  position: absolute;
  width: 34vw;
  min-width: 360px;
  aspect-ratio: 1;
  border-radius: 50%;
  opacity: 0.12;
  filter: blur(52px);
  transform:
    translate3d(
      calc(var(--mouse-x) * 18px),
      calc(var(--mouse-y) * 14px + var(--space-warp) * -48px),
      0
    )
    scale(calc(1 + var(--space-warp) * 0.18));
  animation: nebulaPulse 6.8s ease-in-out infinite;
}

.nebula-one {
  left: 4vw;
  top: 12vh;
  background: rgba(245, 216, 167, 0.24);
}

.nebula-two {
  right: 6vw;
  top: 8vh;
  background: rgba(155, 223, 255, 0.2);
  animation-delay: -2.8s;
}

.planet-hotspot {
  --wake: 0;
  position: fixed;
  left: var(--hotspot-x, 50vw);
  top: var(--hotspot-y, 28vh);
  z-index: 32;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  place-items: center;
  min-width: 118px;
  min-height: 42px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  opacity: var(--planet-opacity);
  transform:
    translate(-50%, -50%)
    translate3d(
      calc(var(--mouse-x) * 6px),
      calc(var(--mouse-y) * 5px),
      0
    )
    scale(var(--hotspot-scale, 1));
  transition:
    opacity 160ms linear,
    transform 180ms ease,
    filter 180ms ease;
}

.planet-hotspot::before {
  content: "";
  position: absolute;
  top: 50%;
  pointer-events: none;
  transform: translateY(-50%);
}

.planet-hotspot::before {
  left: -72px;
  width: calc(72px + var(--wake) * 26px);
  height: 1px;
  background: linear-gradient(90deg, transparent, currentColor, transparent);
  opacity: calc(0.58 + var(--wake) * 0.28);
  box-shadow:
    0 0 14px rgba(245, 216, 167, calc(0.28 + var(--wake) * 0.24)),
    0 0 28px rgba(155, 223, 255, calc(var(--wake) * 0.16));
}

.hotspot-dot {
  display: none;
}

.hotspot-word {
  position: relative;
  z-index: 1;
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(12px, 1.1vw, 17px);
  font-weight: 950;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
  text-shadow:
    0 1px 5px rgba(0, 0, 0, 0.95),
    0 0 16px rgba(245, 216, 167, 0.66),
    0 0 34px rgba(155, 223, 255, 0.18);
  transition:
    letter-spacing 180ms ease,
    text-shadow 180ms ease;
}

.hotspot-copy {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: start;
  gap: 8px;
}

.hotspot-word::after {
  content: "";
  position: absolute;
  left: 0;
  right: 8%;
  bottom: -8px;
  height: 1px;
  background: linear-gradient(90deg, currentColor, transparent);
  opacity: 0.54;
}

.hotspot-subtitle {
  color: rgba(248, 242, 232, 0.62);
  display: none;
  font-size: clamp(9px, 0.72vw, 11px);
  font-weight: 800;
  letter-spacing: 0.12em;
  line-height: 1;
  opacity: 0;
  text-transform: uppercase;
  transform: translateY(-4px);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
  white-space: nowrap;
}

.planet-hotspot:hover,
.planet-hotspot:focus-visible,
.planet-hotspot.is-focused {
  --hotspot-scale: 1.12;
  outline: none;
  filter: drop-shadow(0 0 20px rgba(248, 242, 232, 0.5));
}

.planet-hotspot:hover .hotspot-word,
.planet-hotspot:focus-visible .hotspot-word,
.planet-hotspot.is-focused .hotspot-word {
  letter-spacing: 0.18em;
  text-shadow:
    0 1px 5px rgba(0, 0, 0, 0.96),
    0 0 20px rgba(245, 216, 167, 0.82),
    0 0 42px rgba(155, 223, 255, 0.26);
}

.planet-hotspot:hover .hotspot-subtitle,
.planet-hotspot:focus-visible .hotspot-subtitle,
.planet-hotspot.is-focused .hotspot-subtitle {
  opacity: 1;
  transform: translateY(0);
}

.planet-hotspot.is-dimmed {
  filter: saturate(0.58);
}

.planet-thinking .hotspot-word {
  color: rgba(255, 234, 199, 0.98);
}

.planet-projects .hotspot-word {
  color: rgba(255, 226, 184, 0.98);
}

.planet-projects::before {
  left: -48px;
  width: calc(48px + var(--wake) * 14px);
  opacity: calc(0.38 + var(--wake) * 0.18);
}

.planet-ai .hotspot-word {
  color: rgba(218, 243, 255, 0.98);
}

.planet-ai .hotspot-dot {
  border-color: rgba(155, 223, 255, 0.78);
  box-shadow:
    0 0 calc(4px + var(--wake) * 18px) rgba(155, 223, 255, 0.44),
    inset 0 0 calc(3px + var(--wake) * 10px) rgba(248, 242, 232, 0.24);
}

.planet-ai {
  flex-direction: row-reverse;
}

.planet-ai::before {
  left: auto;
  right: -72px;
}

.planet-ai::after {
  left: auto;
  right: -4px;
}

.planet-ai .hotspot-word::after {
  left: 8%;
  right: 0;
  background: linear-gradient(90deg, transparent, currentColor);
}

.planet-ai .hotspot-copy {
  justify-items: end;
}

.scroll-cue {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 33;
  width: 22px;
  height: 38px;
  border: 1px solid rgba(248, 242, 232, 0.52);
  border-radius: 999px;
  opacity: calc(1 - var(--hero-progress) * 2);
  transform: translateX(-50%);
}

.scroll-cue::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 8px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--ink);
  box-shadow: 0 0 12px rgba(245, 216, 167, 0.72);
  transform: translateX(-50%);
  animation: cue 1.35s ease-in-out infinite;
}

.scroll-signature {
  position: fixed;
  left: 50%;
  top: var(--signature-y);
  z-index: 36;
  width: min(980px, 92vw);
  pointer-events: none;
  opacity: var(--signature-opacity);
  transform:
    translate(-50%, -50%)
    rotate(calc((1 - var(--signature-opacity)) * -2.4deg))
    scale(var(--signature-scale));
  transition:
    opacity 110ms linear,
    transform 110ms linear;
}

.scroll-signature::before {
  content: "";
  position: absolute;
  left: 9%;
  right: 9%;
  top: 50%;
  height: 34%;
  border-radius: 999px;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(245, 216, 167, calc(var(--signature-glow) * 0.22)), transparent 62%),
    linear-gradient(90deg, transparent, rgba(155, 223, 255, calc(var(--signature-glow) * 0.12)), transparent);
  filter: blur(28px);
  opacity: var(--signature-glow);
  transform: translateY(-50%);
}

.scroll-signature svg {
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.signature-main,
.signature-shadow {
  font-family: "Brush Script MT", "Segoe Script", "Lucida Handwriting", cursive;
  font-size: 176px;
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0;
  dominant-baseline: middle;
  fill: rgba(248, 242, 232, var(--signature-fill));
  stroke-linecap: round;
  stroke-linejoin: round;
}

.signature-main {
  stroke: rgba(248, 242, 232, 0.95);
  stroke-width: 2.2;
  filter:
    drop-shadow(0 0 calc(14px + var(--signature-glow) * 8px) rgba(245, 216, 167, 0.42))
    drop-shadow(0 0 calc(42px + var(--signature-glow) * 28px) rgba(155, 223, 255, 0.12));
}

.signature-shadow {
  stroke: rgba(245, 216, 167, 0.24);
  stroke-width: 7;
  filter: blur(0.5px);
}

.signature-word {
  opacity: var(--signature-opacity);
}

.signature-mask-path {
  fill: none;
  stroke: #fff;
  stroke-width: 138;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1;
  stroke-dashoffset: var(--signature-mask-offset);
}

.signature-flourish {
  fill: none;
  stroke: rgba(245, 216, 167, 0.64);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-dasharray: 1;
  stroke-dashoffset: var(--signature-flourish-offset);
  opacity: var(--signature-flourish-opacity);
  filter: drop-shadow(0 0 14px rgba(245, 216, 167, 0.32));
}

.section {
  position: relative;
  z-index: 24;
  min-height: 100svh;
  display: grid;
  align-content: center;
  gap: clamp(24px, 4vw, 48px);
  padding: clamp(76px, 8vw, 128px) clamp(22px, 7vw, 112px);
  border-top: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(3, 3, 3, 0.88), rgba(3, 3, 3, 0.97)),
    radial-gradient(circle at 72% 32%, rgba(155, 223, 255, 0.08), transparent 330px),
    radial-gradient(circle at 20% 64%, rgba(245, 216, 167, 0.08), transparent 320px);
}

.section-projects,
.section-thinking,
.section-ai,
.section-contact {
  isolation: isolate;
  overflow: hidden;
  background:
    radial-gradient(ellipse 72% 58% at 50% 18%, rgba(248, 242, 232, 0.065), transparent 68%),
    radial-gradient(ellipse 54% 42% at 16% 72%, rgba(155, 223, 255, 0.055), transparent 72%),
    linear-gradient(180deg, rgba(7, 7, 6, 0.92), rgba(3, 3, 3, 0.97));
}

.section-projects::before,
.section-thinking::before,
.section-ai::before,
.section-contact::before,
.section-projects::after,
.section-thinking::after,
.section-ai::after,
.section-contact::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.section-projects::before,
.section-thinking::before,
.section-ai::before,
.section-contact::before {
  opacity: 0.18;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.16) 0 0.8px, transparent 1.7px),
    radial-gradient(circle, rgba(155, 223, 255, 0.1) 0 0.7px, transparent 1.6px);
  background-size: 30px 30px, 60px 60px;
  background-position: 0 0, 15px 18px;
  mask-image: linear-gradient(180deg, transparent 0, #000 16%, #000 82%, transparent 100%);
}

.section-projects::after,
.section-thinking::after,
.section-ai::after,
.section-contact::after {
  opacity: 0.32;
  background:
    linear-gradient(96deg, transparent 0 48%, rgba(248, 242, 232, 0.06) 48.06% 48.14%, transparent 48.26%),
    radial-gradient(ellipse 52% 18% at 50% 72%, transparent 0 72%, rgba(155, 223, 255, 0.16) 72.18% 72.34%, transparent 72.7%);
  mix-blend-mode: screen;
}

.section-projects > *,
.section-thinking > *,
.section-ai > *,
.section-contact > * {
  position: relative;
  z-index: 1;
}

.section-kicker,
.panel-kicker {
  margin: 0;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.section h2 {
  max-width: 940px;
  margin: 0;
  font-size: clamp(34px, 6vw, 86px);
  line-height: 1.04;
  letter-spacing: 0;
}

.section-projects h2,
.section-thinking h2,
.section-ai h2,
.section-contact h2 {
  max-width: min(920px, 76vw);
  font-size: clamp(42px, 5.1vw, 76px);
  line-height: 0.98;
  text-wrap: balance;
  text-shadow:
    0 12px 36px rgba(0, 0, 0, 0.42),
    0 0 28px rgba(245, 216, 167, 0.08);
}

.section-contact h2 {
  max-width: min(700px, 55vw);
  font-size: clamp(38px, 4.08vw, 60px);
  line-height: 1;
}

.section-lead {
  max-width: min(760px, 68vw);
  margin: clamp(-28px, -2vw, -14px) 0 0;
  color: rgba(248, 242, 232, 0.62);
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 1.9;
}

.section-contact .section-lead {
  max-width: min(620px, 52vw);
}

.ability-showcase {
  display: grid;
  grid-template-columns: minmax(330px, 0.84fr) minmax(520px, 1fr);
  align-items: center;
  gap: clamp(0px, 1.2vw, 20px);
  min-height: min(720px, 76svh);
}

.ability-copy {
  display: grid;
  align-content: center;
  gap: clamp(18px, 2.2vw, 28px);
  justify-self: end;
  transform: translateX(clamp(10px, 2.6vw, 42px));
}

.ability-copy .section-lead {
  margin: 0;
  max-width: min(460px, 31vw);
}

.ability-copy h2 {
  max-width: 10ch;
  font-size: clamp(50px, 6.4vw, 96px);
  line-height: 0.9;
}

.ability-status {
  position: relative;
  display: grid;
  gap: 8px;
  max-width: min(560px, 40vw);
  margin-top: 4px;
  padding: 18px 0 18px 20px;
  border-left: 1px solid rgba(245, 216, 167, 0.38);
}

.ability-status::before {
  content: "";
  position: absolute;
  left: -4px;
  top: 18px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(245, 216, 167, 0.92);
  box-shadow: 0 0 18px rgba(245, 216, 167, 0.42);
}

.ability-status span {
  color: rgba(245, 216, 167, 0.78);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ability-status strong {
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.1;
}

.ability-status p {
  margin: 0;
  color: rgba(248, 242, 232, 0.64);
  line-height: 1.78;
}

.ability-stage {
  position: relative;
  min-height: clamp(520px, 52vw, 660px);
  display: grid;
  place-items: center;
  overflow: visible;
  isolation: isolate;
  transform: translateX(clamp(-118px, -7.2vw, -64px));
}

.ability-webgl {
  position: absolute;
  inset: -8% -4% -8% -6%;
  z-index: 0;
  width: 110%;
  height: 116%;
  pointer-events: auto;
  filter:
    drop-shadow(0 0 34px rgba(245, 216, 167, 0.12))
    drop-shadow(0 0 58px rgba(155, 223, 255, 0.075));
  mix-blend-mode: screen;
  -webkit-mask-image: radial-gradient(ellipse 56% 54% at 58% 50%, #000 0 58%, rgba(0, 0, 0, 0.72) 74%, transparent 98%);
  mask-image: radial-gradient(ellipse 56% 54% at 58% 50%, #000 0 58%, rgba(0, 0, 0, 0.72) 74%, transparent 98%);
}

.ability-orbit {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.ability-card {
  position: absolute;
  left: var(--skill-x, 50%);
  top: var(--skill-y, 50%);
  z-index: calc(2 + var(--skill-depth, 1));
  width: clamp(130px, 10vw, 164px);
  min-height: 78px;
  padding: 10px 12px;
  border: 1px solid rgba(248, 242, 232, 0.15);
  border-radius: 8px;
  background:
    radial-gradient(circle at 16% 0%, rgba(245, 216, 167, calc(0.1 + var(--skill-wake, 0) * 0.08)), transparent 42%),
    linear-gradient(145deg, rgba(248, 242, 232, 0.072), rgba(155, 223, 255, 0.02)),
    rgba(3, 3, 3, 0.5);
  color: var(--ink);
  cursor: pointer;
  pointer-events: auto;
  text-align: left;
  backdrop-filter: blur(16px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.055),
    0 16px 42px rgba(0, 0, 0, 0.24);
  filter: saturate(calc(0.9 + var(--skill-wake, 0) * 0.28));
  opacity: var(--skill-opacity, 0);
  transform:
    translate(-50%, -50%)
    translateY(calc((1 - var(--skill-depth, 1)) * 18px))
    scale(calc(0.84 + var(--skill-depth, 1) * 0.2 + var(--skill-wake, 0) * 0.045));
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    filter 180ms ease,
    opacity 120ms ease,
    transform 220ms cubic-bezier(0.2, 0.72, 0.18, 1);
}

.ability-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(245, 216, 167, 0.42), transparent 78%);
  opacity: calc(0.42 + var(--skill-wake, 0) * 0.32);
}

.ability-card::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 12px;
  width: 10px;
  height: 10px;
  border: 1px solid rgba(155, 223, 255, 0.22);
  border-radius: 50%;
  box-shadow:
    inset 0 0 12px rgba(155, 223, 255, 0.1),
    0 0 18px rgba(155, 223, 255, 0.08);
  transform: scale(calc(1 + var(--skill-wake, 0) * 0.28));
  transition:
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.ability-card:hover,
.ability-card:focus-visible,
.ability-card.is-active {
  border-color: rgba(245, 216, 167, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 0 40px rgba(245, 216, 167, 0.18),
    0 0 22px rgba(155, 223, 255, 0.08),
    0 20px 60px rgba(0, 0, 0, 0.36);
}

.ability-card:hover::after,
.ability-card:focus-visible::after,
.ability-card.is-active::after {
  border-color: rgba(155, 223, 255, 0.46);
  background: rgba(155, 223, 255, 0.12);
  box-shadow:
    inset 0 0 12px rgba(155, 223, 255, 0.18),
    0 0 24px rgba(155, 223, 255, 0.22);
}

.ability-card:focus-visible {
  outline: 1px solid rgba(155, 223, 255, 0.5);
  outline-offset: 4px;
}

.ability-card span {
  display: block;
  color: rgba(245, 216, 167, 0.82);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ability-card strong {
  display: block;
  max-width: 10ch;
  margin: 0 0 6px;
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(17px, 1.18vw, 20px);
  line-height: 1.02;
}

.ability-card.is-active strong {
  text-shadow:
    0 0 18px rgba(245, 216, 167, 0.22),
    0 0 28px rgba(155, 223, 255, 0.1);
}

.ability-card small {
  display: block;
  max-width: 13ch;
  margin: 0;
  color: rgba(248, 242, 232, 0.62);
  font-size: 11px;
  line-height: 1.48;
}

.ability-core {
  display: none;
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.8vw, 24px);
}

.card-grid article,
.signal-list article,
.timeline article {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.014)),
    rgba(3, 3, 3, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 22px 70px rgba(0, 0, 0, 0.22);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.card-grid article {
  min-height: 240px;
  padding: clamp(22px, 2.2vw, 32px);
  display: grid;
  align-content: space-between;
}

.card-grid article::before,
.signal-list article::before,
.timeline article::before,
.platform-card::before,
.contact-main::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(245, 216, 167, 0.48), transparent 72%);
  opacity: 0.42;
}

.card-grid article::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 18px;
  width: 62px;
  height: 62px;
  border: 1px solid rgba(248, 242, 232, 0.12);
  border-radius: 50%;
  opacity: 0.38;
  box-shadow: inset 0 0 28px rgba(155, 223, 255, 0.06);
  transform: rotate(-12deg);
}

.card-grid article:hover,
.signal-list article:hover,
.timeline article:hover,
.platform-card:hover,
.contact-main:hover {
  border-color: rgba(245, 216, 167, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 0 38px rgba(245, 216, 167, 0.08),
    0 24px 82px rgba(0, 0, 0, 0.28);
}

.card-grid article:hover,
.signal-list article:hover,
.timeline article:hover {
  transform: translateY(-4px);
}

.card-grid span,
.timeline span,
.signal-list span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.card-grid h3 {
  margin: 26px 0 10px;
  font-size: clamp(24px, 2.5vw, 36px);
}

.card-grid p,
.signal-list p,
.timeline p {
  margin: 0;
  color: var(--muted);
  line-height: 1.8;
}

.card-points {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  margin: 24px 0 0;
  padding: 20px 0 0;
  border-top: 1px solid rgba(248, 242, 232, 0.09);
  list-style: none;
}

.card-points li {
  position: relative;
  padding-left: 18px;
  color: rgba(248, 242, 232, 0.68);
  font-size: 13px;
  line-height: 1.55;
}

.card-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 6px;
  height: 6px;
  border: 1px solid rgba(245, 216, 167, 0.54);
  border-radius: 50%;
  box-shadow: 0 0 14px rgba(245, 216, 167, 0.22);
  transform: translateY(-50%);
}

.signal-list,
.timeline {
  display: grid;
  gap: 14px;
  max-width: min(980px, 76vw);
}

.signal-list article,
.timeline article {
  display: grid;
  grid-template-columns: 142px 1fr;
  gap: clamp(18px, 3vw, 42px);
  padding: 20px 24px;
}

.signal-list article span,
.timeline article span {
  color: rgba(245, 216, 167, 0.76);
}

.signal-list article div,
.timeline article div {
  display: grid;
  gap: 8px;
}

.signal-list h3,
.timeline h3 {
  margin: 0;
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(18px, 1.7vw, 26px);
  line-height: 1.18;
}

.section-thinking {
  --project-focus-x: 50%;
  --project-focus-y: 58%;
  align-content: center;
  justify-items: center;
  gap: clamp(12px, 1.45vw, 20px);
  padding-top: clamp(58px, 5.6vw, 86px);
  padding-bottom: clamp(58px, 5.6vw, 86px);
  background:
    radial-gradient(circle at var(--project-focus-x) var(--project-focus-y), rgba(155, 223, 255, 0.105), transparent 280px),
    linear-gradient(90deg, rgba(155, 223, 255, 0.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(248, 242, 232, 0.032) 1px, transparent 1px),
    linear-gradient(180deg, rgba(6, 8, 10, 0.97), rgba(2, 3, 5, 0.99));
  background-size: auto, 92px 92px, 92px 92px, auto;
}

.section-thinking::after {
  opacity: 0.52;
  background:
    radial-gradient(circle at var(--project-focus-x) var(--project-focus-y), transparent 0 92px, rgba(155, 223, 255, 0.18) 93px 94px, transparent 96px),
    linear-gradient(100deg, transparent 0 42%, rgba(155, 223, 255, 0.08) 42.08% 42.18%, transparent 42.36%),
    linear-gradient(180deg, transparent 0 17%, rgba(248, 242, 232, 0.06) 17.06% 17.18%, transparent 17.32%),
    linear-gradient(90deg, transparent 0 9%, rgba(248, 242, 232, 0.075), rgba(155, 223, 255, 0.11), transparent 91%);
  mask-image: linear-gradient(180deg, transparent 0, #000 18%, #000 84%, transparent 100%);
}

.section-thinking::before {
  opacity: 0.2;
  background:
    repeating-linear-gradient(90deg, rgba(155, 223, 255, 0.08) 0 1px, transparent 1px 54px),
    repeating-linear-gradient(180deg, rgba(248, 242, 232, 0.048) 0 1px, transparent 1px 54px);
  mask-image: linear-gradient(180deg, transparent 0, #000 18%, #000 80%, transparent 100%);
}

.section-thinking .section-lead {
  width: min(1120px, 82vw);
  max-width: min(1120px, 82vw);
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.section-thinking > .section-kicker,
.section-thinking > h2 {
  width: min(1120px, 82vw);
  max-width: min(1120px, 82vw);
  text-align: center;
}

.section-thinking > h2 {
  max-width: 980px;
  color: rgba(248, 242, 232, 0.98);
  font-size: clamp(54px, 6.25vw, 90px);
  line-height: 0.86;
  letter-spacing: 0;
  text-transform: uppercase;
  text-shadow:
    0 18px 42px rgba(0, 0, 0, 0.62),
    0 0 34px rgba(155, 223, 255, 0.12);
}

.section-thinking > .section-kicker {
  color: rgba(248, 242, 232, 0.64);
  letter-spacing: 0;
}

.project-archive-status {
  position: relative;
  display: grid;
  grid-template-columns: minmax(92px, auto) minmax(0, 1fr) auto;
  grid-template-areas:
    "index title state"
    "index body state";
  gap: 6px 20px;
  align-items: center;
  width: min(1040px, 76vw);
  min-height: 64px;
  margin-top: 0;
  padding: 12px 16px;
  overflow: hidden;
  border: 1px solid rgba(155, 223, 255, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(155, 223, 255, 0.08), rgba(248, 242, 232, 0.045) 46%, rgba(155, 223, 255, 0.028)),
    rgba(2, 4, 8, 0.66);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 0 0 1px rgba(255, 255, 255, 0.018),
    0 18px 52px rgba(0, 0, 0, 0.28),
    0 0 34px rgba(155, 223, 255, 0.055);
  backdrop-filter: blur(18px);
}

.project-archive-status::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(155, 223, 255, 0.72), rgba(248, 242, 232, 0.46), transparent);
  opacity: 0.84;
}

.project-archive-status::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -38%;
  width: 34%;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.14), transparent);
  opacity: 0.72;
  transform: skewX(-18deg);
  animation: projectStatusSweep 4.2s ease-in-out infinite;
}

.project-archive-status > * {
  position: relative;
  z-index: 1;
}

.project-archive-status span {
  grid-area: index;
  color: rgba(155, 223, 255, 0.82);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
  white-space: nowrap;
}

.project-archive-status strong {
  grid-area: title;
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(18px, 1.55vw, 22px);
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.project-archive-status p {
  grid-area: body;
  margin: 0;
  color: rgba(248, 242, 232, 0.58);
  font-size: 12px;
  line-height: 1.45;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.project-archive-status em {
  grid-area: state;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(155, 223, 255, 0.72);
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
  white-space: nowrap;
}

.project-archive-status em::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(155, 223, 255, 0.86);
  box-shadow:
    0 0 16px rgba(155, 223, 255, 0.48),
    0 0 28px rgba(248, 242, 232, 0.06);
}

.project-competency-line {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: min(1120px, 82vw);
  justify-content: center;
  margin-top: clamp(-12px, -0.9vw, -6px);
}

.project-competency-line span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border: 1px solid rgba(248, 242, 232, 0.1);
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(155, 223, 255, 0.045), rgba(245, 216, 167, 0.035)),
    rgba(3, 3, 3, 0.3);
  color: rgba(248, 242, 232, 0.66);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.section-thinking .signal-list {
  position: relative;
  width: min(1120px, 82vw);
  max-width: none;
  grid-template-columns: minmax(380px, 1.08fr) repeat(2, minmax(250px, 0.86fr));
  grid-auto-rows: minmax(160px, auto);
  gap: 16px;
  margin-top: 6px;
}

.section-thinking .signal-list::before,
.section-thinking .signal-list::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.section-thinking .signal-list::before {
  inset: -13% -5% -10% -4%;
  z-index: -1;
  opacity: 0.44;
  background:
    linear-gradient(115deg, transparent 0 41%, rgba(155, 223, 255, 0.13) 41.08% 41.18%, transparent 41.32%),
    linear-gradient(25deg, transparent 0 58%, rgba(248, 242, 232, 0.08) 58.06% 58.16%, transparent 58.34%),
    repeating-linear-gradient(90deg, rgba(155, 223, 255, 0.045) 0 1px, transparent 1px 86px);
  filter: blur(0.1px);
  mix-blend-mode: screen;
}

.section-thinking .signal-list::after {
  left: 7%;
  right: 8%;
  top: 50%;
  height: 1px;
  z-index: 0;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.18), rgba(248, 242, 232, 0.11), transparent);
  opacity: 0.5;
}

.section-thinking .signal-list article {
  --project-card-wake: 0;
  z-index: 1;
  isolation: isolate;
  grid-template-columns: 1fr;
  align-content: end;
  gap: 14px;
  min-height: 170px;
  padding: 24px;
  border-color: rgba(155, 223, 255, 0.18);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), transparent 42%),
    linear-gradient(135deg, rgba(155, 223, 255, calc(0.04 + var(--project-card-wake) * 0.06)), rgba(248, 242, 232, 0.018) 46%, transparent 72%),
    rgba(3, 7, 11, 0.68);
  backdrop-filter: blur(16px);
  cursor: pointer;
  transform: translateY(calc(var(--project-card-wake) * -6px));
}

.section-thinking .signal-list article > :not(.project-singularity) {
  position: relative;
  z-index: 1;
}

.section-thinking .signal-list article::before {
  left: -42%;
  top: 0;
  z-index: 0;
  width: 36%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.12), transparent);
  opacity: calc(0.12 + var(--project-card-wake) * 0.42);
  transform: translateX(calc(var(--project-card-wake) * 350%)) skewX(-16deg);
  transition:
    opacity 220ms ease,
    transform 520ms ease;
}

.section-thinking .signal-list article::after {
  content: "";
  position: absolute;
  inset: 1px;
  z-index: 0;
  border-radius: inherit;
  opacity: calc(0.34 + var(--project-card-wake) * 0.24);
  background:
    linear-gradient(90deg, transparent 0 16%, rgba(155, 223, 255, 0.12) 16.2% 16.6%, transparent 16.8%),
    linear-gradient(180deg, transparent 0 68%, rgba(248, 242, 232, 0.07) 68.2% 68.6%, transparent 68.8%);
  mix-blend-mode: screen;
  transform: none;
  transition:
    opacity 180ms ease,
    background 180ms ease;
}

.section-thinking .signal-list article:first-child {
  grid-row: span 2;
  min-height: 360px;
  padding: 34px;
  border-color: rgba(155, 223, 255, 0.24);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.095), transparent 38%),
    linear-gradient(135deg, rgba(155, 223, 255, calc(0.06 + var(--project-card-wake) * 0.08)), rgba(248, 242, 232, 0.035) 48%, transparent 74%),
    rgba(3, 7, 11, 0.76);
}

.section-thinking .signal-list article:first-child h3 {
  max-width: 100%;
  font-size: clamp(34px, 3.15vw, 44px);
  line-height: 0.98;
  text-wrap: balance;
}

.section-thinking .signal-list article:first-child p {
  max-width: 46ch;
  color: rgba(248, 242, 232, 0.7);
}

.section-thinking .signal-list h3 {
  font-size: clamp(22px, 1.55vw, 25px);
  line-height: 1.08;
}

.section-thinking .signal-list p {
  color: rgba(248, 242, 232, 0.66);
  font-size: 15px;
  line-height: 1.52;
}

.section-thinking .signal-list span {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  color: rgba(155, 223, 255, 0.8);
  letter-spacing: 0;
}

.section-thinking .signal-list span::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(155, 223, 255, 0.92);
  box-shadow:
    0 0 14px rgba(155, 223, 255, 0.42),
    0 0 28px rgba(248, 242, 232, 0.08);
}

.section-thinking .project-module-copy {
  display: grid;
  gap: 8px;
  max-width: min(100%, 40ch);
}

.section-thinking .project-module-copy small {
  display: block;
  max-width: 42ch;
  margin-top: 2px;
  padding-top: 9px;
  border-top: 1px solid rgba(155, 223, 255, 0.14);
  color: rgba(155, 223, 255, 0.7);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.35;
}

.section-thinking .signal-list .project-singularity {
  position: absolute;
  right: clamp(18px, 1.9vw, 30px);
  top: clamp(18px, 1.9vw, 30px);
  z-index: 0;
  display: block;
  width: clamp(70px, 6.2vw, 102px);
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
  opacity: calc(0.62 + var(--project-card-wake) * 0.22);
  filter: drop-shadow(0 0 22px rgba(155, 223, 255, calc(0.08 + var(--project-card-wake) * 0.08)));
  transform: rotate(calc(var(--project-card-wake) * 10deg));
  transition:
    opacity 220ms ease,
    filter 220ms ease,
    transform 420ms ease;
}

.section-thinking .signal-list .project-singularity::before,
.section-thinking .signal-list .project-singularity::after,
.section-thinking .signal-list .project-singularity i,
.section-thinking .signal-list .project-singularity b {
  content: "";
  position: absolute;
  pointer-events: none;
}

.section-thinking .signal-list .project-singularity::before {
  inset: 29%;
  z-index: 2;
  border-radius: 50%;
  background:
    radial-gradient(circle at 42% 38%, rgba(248, 242, 232, 0.08), transparent 0 22%),
    radial-gradient(circle, #000 0 56%, rgba(2, 5, 9, 0.9) 62%, transparent 70%);
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.9),
    0 0 28px rgba(0, 0, 0, 0.92),
    0 0 44px rgba(155, 223, 255, calc(0.12 + var(--project-card-wake) * 0.12));
}

.section-thinking .signal-list .project-singularity::after {
  left: -15%;
  right: -15%;
  top: 42%;
  height: 22%;
  z-index: 1;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, rgba(248, 242, 232, 0.88) 0 5%, rgba(155, 223, 255, 0.58) 6% 18%, rgba(155, 223, 255, 0.2) 34%, transparent 66%),
    conic-gradient(from 115deg, transparent 0 18%, rgba(248, 242, 232, 0.58), rgba(155, 223, 255, 0.38), transparent 58% 100%);
  filter: blur(0.2px);
  transform: rotate(-12deg) scaleY(0.48);
  animation: projectDiskDrift 14s linear infinite;
}

.section-thinking .signal-list .project-singularity i {
  inset: 12%;
  border: 1px solid rgba(155, 223, 255, 0.2);
  border-radius: 50%;
  box-shadow:
    inset 0 0 24px rgba(155, 223, 255, 0.06),
    0 0 26px rgba(155, 223, 255, 0.05);
  transform: rotate(24deg) scaleY(0.45);
}

.section-thinking .signal-list .project-singularity b {
  left: -6%;
  right: -6%;
  top: 50%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(248, 242, 232, 0.42), rgba(155, 223, 255, 0.28), transparent);
  transform: rotate(-12deg);
}

.section-thinking .signal-list article:first-child .project-singularity {
  width: clamp(116px, 9.8vw, 154px);
}

.section-thinking .signal-list article:hover {
  --project-card-wake: 0.72;
  border-color: rgba(155, 223, 255, 0.42);
  transform: translateY(-6px);
}

.section-thinking .signal-list article.is-active {
  --project-card-wake: 1;
  border-color: rgba(155, 223, 255, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.13),
    inset 0 0 0 1px rgba(248, 242, 232, 0.035),
    0 0 46px rgba(155, 223, 255, 0.14),
    0 26px 82px rgba(0, 0, 0, 0.34);
}

.section-thinking .signal-list article.is-active::after {
  opacity: 0.72;
}

.section-thinking .signal-list article:focus-visible {
  outline: 1px solid rgba(155, 223, 255, 0.54);
  outline-offset: 4px;
}

.section-ai .timeline {
  counter-reset: ai-step;
  max-width: none;
}

.section-ai {
  --workflow-focus-x: 50%;
  --workflow-focus-y: 62%;
  z-index: 37;
  justify-items: center;
  padding-top: clamp(64px, 5vw, 82px);
  padding-bottom: clamp(64px, 5vw, 82px);
  background:
    radial-gradient(circle at var(--workflow-focus-x) var(--workflow-focus-y), rgb(86 207 255 / 0.16), transparent 290px),
    radial-gradient(circle at 76% 38%, rgb(86 207 255 / 0.08), transparent 370px),
    radial-gradient(circle at 20% 74%, rgb(255 255 255 / 0.055), transparent 320px),
    radial-gradient(ellipse 90% 42% at 50% 58%, rgb(155 223 255 / 0.055), transparent 74%),
    linear-gradient(180deg, rgb(4 6 9), rgb(1 3 6));
}

.section-ai::before {
  opacity: 0.22;
  background:
    radial-gradient(circle, rgb(255 255 255 / 0.18) 0 0.8px, transparent 1.8px),
    radial-gradient(circle, rgb(155 223 255 / 0.16) 0 0.7px, transparent 1.7px);
  background-size: 28px 28px, 58px 58px;
  background-position: 0 0, 16px 20px;
}

.section-ai::after {
  opacity: 0.42;
  background:
    linear-gradient(96deg, transparent 0 48%, rgb(155 223 255 / 0.08) 48.06% 48.14%, transparent 48.28%),
    repeating-linear-gradient(0deg, transparent 0 22px, rgb(155 223 255 / 0.038) 23px 24px),
    radial-gradient(ellipse 54% 18% at 50% 72%, transparent 0 72%, rgb(155 223 255 / 0.2) 72.18% 72.34%, transparent 72.7%);
  animation: workflowFieldScan 9s ease-in-out infinite;
}

.workflow-engine {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  justify-items: center;
  width: min(1280px, 88vw);
}

.workflow-engine::before,
.workflow-engine::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.workflow-engine::before {
  inset: -12% -6% -10%;
  border-radius: 50%;
  opacity: 0.52;
  background:
    radial-gradient(ellipse 72% 24% at 50% 54%, transparent 0 70%, rgb(155 223 255 / 0.24) 70.2% 70.48%, transparent 71%),
    radial-gradient(ellipse 84% 31% at 50% 56%, transparent 0 76%, rgb(255 255 255 / 0.11) 76.2% 76.45%, transparent 77%),
    radial-gradient(ellipse 96% 38% at 50% 58%, transparent 0 82%, rgb(86 207 255 / 0.11) 82.2% 82.46%, transparent 83%),
    linear-gradient(82deg, transparent 0 49%, rgb(155 223 255 / 0.12) 49.05% 49.12%, transparent 49.22%);
  transform: rotate(-7deg);
  mix-blend-mode: screen;
}

.workflow-engine::after {
  left: 50%;
  top: 63%;
  width: min(760px, 52vw);
  aspect-ratio: 1;
  border: 1px solid rgb(155 223 255 / 0.1);
  border-radius: 50%;
  opacity: 0.56;
  background:
    conic-gradient(from 18deg, transparent 0 62%, rgb(86 207 255 / 0.18) 65%, transparent 69% 100%),
    radial-gradient(circle, rgb(255 255 255 / 0.12) 0 1px, transparent 2px),
    radial-gradient(circle at 50% 50%, transparent 0 42%, rgb(155 223 255 / 0.15) 42.2% 42.55%, transparent 43.2%),
    radial-gradient(circle at 50% 50%, transparent 0 64%, rgb(86 207 255 / 0.18) 64.2% 64.55%, transparent 65.4%);
  background-size: 18px 18px, 100% 100%, 100% 100%;
  transform: translate(-50%, -50%);
  animation: workflowOrbitSpin 24s linear infinite;
}

.workflow-copy {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 14px;
  width: 100%;
  text-align: center;
}

.workflow-copy > h2 {
  color: rgb(255 255 255 / 0.98);
  font-size: 6rem;
  line-height: 0.88;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-shadow:
    0 0 28px rgb(155 223 255 / 0.18),
    0 0 70px rgb(86 207 255 / 0.12),
    0 22px 70px rgb(0 0 0 / 0.36);
}

.workflow-copy .section-lead {
  max-width: min(760px, 62vw);
  margin-top: -4px;
  color: rgb(255 255 255 / 0.68);
}

.workflow-status {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 7px 18px;
  align-items: center;
  width: min(900px, 70vw);
  margin-top: 8px;
  padding: 13px 18px;
  overflow: hidden;
  border: 1px solid rgb(155 223 255 / 0.2);
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgb(86 207 255 / 0.1), rgb(255 255 255 / 0.028)),
    rgb(2 8 14 / 0.6);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.08),
    0 0 28px rgb(86 207 255 / 0.08),
    0 18px 48px rgb(0 0 0 / 0.22);
  backdrop-filter: blur(16px);
  text-align: left;
}

.workflow-status::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  width: auto;
  height: 1px;
  border-radius: 0;
  background: linear-gradient(90deg, rgb(155 223 255 / 0.62), rgb(255 255 255 / 0.2), transparent);
  box-shadow: none;
}

.workflow-status::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 42%;
  background: linear-gradient(90deg, transparent, rgb(155 223 255 / 0.12), transparent);
  transform: translateX(-120%);
  animation: workflowStatusScan 5.4s ease-in-out infinite;
}

.workflow-status span {
  color: rgb(155 223 255 / 0.9);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  white-space: nowrap;
}

.workflow-status strong {
  color: rgb(255 255 255 / 0.96);
  font-size: 22px;
  line-height: 1.06;
  white-space: nowrap;
}

.workflow-status p {
  grid-column: 1 / -1;
  max-width: 78ch;
  margin: 0;
  color: rgb(255 255 255 / 0.64);
  font-size: 13px;
  line-height: 1.6;
}

.workflow-status span,
.workflow-status strong,
.workflow-status p {
  position: relative;
  z-index: 1;
}

.workflow-core {
  position: absolute;
  left: 50%;
  top: 63%;
  z-index: 1;
  display: grid;
  place-items: center;
  width: min(300px, 24vw);
  aspect-ratio: 1;
  border: 1px solid rgb(155 223 255 / 0.24);
  border-radius: 50%;
  color: rgb(255 255 255 / 0.76);
  text-align: center;
  pointer-events: none;
  transform: translate(-50%, -50%);
  background:
    radial-gradient(circle at 50% 50%, rgb(155 223 255 / 0.2), transparent 31%),
    conic-gradient(from 0deg, transparent 0 36%, rgb(86 207 255 / 0.18) 42%, transparent 48% 100%),
    radial-gradient(circle, transparent 0 54%, rgb(155 223 255 / 0.26) 54.4% 55%, transparent 56%),
    radial-gradient(circle, transparent 0 72%, rgb(255 255 255 / 0.14) 72.2% 72.7%, transparent 73.4%);
  box-shadow:
    inset 0 0 46px rgb(155 223 255 / 0.12),
    0 0 58px rgb(86 207 255 / 0.16);
  opacity: 0.88;
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease;
}

.workflow-core::before,
.workflow-core::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.workflow-core::before {
  inset: 22%;
  border: 1px solid rgb(155 223 255 / 0.2);
  background:
    radial-gradient(circle, rgb(255 255 255 / 0.2) 0 1px, transparent 2px);
  background-size: 12px 12px;
  animation: projectRadarSpin 20s linear infinite;
}

.workflow-core::after {
  inset: -18%;
  border: 1px solid rgb(155 223 255 / 0.1);
  box-shadow: 0 0 42px rgb(86 207 255 / 0.08);
}

.section-ai.is-workflow-pulse .workflow-core {
  animation: workflowCorePulse 720ms ease;
}

.section-ai.is-workflow-pulse .workflow-core::after {
  animation: workflowCorePing 720ms ease;
}

.workflow-core span,
.workflow-core strong {
  position: absolute;
  left: 50%;
  width: 100%;
  font-family: "SFMono-Regular", Consolas, monospace;
  text-transform: uppercase;
  transform: translateX(-50%);
}

.workflow-core span {
  top: 43%;
  color: rgb(155 223 255 / 0.72);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.18em;
}

.workflow-core strong {
  top: 51%;
  color: rgb(255 255 255 / 0.78);
  font-size: 11px;
  letter-spacing: 0.08em;
}

.section-ai .timeline {
  position: relative;
  z-index: 2;
  isolation: isolate;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(30px, 4vw, 48px) 18px;
  width: 100%;
}

.section-ai .timeline::before {
  content: "";
  position: absolute;
  left: 2%;
  right: 2%;
  top: calc(50% - 4px);
  bottom: auto;
  width: auto;
  height: 1px;
  z-index: 0;
  background: linear-gradient(90deg, transparent, rgb(155 223 255 / 0.34), rgb(255 255 255 / 0.16), rgb(155 223 255 / 0.28), transparent);
  opacity: 0.72;
  box-shadow: 0 0 24px rgb(86 207 255 / 0.14);
}

.section-ai .timeline::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 0;
  width: min(520px, 42vw);
  height: min(190px, 18vw);
  border: 1px solid rgb(155 223 255 / 0.12);
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent 0 44%, rgb(155 223 255 / 0.14) 49%, transparent 54% 100%),
    radial-gradient(ellipse at 50% 50%, transparent 0 62%, rgb(86 207 255 / 0.16) 62.2% 62.8%, transparent 63.4%);
  opacity: 0.68;
  pointer-events: none;
  transform: translate(-50%, -50%);
  animation: workflowLaneSweep 12s linear infinite;
}

.section-ai .timeline article {
  --module-lift: 0px;
  --bot-accent: rgb(155 223 255);
  --bot-soft: rgb(255 255 255);
  --bot-head-width: 94px;
  --bot-head-radius: 24px 24px 16px 16px;
  --bot-eye-width: 13px;
  --bot-eye-height: 9px;
  z-index: 1;
  grid-template-columns: 1fr;
  align-content: stretch;
  grid-template-rows: auto 112px auto auto;
  gap: 10px;
  min-height: 306px;
  padding: 16px 18px 14px;
  border-color: rgb(155 223 255 / 0.18);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0.07), transparent 38%),
    radial-gradient(circle at 86% 16%, rgb(155 223 255 / 0.13), transparent 30%),
    radial-gradient(circle at var(--workflow-focus-x) var(--workflow-focus-y), rgb(86 207 255 / 0.055), transparent 42%),
    linear-gradient(145deg, rgb(86 207 255 / 0.12), rgb(255 255 255 / 0.018) 44%, rgb(3 8 14 / 0.68)),
    rgb(2 6 11 / 0.66);
  backdrop-filter: blur(16px);
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  cursor: pointer;
  transform: translateY(var(--module-lift));
}

.section-ai .timeline article::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 18px;
  width: 52px;
  aspect-ratio: 1;
  border: 1px solid rgb(155 223 255 / 0.24);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgb(255 255 255 / 0.16) 0 1px, transparent 2px),
    radial-gradient(circle at 50% 50%, transparent 0 54%, rgb(155 223 255 / 0.3) 55% 57%, transparent 60%);
  background-size: 9px 9px, 100% 100%;
  opacity: 0.52;
  animation: projectRadarSpin 18s linear infinite;
}

.section-ai .timeline article:nth-child(2),
.section-ai .timeline article:nth-child(3) {
  --module-lift: -8px;
}

.section-ai .timeline article:nth-child(6),
.section-ai .timeline article:nth-child(7) {
  --module-lift: 8px;
}

.tool-claude {
  --bot-accent: rgb(176 230 255);
  --bot-head-width: 100px;
  --bot-head-radius: 28px 28px 18px 18px;
  --bot-eye-width: 16px;
}

.tool-codex {
  --bot-accent: rgb(92 214 255);
  --bot-head-width: 90px;
  --bot-head-radius: 14px;
  --bot-eye-height: 11px;
}

.tool-gemini {
  --bot-accent: rgb(138 236 255);
  --bot-head-width: 108px;
  --bot-head-radius: 999px;
}

.tool-remotion {
  --bot-accent: rgb(115 196 255);
  --bot-head-width: 96px;
  --bot-head-radius: 18px 30px 18px 30px;
}

.tool-vscode {
  --bot-accent: rgb(91 186 255);
  --bot-head-width: 92px;
  --bot-head-radius: 14px 24px 14px 24px;
}

.tool-github {
  --bot-accent: rgb(214 238 255);
  --bot-head-width: 96px;
  --bot-head-radius: 28px 28px 20px 20px;
}

.tool-capcut {
  --bot-accent: rgb(107 225 245);
  --bot-head-width: 92px;
  --bot-head-radius: 18px;
}

.tool-canva {
  --bot-accent: rgb(162 219 255);
  --bot-head-width: 98px;
  --bot-head-radius: 24px 14px 24px 14px;
}

.tool-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  min-height: 38px;
}

.tool-mark {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgb(155 223 255 / 0.22);
  border-radius: 8px;
  background:
    radial-gradient(circle at 35% 25%, rgb(255 255 255 / 0.18), transparent 48%),
    linear-gradient(145deg, rgb(155 223 255 / 0.18), rgb(86 207 255 / 0.08)),
    rgb(3 8 14 / 0.72);
  color: rgb(255 255 255 / 0.9);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.03em;
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.1),
    0 0 22px rgb(86 207 255 / 0.1);
}

.tool-card-top em {
  color: rgb(155 223 255 / 0.84);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.tool-bot {
  position: relative;
  justify-self: center;
  align-self: center;
  width: 136px;
  height: 112px;
  color: var(--bot-accent);
  filter:
    drop-shadow(0 0 18px rgb(86 207 255 / 0.14))
    drop-shadow(0 18px 26px rgb(0 0 0 / 0.28));
  transform: translateY(0);
  transition:
    filter 180ms ease,
    transform 180ms ease;
  animation: workflowBotIdle 4.8s ease-in-out infinite;
}

.section-ai .timeline .tool-bot span {
  display: block;
  color: inherit;
  font-size: 0;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
}

.tool-antenna {
  position: absolute;
  left: 50%;
  top: 0;
  width: 2px;
  height: 15px;
  border-radius: 99px;
  background: linear-gradient(180deg, transparent, var(--bot-accent));
  box-shadow: 0 0 14px rgb(86 207 255 / 0.22);
  transform: translateX(-50%);
}

.tool-antenna::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -4px;
  width: 9px;
  height: 9px;
  border: 1px solid rgb(155 223 255 / 0.56);
  border-radius: 50%;
  background: rgb(3 9 16 / 0.9);
  box-shadow: 0 0 18px color-mix(in srgb, var(--bot-accent) 68%, transparent);
  transform: translateX(-50%);
}

.tool-bot-head {
  position: absolute;
  left: 50%;
  top: 15px;
  width: var(--bot-head-width);
  height: 54px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 42%, transparent);
  border-radius: var(--bot-head-radius);
  background:
    radial-gradient(circle at 50% 16%, rgb(255 255 255 / 0.22), transparent 24%),
    linear-gradient(145deg, rgb(255 255 255 / 0.16), color-mix(in srgb, var(--bot-accent) 18%, transparent)),
    rgb(5 13 22 / 0.9);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.16),
    inset 0 -18px 26px rgb(2 6 12 / 0.38),
    0 0 26px color-mix(in srgb, var(--bot-accent) 16%, transparent);
  transform: translateX(-50%);
}

.tool-bot-head::before,
.tool-bot-head::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.tool-bot-head::before {
  inset: 9px 13px auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgb(255 255 255 / 0.38), transparent);
  opacity: 0.52;
}

.tool-bot-head::after {
  left: 12px;
  right: 12px;
  bottom: 9px;
  height: 3px;
  border-radius: 99px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--bot-accent) 72%, transparent), transparent);
  opacity: 0.58;
  animation: workflowBotScan 2.8s ease-in-out infinite;
}

.tool-eye {
  position: absolute;
  top: 21px;
  width: var(--bot-eye-width);
  height: var(--bot-eye-height);
  border-radius: 999px;
  background: linear-gradient(180deg, rgb(255 255 255 / 0.96), var(--bot-accent));
  box-shadow:
    0 0 12px color-mix(in srgb, var(--bot-accent) 48%, transparent),
    inset 0 0 5px rgb(255 255 255 / 0.4);
  animation: workflowBotEye 5.8s ease-in-out infinite;
}

.tool-eye:first-child {
  left: 24px;
}

.tool-eye:nth-child(2) {
  right: 24px;
}

.tool-screen {
  position: absolute;
  left: 50%;
  bottom: 12px;
  width: 30px;
  height: 5px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bot-accent) 44%, transparent);
  box-shadow: 0 0 12px color-mix(in srgb, var(--bot-accent) 36%, transparent);
  transform: translateX(-50%);
}

.tool-bot-body {
  position: absolute;
  left: 50%;
  top: 70px;
  width: 74px;
  height: 39px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 34%, transparent);
  border-radius: 16px 16px 20px 20px;
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0.12), transparent 36%),
    rgb(4 11 20 / 0.92);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.12),
    0 0 18px color-mix(in srgb, var(--bot-accent) 12%, transparent);
  transform: translateX(-50%);
}

.tool-bot-body::before,
.tool-bot-body::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.tool-bot-body::before {
  left: 50%;
  top: -6px;
  width: 26px;
  height: 8px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 28%, transparent);
  border-bottom: 0;
  border-radius: 12px 12px 0 0;
  transform: translateX(-50%);
}

.tool-bot-body::after {
  left: 12px;
  right: 12px;
  bottom: 9px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgb(255 255 255 / 0.3), transparent);
}

.tool-core-light {
  position: absolute;
  left: 50%;
  top: 9px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle, rgb(255 255 255 / 0.95), var(--bot-accent) 45%, transparent 72%);
  box-shadow: 0 0 18px color-mix(in srgb, var(--bot-accent) 55%, transparent);
  transform: translateX(-50%);
}

.tool-panel-line {
  position: absolute;
  top: 16px;
  width: 14px;
  height: 2px;
  border-radius: 99px;
  background: rgb(255 255 255 / 0.22);
}

.tool-panel-line:nth-child(2) {
  left: 12px;
}

.tool-panel-line:nth-child(3) {
  right: 12px;
}

.tool-arm {
  position: absolute;
  top: 76px;
  width: 24px;
  height: 31px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 26%, transparent);
  border-top: 0;
  border-radius: 0 0 16px 16px;
  box-shadow: 0 0 14px color-mix(in srgb, var(--bot-accent) 9%, transparent);
}

.tool-arm-left {
  left: 16px;
  transform: rotate(10deg);
}

.tool-arm-right {
  right: 16px;
  transform: rotate(-10deg);
}

.tool-codex .tool-bot-body::after {
  left: 14px;
  right: 14px;
  bottom: 10px;
  height: 10px;
  background:
    linear-gradient(90deg, var(--bot-accent) 0 18px, transparent 18px 24px, rgb(255 255 255 / 0.34) 24px 38px, transparent 38px),
    linear-gradient(90deg, rgb(255 255 255 / 0.24) 0 12px, transparent 12px 18px, var(--bot-accent) 18px 34px, transparent 34px);
  background-size: 48px 2px, 48px 2px;
  background-position: 0 0, 0 7px;
  background-repeat: no-repeat;
}

.tool-gemini .tool-bot-head::after {
  left: 20px;
  right: 20px;
  height: 4px;
  background:
    radial-gradient(circle at 0 50%, var(--bot-accent) 0 3px, transparent 4px),
    radial-gradient(circle at 100% 50%, rgb(255 255 255 / 0.9) 0 3px, transparent 4px),
    linear-gradient(90deg, transparent, color-mix(in srgb, var(--bot-accent) 72%, transparent), transparent);
}

.tool-remotion .tool-screen::after {
  content: "";
  position: absolute;
  left: 12px;
  top: -8px;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid rgb(255 255 255 / 0.78);
  filter: drop-shadow(0 0 8px color-mix(in srgb, var(--bot-accent) 44%, transparent));
}

.tool-vscode .tool-bot-head {
  clip-path: polygon(0 0, 86% 0, 100% 18%, 100% 100%, 14% 100%, 0 82%);
}

.tool-github .tool-bot-head::before {
  inset: 12px 24px auto;
  height: 24px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 34%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle at 20% 50%, var(--bot-accent) 0 2px, transparent 3px),
    radial-gradient(circle at 50% 20%, rgb(255 255 255 / 0.72) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 50%, var(--bot-accent) 0 2px, transparent 3px),
    linear-gradient(90deg, transparent 0 19%, rgb(255 255 255 / 0.22) 20% 80%, transparent 81%);
}

.tool-capcut .tool-arm-left {
  height: 40px;
  border-radius: 18px;
  transform: rotate(-28deg);
}

.tool-capcut .tool-arm-right {
  height: 40px;
  border-radius: 18px;
  transform: rotate(28deg);
}

.tool-canva .tool-bot-body::after {
  left: 14px;
  right: 14px;
  bottom: 8px;
  height: 14px;
  background:
    linear-gradient(90deg, rgb(255 255 255 / 0.18) 1px, transparent 1px),
    linear-gradient(0deg, rgb(255 255 255 / 0.18) 1px, transparent 1px),
    radial-gradient(circle at 28% 50%, var(--bot-accent) 0 3px, transparent 4px),
    radial-gradient(circle at 72% 50%, rgb(255 255 255 / 0.74) 0 3px, transparent 4px);
  background-size: 12px 12px, 12px 12px, 100% 100%, 100% 100%;
}

.section-ai .timeline article:hover .tool-bot,
.section-ai .timeline article.is-active .tool-bot {
  filter:
    drop-shadow(0 0 28px color-mix(in srgb, var(--bot-accent) 32%, transparent))
    drop-shadow(0 20px 30px rgb(0 0 0 / 0.34));
  transform: translateY(-6px);
}

.section-ai .timeline article:hover .tool-eye,
.section-ai .timeline article.is-active .tool-eye,
.section-ai .timeline article:hover .tool-core-light,
.section-ai .timeline article.is-active .tool-core-light {
  box-shadow:
    0 0 18px color-mix(in srgb, var(--bot-accent) 70%, transparent),
    0 0 30px color-mix(in srgb, var(--bot-accent) 32%, transparent);
}

.tool-card-copy {
  display: grid;
  gap: 7px;
}

.section-ai .timeline .tool-card-copy h3 {
  margin: 0;
  color: rgb(255 255 255 / 0.96);
  font-size: 1.42rem;
  line-height: 1.05;
}

.tool-card-copy small {
  color: rgb(255 255 255 / 0.56);
  font-size: 12px;
  line-height: 1.4;
}

.section-ai .timeline .tool-card-copy p {
  color: rgb(255 255 255 / 0.64);
  font-size: 13px;
  line-height: 1.56;
}

.section-ai .timeline .tool-tags {
  align-self: end;
  display: block;
  padding-top: 13px;
  border-top: 1px solid rgb(155 223 255 / 0.12);
  color: rgb(155 223 255 / 0.52);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: none;
}

.section-ai .timeline article::before {
  position: absolute;
  left: 18px;
  right: 18px;
  top: 0;
  width: auto;
  height: 1px;
  border-radius: 0;
  background:
    linear-gradient(90deg, rgb(155 223 255 / 0.54), rgb(255 255 255 / 0.18), transparent);
  opacity: 0.54;
  box-shadow: 0 0 18px rgb(86 207 255 / 0.14);
}

.section-ai .timeline article:hover,
.section-ai .timeline article.is-active {
  border-color: rgb(155 223 255 / 0.56);
  background:
    linear-gradient(180deg, rgb(255 255 255 / 0.09), transparent 38%),
    radial-gradient(circle at 86% 16%, rgb(155 223 255 / 0.2), transparent 32%),
    radial-gradient(circle at var(--workflow-focus-x) var(--workflow-focus-y), rgb(86 207 255 / 0.08), transparent 42%),
    linear-gradient(145deg, rgb(86 207 255 / 0.18), rgb(255 255 255 / 0.026) 44%, rgb(3 8 14 / 0.72)),
    rgb(2 8 14 / 0.72);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.14),
    0 0 44px rgb(86 207 255 / 0.16),
    0 24px 82px rgb(0 0 0 / 0.3);
  transform: translateY(calc(var(--module-lift) - 8px));
}

.section-ai .timeline article.is-active .tool-mark {
  border-color: rgb(155 223 255 / 0.56);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.16),
    0 0 30px rgb(86 207 255 / 0.24);
}

.section-ai .timeline article.is-active::after {
  opacity: 0.9;
  border-color: rgb(155 223 255 / 0.42);
  box-shadow:
    inset 0 0 30px rgb(155 223 255 / 0.12),
    0 0 28px rgb(86 207 255 / 0.2);
  animation-duration: 8s;
}

.section-ai .timeline article:focus-visible {
  outline: 1px solid rgb(155 223 255 / 0.58);
  outline-offset: 4px;
}

.section-ai {
  --workflow-focus-x: 50%;
  --workflow-focus-y: 50%;
  --workflow-active-accent: rgb(155 223 255);
  z-index: 37;
  min-height: 100svh;
  align-content: stretch;
  justify-items: stretch;
  padding: 0;
  background: #010306;
}

.section-ai::before,
.section-ai::after {
  display: none;
}

.workflow-scene {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
  overflow: hidden;
  background: #010306;
}

.workflow-scene::before,
.workflow-scene::after,
.workflow-scene-shade {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.workflow-scene::before {
  z-index: 1;
  background:
    radial-gradient(circle at var(--workflow-focus-x) var(--workflow-focus-y), rgb(155 223 255 / 0.16), transparent 170px),
    radial-gradient(circle at 50% 62%, rgb(155 223 255 / 0.08), transparent 330px),
    linear-gradient(90deg, rgb(0 0 0 / 0.5), transparent 28%, transparent 72%, rgb(0 0 0 / 0.5));
  mix-blend-mode: screen;
}

.workflow-scene::after {
  z-index: 1;
  opacity: 0.4;
  background:
    radial-gradient(circle, rgb(255 255 255 / 0.24) 0 0.8px, transparent 1.8px),
    radial-gradient(circle, rgb(155 223 255 / 0.16) 0 0.7px, transparent 1.7px);
  background-size: 34px 34px, 70px 70px;
  mask-image: linear-gradient(180deg, transparent 0, #000 18%, #000 86%, transparent 100%);
}

.workflow-scene-image {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(0.82) contrast(1.05) saturate(0.95);
  transform: scale(1.025);
}

.workflow-scene-shade {
  z-index: 1;
  background:
    linear-gradient(180deg, rgb(0 0 0 / 0.7) 0%, rgb(0 0 0 / 0.18) 28%, rgb(0 0 0 / 0.16) 60%, rgb(0 0 0 / 0.76) 100%),
    radial-gradient(ellipse at 50% 52%, transparent 0 36%, rgb(0 0 0 / 0.32) 70%);
}

.workflow-scene .workflow-copy {
  position: absolute;
  left: 50%;
  top: clamp(54px, 7svh, 88px);
  z-index: 3;
  width: min(920px, 90vw);
  gap: 12px;
  justify-items: center;
  text-align: center;
  transform: translateX(-50%);
}

.workflow-scene .workflow-copy > h2 {
  max-width: 100%;
  color: rgb(255 255 255 / 0.98);
  font-size: clamp(58px, 7.2vw, 118px);
  line-height: 0.88;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-shadow:
    0 0 22px rgb(155 223 255 / 0.18),
    0 24px 58px rgb(0 0 0 / 0.5);
}

.workflow-scene .workflow-copy .section-lead {
  max-width: min(760px, 80vw);
  margin-top: 0;
  color: rgb(255 255 255 / 0.72);
  text-shadow: 0 12px 34px rgb(0 0 0 / 0.68);
}

.workflow-crew {
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
}

.workflow-bot {
  --x: 50%;
  --y: 50%;
  --bot-size: 98px;
  --float-delay: 0s;
  --bot-accent: rgb(155 223 255);
  position: absolute;
  left: var(--x);
  top: var(--y);
  display: grid;
  justify-items: center;
  gap: 8px;
  width: clamp(108px, 10vw, 150px);
  padding: 0;
  border: 0;
  background: transparent;
  color: rgb(255 255 255 / 0.92);
  cursor: pointer;
  font: inherit;
  pointer-events: auto;
  transform: translate(-50%, -50%);
  transition:
    filter 180ms ease,
    opacity 180ms ease,
    transform 180ms ease;
  animation: workflowCrewFloat 5.8s ease-in-out infinite;
  animation-delay: var(--float-delay);
}

.workflow-bot.tool-claude {
  --bot-accent: rgb(176 230 255);
}

.workflow-bot.tool-codex {
  --bot-accent: rgb(66 198 255);
}

.workflow-bot.tool-gpt {
  --bot-accent: rgb(116 225 255);
}

.workflow-bot.tool-gemini {
  --bot-accent: rgb(90 236 228);
}

.workflow-bot.tool-remotion {
  --bot-accent: rgb(160 132 255);
}

.workflow-bot.tool-vscode {
  --bot-accent: rgb(72 160 255);
}

.workflow-bot.tool-github {
  --bot-accent: rgb(225 236 255);
}

.workflow-bot.tool-capcut {
  --bot-accent: rgb(66 238 185);
}

.workflow-bot.tool-obsidian {
  --bot-accent: rgb(150 116 255);
}

.workflow-bot.tool-canva {
  --bot-accent: rgb(238 144 255);
}

.crew-01 {
  --x: 23%;
  --y: 30%;
  --bot-size: 92px;
  --float-delay: -0.4s;
}

.crew-02 {
  --x: 18%;
  --y: 45%;
  --bot-size: 108px;
  --float-delay: -1.1s;
}

.crew-03 {
  --x: 20%;
  --y: 61%;
  --bot-size: 96px;
  --float-delay: -2.2s;
}

.crew-04 {
  --x: 26%;
  --y: 76%;
  --bot-size: 102px;
  --float-delay: -3.1s;
}

.crew-05 {
  --x: 77%;
  --y: 30%;
  --bot-size: 96px;
  --float-delay: -1.7s;
}

.crew-06 {
  --x: 82%;
  --y: 45%;
  --bot-size: 106px;
  --float-delay: -2.6s;
}

.crew-07 {
  --x: 80%;
  --y: 61%;
  --bot-size: 98px;
  --float-delay: -0.9s;
}

.crew-08 {
  --x: 74%;
  --y: 76%;
  --bot-size: 100px;
  --float-delay: -3.8s;
}

.crew-robot-frame {
  position: relative;
  display: grid;
  place-items: center;
  width: calc(var(--bot-size) + 38px);
  aspect-ratio: 1;
}

.crew-orbit {
  position: absolute;
  left: 50%;
  top: 50%;
  width: calc(var(--bot-size) + 44px);
  aspect-ratio: 1;
  border: 1px solid rgb(155 223 255 / 0.13);
  border-radius: 50%;
  opacity: 0.5;
  transform: translate(-50%, -50%);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease;
}

.crew-robot {
  position: relative;
  z-index: 1;
  display: block;
  width: var(--bot-size);
  height: auto;
  filter:
    drop-shadow(0 0 18px color-mix(in srgb, var(--bot-accent) 28%, transparent))
    drop-shadow(0 20px 26px rgb(0 0 0 / 0.44));
  transition:
    filter 180ms ease,
    transform 180ms ease;
}

.crew-badge {
  position: absolute;
  left: 50%;
  top: 63%;
  z-index: 2;
  display: grid;
  place-items: center;
  min-width: 24px;
  height: 18px;
  padding: 0 5px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 52%, transparent);
  border-radius: 6px;
  background: rgb(3 9 16 / 0.76);
  color: rgb(255 255 255 / 0.9);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.06em;
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.16),
    0 0 18px color-mix(in srgb, var(--bot-accent) 24%, transparent);
  transform: translate(-50%, -50%);
}

.crew-signal {
  position: absolute;
  right: 2px;
  top: 26%;
  z-index: 2;
  display: grid;
  place-items: center;
  min-width: 28px;
  height: 22px;
  border: 1px solid color-mix(in srgb, var(--bot-accent) 34%, transparent);
  border-radius: 8px;
  background: rgb(3 9 16 / 0.72);
  color: color-mix(in srgb, var(--bot-accent) 78%, white);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 9px;
  font-weight: 900;
  box-shadow: 0 0 18px color-mix(in srgb, var(--bot-accent) 18%, transparent);
}

.crew-signal::before {
  content: "AI";
}

.tool-codex .crew-signal::before {
  content: "</>";
}

.tool-gemini .crew-signal::before {
  content: "2x";
}

.tool-remotion .crew-signal::before {
  content: "▶";
}

.tool-vscode .crew-signal::before {
  content: "{ }";
}

.tool-github .crew-signal::before {
  content: "↟";
}

.tool-capcut .crew-signal::before {
  content: "CUT";
}

.tool-canva .crew-signal::before {
  content: "▦";
}

.crew-label {
  display: grid;
  min-width: 96px;
  padding: 9px 11px;
  border: 1px solid rgb(155 223 255 / 0.16);
  border-radius: 8px;
  background: rgb(2 8 14 / 0.54);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.08),
    0 16px 34px rgb(0 0 0 / 0.22);
  backdrop-filter: blur(10px);
  text-align: center;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    box-shadow 180ms ease;
}

.crew-label strong {
  color: rgb(255 255 255 / 0.96);
  font-size: 17px;
  line-height: 1;
}

.crew-label small {
  color: color-mix(in srgb, var(--bot-accent) 72%, white);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
}

.workflow-bot:hover,
.workflow-bot:focus-visible,
.workflow-bot.is-active {
  filter: drop-shadow(0 0 24px color-mix(in srgb, var(--bot-accent) 32%, transparent));
  transform: translate(-50%, -50%) scale(1.08);
}

.workflow-bot:hover .crew-robot,
.workflow-bot:focus-visible .crew-robot,
.workflow-bot.is-active .crew-robot {
  filter:
    drop-shadow(0 0 26px color-mix(in srgb, var(--bot-accent) 48%, transparent))
    drop-shadow(0 22px 32px rgb(0 0 0 / 0.5));
  transform: translateY(-4px);
}

.workflow-bot:hover .crew-orbit,
.workflow-bot:focus-visible .crew-orbit,
.workflow-bot.is-active .crew-orbit {
  border-color: color-mix(in srgb, var(--bot-accent) 46%, transparent);
  box-shadow:
    0 0 28px color-mix(in srgb, var(--bot-accent) 22%, transparent),
    inset 0 0 28px color-mix(in srgb, var(--bot-accent) 12%, transparent);
  opacity: 0.9;
}

.workflow-bot:hover .crew-label,
.workflow-bot:focus-visible .crew-label,
.workflow-bot.is-active .crew-label {
  border-color: color-mix(in srgb, var(--bot-accent) 46%, transparent);
  background: rgb(3 12 22 / 0.68);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.12),
    0 0 28px color-mix(in srgb, var(--bot-accent) 14%, transparent),
    0 18px 38px rgb(0 0 0 / 0.28);
}

.workflow-bot:focus-visible {
  outline: 1px solid color-mix(in srgb, var(--bot-accent) 72%, white);
  outline-offset: 6px;
}

.section-ai.is-workflow-pulse .workflow-bot.is-active .crew-orbit {
  animation: workflowCrewPing 720ms ease;
}

.workflow-detail-card {
  position: absolute;
  left: 50%;
  bottom: clamp(34px, 6svh, 72px);
  z-index: 5;
  display: grid;
  gap: 9px;
  width: min(420px, 40vw);
  padding: 14px 16px;
  border: 1px solid color-mix(in srgb, var(--workflow-active-accent) 38%, transparent);
  border-radius: 8px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--workflow-active-accent) 12%, transparent), rgb(255 255 255 / 0.025)),
    rgb(2 8 14 / 0.72);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.1),
    0 0 32px color-mix(in srgb, var(--workflow-active-accent) 16%, transparent),
    0 22px 54px rgb(0 0 0 / 0.34);
  backdrop-filter: blur(16px);
  color: rgb(255 255 255 / 0.9);
  pointer-events: none;
  opacity: 0;
  transform: translateX(-50%) translateY(12px);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.workflow-detail-card::before {
  content: "能帮我做什么";
  color: color-mix(in srgb, var(--workflow-active-accent) 74%, white);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.14em;
}

body[data-language="en"] .workflow-detail-card::before {
  content: "What it helps me do";
}

.workflow-detail-card span {
  color: rgb(255 255 255 / 0.98);
  font-size: 24px;
  font-weight: 900;
  line-height: 1;
}

.workflow-detail-card p {
  margin: 0;
  color: rgb(255 255 255 / 0.7);
  font-size: 14px;
  line-height: 1.66;
}

.section-ai.is-workflow-detail-open .workflow-detail-card {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.section-ai.is-workflow-pulse.is-workflow-detail-open .workflow-detail-card {
  animation: workflowDetailIn 520ms ease;
}

.section-about {
  --about-focus-x: 50%;
  --about-focus-y: 46%;
  --about-focus-strength: 0;
  z-index: 38;
  overflow: hidden;
  min-height: 100svh;
  padding: 0;
  border-top: 0;
  background: transparent;
  transition: none;
}

.section-about.has-about-focus {
  --about-focus-strength: 1;
}

.section-about::before,
.section-about::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.section-about::before {
  display: none;
  opacity: 0;
  background: none;
  animation: none;
}

.section-about::after {
  display: none;
  opacity: 0;
  background: none;
  mix-blend-mode: normal;
  mask-image: none;
  animation: none;
}

.section-about > * {
  position: relative;
  z-index: 1;
}

.about-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 0.8fr);
  gap: clamp(28px, 6vw, 86px);
  align-items: center;
}

.about-copy {
  display: grid;
  gap: 22px;
}

.about-intro {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.45vw, 20px);
  line-height: 1.9;
}

.about-console {
  position: relative;
  min-height: 520px;
  display: grid;
  align-content: end;
}

.about-orbit {
  position: absolute;
  left: 50%;
  top: 16px;
  width: min(76vw, 340px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  transform: translateX(-50%);
}

.about-orbit span {
  position: absolute;
  border: 1px solid rgba(248, 242, 232, 0.22);
  border-radius: 50%;
}

.about-orbit span:first-child {
  width: 88%;
  height: 38%;
  transform: rotate(-18deg);
  animation: aboutOrbit 14s linear infinite;
}

.about-orbit span:nth-child(2) {
  width: 46%;
  height: 88%;
  border-style: dashed;
  animation: aboutOrbit 18s linear infinite reverse;
}

.about-orbit strong {
  display: grid;
  place-items: center;
  width: 132px;
  aspect-ratio: 1;
  border: 1px solid rgba(248, 242, 232, 0.42);
  border-radius: 50%;
  background:
    radial-gradient(circle at 34% 26%, rgba(255, 255, 255, 0.28), transparent 18%),
    linear-gradient(135deg, rgba(245, 216, 167, 0.13), rgba(155, 223, 255, 0.04));
  box-shadow:
    0 0 46px rgba(245, 216, 167, 0.16),
    inset 0 0 32px rgba(155, 223, 255, 0.08);
  font-size: 42px;
}

.about-tabs {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}

.about-tab {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.035);
  color: var(--muted);
  cursor: pointer;
  font-size: 14px;
  font-weight: 900;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.about-tab:hover,
.about-tab.is-active {
  border-color: rgba(155, 223, 255, 0.5);
  background: rgba(155, 223, 255, 0.1);
  color: var(--ink);
  transform: translateY(-1px);
}

.about-card {
  position: relative;
  z-index: 2;
  min-height: 260px;
  padding: clamp(20px, 3vw, 30px);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(3, 3, 3, 0.58);
  backdrop-filter: blur(18px);
  box-shadow:
    0 26px 100px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.about-card-kicker {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-card h3 {
  margin: 0 0 16px;
  font-size: clamp(25px, 3vw, 38px);
  line-height: 1.15;
}

.about-card p:last-child {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.9;
}

.section-about > .about-shell:not(.about-shell-v2) {
  display: none;
}

.about-shell-v2 {
  grid-template-columns: minmax(0, 0.9fr) minmax(420px, 0.95fr);
}

.about-shell-v2 .about-copy h2 {
  max-width: 760px;
  font-size: clamp(38px, 4.3vw, 68px);
  line-height: 1.08;
}

.about-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 680px;
}

.about-metrics span {
  display: inline-grid;
  place-items: center;
  min-height: 34px;
  padding: 0 12px;
  border: 1px solid rgba(248, 242, 232, 0.13);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.035);
  color: rgba(248, 242, 232, 0.74);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.about-console-v2 {
  isolation: isolate;
  min-height: 640px;
  align-content: stretch;
  grid-template-rows: auto minmax(350px, 1fr) auto;
  gap: 18px;
  padding: clamp(14px, 2vw, 20px);
}

.about-console-v2::before,
.about-console-v2::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: 8px;
  pointer-events: none;
}

.about-console-v2::before {
  border: 1px solid rgba(248, 242, 232, 0.12);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.055), transparent 26%),
    radial-gradient(circle at 50% 38%, rgba(155, 223, 255, 0.1), transparent 290px),
    radial-gradient(circle at 22% 70%, rgba(245, 216, 167, 0.1), transparent 220px),
    rgba(3, 3, 3, 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 32px 90px rgba(0, 0, 0, 0.28);
}

.about-console-v2::after {
  opacity: 0.18;
  background-image:
    linear-gradient(rgba(248, 242, 232, 0.16) 1px, transparent 1px),
    linear-gradient(90deg, rgba(248, 242, 232, 0.16) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: radial-gradient(circle at 50% 46%, #000 0 46%, transparent 78%);
}

.about-panel-head {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 34px;
  color: rgba(248, 242, 232, 0.58);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.about-panel-head strong {
  color: rgba(155, 223, 255, 0.86);
}

.about-constellation {
  position: relative;
  z-index: 2;
  min-height: 360px;
}

.about-core {
  position: absolute;
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  width: 132px;
  aspect-ratio: 1;
  border: 1px solid rgba(248, 242, 232, 0.38);
  border-radius: 50%;
  background:
    radial-gradient(circle at 36% 28%, rgba(255, 255, 255, 0.24), transparent 18%),
    linear-gradient(135deg, rgba(245, 216, 167, 0.16), rgba(155, 223, 255, 0.05));
  box-shadow:
    0 0 42px rgba(245, 216, 167, 0.14),
    inset 0 0 32px rgba(155, 223, 255, 0.08);
  transform: translate(-50%, -50%);
  animation: aboutCorePulse 3.8s ease-in-out infinite;
}

.about-core strong {
  font-size: 38px;
  line-height: 1;
}

.about-core span {
  margin-top: -28px;
  color: rgba(248, 242, 232, 0.5);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-ring {
  position: absolute;
  left: 50%;
  top: 50%;
  border: 1px solid rgba(248, 242, 232, 0.15);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.about-ring-one {
  width: 72%;
  height: 34%;
  animation: aboutOrbit 16s linear infinite;
}

.about-ring-two {
  width: 42%;
  height: 78%;
  border-style: dashed;
  animation: aboutOrbit 22s linear infinite reverse;
}

.about-link {
  position: absolute;
  left: 50%;
  top: 50%;
  height: 1px;
  width: 32%;
  background: linear-gradient(90deg, rgba(248, 242, 232, 0.28), transparent);
  transform-origin: left center;
}

.about-link-one {
  transform: rotate(206deg);
}

.about-link-two {
  transform: rotate(-28deg);
}

.about-link-three {
  transform: rotate(150deg);
}

.about-link-four {
  transform: rotate(32deg);
}

.about-node {
  position: absolute;
  z-index: 2;
  width: min(190px, 42%);
  min-height: 96px;
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 14px 14px 14px 34px;
  border: 1px solid rgba(248, 242, 232, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.02)),
    rgba(3, 3, 3, 0.5);
  color: var(--ink);
  text-align: left;
  cursor: pointer;
  backdrop-filter: blur(18px);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition:
    border-color 180ms ease,
    background 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.about-node::before {
  content: "";
  position: absolute;
  left: 14px;
  top: 21px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(245, 216, 167, 0.82);
  box-shadow: 0 0 16px rgba(245, 216, 167, 0.5);
}

.about-node::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  border: 1px solid rgba(155, 223, 255, 0);
  opacity: 0;
}

.about-node span {
  color: rgba(248, 242, 232, 0.44);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.about-node strong {
  font-size: 16px;
  line-height: 1.2;
}

.about-node small {
  color: rgba(248, 242, 232, 0.58);
  font-size: 12px;
  line-height: 1.45;
}

.about-node:hover,
.about-node.is-active {
  border-color: rgba(155, 223, 255, 0.56);
  background:
    linear-gradient(135deg, rgba(155, 223, 255, 0.13), rgba(245, 216, 167, 0.06)),
    rgba(3, 3, 3, 0.64);
  box-shadow:
    0 0 28px rgba(155, 223, 255, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.1);
  transform: translateY(-2px);
}

.about-node.is-active::after {
  border-color: rgba(155, 223, 255, 0.46);
  opacity: 1;
  animation: aboutNodeScan 1.35s ease-in-out infinite;
}

.about-node-identity {
  left: 2%;
  top: 14%;
}

.about-node-building {
  right: 2%;
  top: 13%;
}

.about-node-method {
  left: 8%;
  bottom: 9%;
}

.about-node-status {
  right: 8%;
  bottom: 8%;
}

.about-card-v2 {
  min-height: 232px;
  background:
    linear-gradient(180deg, rgba(7, 7, 7, 0.78), rgba(3, 3, 3, 0.68)),
    rgba(3, 3, 3, 0.58);
}

.about-console-v2.is-scanning .about-card-v2 {
  animation: aboutPanelFlash 680ms ease;
}

.about-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.about-card-meta span {
  min-height: 28px;
  display: inline-grid;
  place-items: center;
  padding: 0 10px;
  border: 1px solid rgba(248, 242, 232, 0.1);
  border-radius: 999px;
  color: rgba(248, 242, 232, 0.52);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.section-about > .about-shell:not(.about-shell-v3) {
  display: none;
}

.section-about > .about-shell.about-shell-v3 {
  display: grid;
}

.about-shell-v3 {
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
  align-content: stretch;
  min-height: 100svh;
}

.about-keyword-head {
  position: absolute;
  left: 50%;
  top: clamp(58px, 8.5vh, 96px);
  z-index: 6;
  display: grid;
  justify-items: center;
  gap: 0;
  text-align: center;
  transform: translateX(-50%);
}

.about-keyword-head h2 {
  margin: 0;
  color: rgba(248, 242, 232, 0.98);
  font-size: clamp(54px, 6.8vw, 94px);
  line-height: 0.9;
  letter-spacing: 0;
  text-transform: uppercase;
  text-shadow:
    0 10px 28px rgba(0, 0, 0, 0.62),
    0 0 22px rgba(245, 216, 167, 0.12);
}

.about-keyword-head .section-kicker,
.about-keyword-head p:last-child {
  display: none;
}

.about-console-v3 {
  position: relative;
  isolation: isolate;
  min-height: 100svh;
}

.about-console-v3::before {
  content: "";
  position: absolute;
  inset: -16% -8% -10%;
  z-index: -2;
  background:
    radial-gradient(circle at var(--about-focus-x) var(--about-focus-y), rgb(245 216 167 / calc(0.03 + var(--about-focus-strength) * 0.055)), transparent 300px),
    radial-gradient(ellipse 58% 54% at 50% 38%, rgba(248, 242, 232, 0.055), transparent 72%);
  pointer-events: none;
}

.about-console-v3::after {
  content: "";
  position: absolute;
  inset: -4% -2%;
  z-index: -1;
  opacity: 0.3;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.2) 0 0.8px, transparent 1.7px),
    radial-gradient(circle, rgba(155, 223, 255, 0.12) 0 0.7px, transparent 1.6px),
    linear-gradient(101deg, transparent 0 45%, rgba(248, 242, 232, 0.055) 45.08% 45.16%, transparent 45.28%),
    linear-gradient(73deg, transparent 0 56%, rgba(155, 223, 255, 0.05) 56.08% 56.16%, transparent 56.3%);
  background-size:
    30px 30px,
    60px 60px,
    100% 100%,
    100% 100%;
  background-position:
    0 0,
    15px 19px,
    0 0,
    0 0;
  mask-image: radial-gradient(ellipse 76% 58% at 50% 50%, #000 0 62%, transparent 90%);
  pointer-events: none;
  transition:
    opacity 240ms ease;
}

.about-console-v3.has-active::after {
  opacity: 0.38;
}

.about-keyword-field {
  position: relative;
  min-height: 100svh;
}

.about-letter-cloud,
.about-core-v3,
.about-keyword-field > .about-ring {
  display: none;
}

.about-letter-cloud {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.9;
  pointer-events: none;
}

.about-letter-cloud span {
  position: absolute;
  color: rgba(248, 242, 232, 0.105);
  font-size: clamp(88px, 11vw, 178px);
  font-weight: 950;
  line-height: 1;
  text-transform: uppercase;
  filter: blur(0.1px);
  text-shadow:
    0 0 34px rgba(155, 223, 255, 0.16),
    0 0 90px rgba(248, 242, 232, 0.045);
}

.letter-i {
  left: 16%;
  top: 10%;
}

.letter-m-one {
  right: 19%;
  top: 8%;
}

.letter-m-two {
  left: 20%;
  top: 38%;
}

.letter-o {
  right: 14%;
  top: 38%;
}

.letter-r {
  left: 18%;
  bottom: 7%;
}

.letter-t {
  right: 18%;
  bottom: 8%;
}

.about-core-v3 {
  left: 50%;
  top: 50%;
  display: grid;
  place-items: center;
  z-index: 1;
  width: clamp(34px, 4vw, 58px);
  border-color: rgba(155, 223, 255, 0.16);
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.34) 0 7%, rgba(155, 223, 255, 0.18) 8% 18%, transparent 20%),
    radial-gradient(circle, rgba(155, 223, 255, 0.09), transparent 68%);
  box-shadow:
    0 0 42px rgba(155, 223, 255, 0.12),
    inset 0 0 22px rgba(155, 223, 255, 0.06);
  opacity: 0.72;
  transform: none;
  translate: -50% -50%;
  animation: aboutCorePulse 3.8s ease-in-out infinite;
}

.about-core-v3::before,
.about-core-v3::after {
  content: "";
  position: absolute;
  inset: -220%;
  border: 1px solid rgba(155, 223, 255, 0.08);
  border-radius: inherit;
  pointer-events: none;
}

.about-core-v3::before {
  background:
    conic-gradient(from 112deg, transparent 0 28%, rgba(155, 223, 255, 0.12) 34%, rgba(248, 242, 232, 0.08) 40%, transparent 52% 100%);
  filter: blur(0.1px);
  opacity: 0.38;
  transform: rotate(-14deg) scaleY(0.3);
  animation: aboutDiskSpin 7.8s linear infinite reverse;
}

.about-core-v3::after {
  inset: -380%;
  border: 1px solid rgba(248, 242, 232, 0.045);
  background:
    radial-gradient(circle, rgba(155, 223, 255, 0.05), transparent 56%);
  box-shadow: 0 0 28px rgba(155, 223, 255, 0.08);
  opacity: 0.42;
}

.about-core-v3 strong,
.about-core-v3 span {
  display: none;
}

.about-keyword-field > .about-ring {
  z-index: 1;
  border-color: rgba(155, 223, 255, 0.2);
  box-shadow:
    0 0 26px rgba(155, 223, 255, 0.06),
    inset 0 0 24px rgba(248, 242, 232, 0.035);
}

.about-keyword-field > .about-ring-two {
  border-color: rgba(248, 242, 232, 0.16);
}

.section-about .about-console-v3::before,
.section-about .about-console-v3::after,
.section-about .about-letter-cloud,
.section-about .about-core,
.section-about .about-keyword-field > .about-ring,
.section-about .about-keyword-detail {
  display: none !important;
}

.keyword-node {
  position: absolute;
  z-index: 5;
  display: grid;
  gap: 0;
  min-width: clamp(160px, 18vw, 260px);
  padding: 10px 0 12px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: rgba(248, 242, 232, 0.74);
  text-align: left;
  cursor: default;
  letter-spacing: 0;
  pointer-events: none;
  transition:
    color 180ms ease,
    opacity 180ms ease,
    transform 180ms ease;
}

.keyword-node.about-tab,
.keyword-node.about-tab:hover,
.keyword-node.about-tab.is-active {
  min-height: 0;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.keyword-node::before {
  display: none;
}

.keyword-node::after {
  display: none;
}

.keyword-node span {
  display: none;
  color: rgba(155, 223, 255, 0.62);
  font-size: 10px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.keyword-node strong {
  max-width: 10ch;
  font-size: clamp(30px, 3vw, 48px);
  line-height: 0.98;
  text-shadow:
    0 5px 16px rgba(0, 0, 0, 0.86),
    0 0 18px rgba(248, 242, 232, 0.12);
}

.keyword-node:hover,
.keyword-node.is-active {
  color: rgba(248, 242, 232, 0.98);
  opacity: 1;
  transform: translateY(-4px);
}

.keyword-node:hover span,
.keyword-node.is-active span {
  color: rgba(245, 216, 167, 0.82);
}

.keyword-node:hover::before,
.keyword-node.is-active::before {
  border-color: rgba(245, 216, 167, 0.72);
  box-shadow:
    0 0 22px rgba(245, 216, 167, 0.3),
    0 0 28px rgba(155, 223, 255, 0.12),
    inset 0 0 10px rgba(245, 216, 167, 0.16);
}

.keyword-node:hover::after,
.keyword-node.is-active::after {
  background: linear-gradient(90deg, rgba(245, 216, 167, 0.48), rgba(155, 223, 255, 0.18), transparent);
  opacity: 0.86;
}

.keyword-ai,
.keyword-content,
.keyword-explorer {
  justify-items: end;
  text-align: right;
}

.keyword-ai::before,
.keyword-content::before,
.keyword-explorer::before {
  right: auto;
  left: -18px;
}

.keyword-ai::after,
.keyword-content::after,
.keyword-explorer::after {
  right: auto;
  left: -102px;
  background: linear-gradient(270deg, rgba(155, 223, 255, 0.34), transparent);
}

.keyword-ai:hover::after,
.keyword-ai.is-active::after,
.keyword-content:hover::after,
.keyword-content.is-active::after,
.keyword-explorer:hover::after,
.keyword-explorer.is-active::after {
  background: linear-gradient(270deg, rgba(245, 216, 167, 0.48), rgba(155, 223, 255, 0.18), transparent);
}

.keyword-taste {
  left: clamp(34px, 9vw, 132px);
  top: 30%;
}

.keyword-ai {
  right: clamp(34px, 9vw, 132px);
  top: 37%;
}

.keyword-project {
  left: clamp(34px, 9vw, 132px);
  top: 49%;
}

.keyword-content {
  right: clamp(34px, 9vw, 132px);
  top: 49%;
}

.keyword-long {
  left: clamp(34px, 9vw, 132px);
  top: 68%;
  bottom: auto;
}

.keyword-explorer {
  right: clamp(34px, 9vw, 132px);
  top: 68%;
  bottom: auto;
}

.about-keyword-detail {
  position: absolute;
  left: 50%;
  top: auto;
  bottom: clamp(34px, 7vh, 74px);
  z-index: 4;
  display: grid;
  gap: 10px;
  justify-items: start;
  width: min(520px, 38vw);
  min-height: 112px;
  padding: 16px 18px;
  border: 1px solid rgba(248, 242, 232, 0.14);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(248, 242, 232, 0.07), transparent 42%),
    rgba(3, 3, 3, 0.34);
  opacity: 0;
  pointer-events: none;
  text-align: left;
  backdrop-filter: blur(18px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 20px 64px rgba(0, 0, 0, 0.3);
  transform: translate(-50%, 12px);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
}

.about-keyword-detail::before {
  content: "";
  position: absolute;
  left: -1px;
  top: 12px;
  width: 1px;
  height: calc(100% - 24px);
  background: linear-gradient(180deg, transparent, rgba(245, 216, 167, 0.64), rgba(248, 242, 232, 0.18), transparent);
  box-shadow: 0 0 16px rgba(245, 216, 167, 0.36);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 360ms ease;
}

.about-console-v3.has-active .about-keyword-detail {
  opacity: 1;
  transform: translate(-50%, 0);
}

.about-console-v3.has-active .about-keyword-detail::before {
  transform: scaleY(1);
}

.about-keyword-detail .about-card-kicker {
  display: none;
  margin: 0;
  color: rgba(155, 223, 255, 0.68);
  font-size: 10px;
  letter-spacing: 0.14em;
}

.about-keyword-detail h3 {
  display: block;
  margin: 0;
  color: rgba(248, 242, 232, 0.98);
  font-size: clamp(20px, 1.6vw, 28px);
  line-height: 1.05;
}

.about-keyword-detail p:last-of-type {
  max-width: 100%;
  margin: 0;
  color: rgba(248, 242, 232, 0.78);
  font-size: clamp(14px, 0.98vw, 16px);
  line-height: 1.72;
  text-shadow: 0 0 18px rgba(245, 216, 167, 0.12);
}

.about-keyword-detail p:last-of-type::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 1em;
  margin-left: 6px;
  border-right: 1px solid rgba(245, 216, 167, 0.68);
  transform: translateY(2px);
  animation: noteCursorBlink 920ms steps(2, start) infinite;
}

.about-keyword-detail > span {
  display: none;
  min-height: 24px;
  align-items: center;
  margin-top: 2px;
  padding: 0 9px;
  border: 1px solid rgba(248, 242, 232, 0.12);
  border-radius: 999px;
  color: rgba(245, 216, 167, 0.72);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.about-console-v3.is-scanning .about-keyword-detail {
  animation: aboutNoteIn 520ms ease both;
}

.about-console-v3.is-scanning .about-keyword-detail p:last-of-type {
  animation: aboutTextReveal 620ms steps(18, end) both;
}

.section-contact {
  background:
    radial-gradient(ellipse 58% 46% at 26% 48%, rgba(155, 223, 255, 0.075), transparent 70%),
    radial-gradient(ellipse 56% 42% at 78% 62%, rgba(248, 242, 232, 0.055), transparent 72%),
    linear-gradient(180deg, rgba(7, 7, 6, 0.93), rgba(3, 3, 3, 0.98));
}

.contact-dock {
  position: relative;
  display: grid;
  grid-template-columns: minmax(420px, 0.92fr) minmax(520px, 1fr);
  gap: clamp(28px, 4vw, 58px);
  align-items: center;
  width: min(1180px, 84vw);
  margin: 0 auto;
}

.contact-dock::before {
  content: "";
  position: absolute;
  left: 42%;
  top: 50%;
  z-index: 0;
  width: 52vw;
  max-width: 760px;
  aspect-ratio: 1;
  border: 1px solid rgba(155, 223, 255, 0.08);
  border-radius: 50%;
  pointer-events: none;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.1) 0 1px, transparent 2px),
    radial-gradient(circle at 50% 50%, transparent 0 48%, rgba(155, 223, 255, 0.13) 48.2% 48.6%, transparent 49.3%),
    radial-gradient(circle at 50% 50%, transparent 0 68%, rgba(248, 242, 232, 0.09) 68.2% 68.5%, transparent 69%);
  background-size: 18px 18px, 100% 100%, 100% 100%;
  opacity: 0.46;
  transform: translate(-50%, -50%);
  animation: workflowOrbitSpin 28s linear infinite;
}

.contact-visual,
.contact-terminal {
  position: relative;
  z-index: 1;
}

.contact-visual {
  display: grid;
  gap: 16px;
  align-content: center;
}

.contact-portrait-frame {
  position: relative;
  overflow: hidden;
  min-height: min(660px, 70vh);
  border: 1px solid rgba(248, 242, 232, 0.12);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 35%, rgba(155, 223, 255, 0.08), transparent 38%),
    rgba(3, 3, 3, 0.54);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 28px 90px rgba(0, 0, 0, 0.34);
}

.contact-portrait-frame::before,
.contact-portrait-frame::after {
  content: "";
  position: relative;
}

.contact-portrait-frame::before {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(3, 3, 3, 0.18), transparent 34%, rgba(3, 3, 3, 0.74)),
    linear-gradient(90deg, rgba(155, 223, 255, 0.1), transparent 26%, transparent 76%, rgba(155, 223, 255, 0.08));
}

.contact-portrait-frame::after {
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 16%;
  z-index: 3;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.52), rgba(248, 242, 232, 0.24), transparent);
  opacity: 0.76;
}

.contact-portrait-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 38%;
  opacity: 0.78;
  filter: saturate(0.8) contrast(1.08) brightness(0.76);
  transform: scale(1.08);
}

.contact-scan-line {
  position: absolute;
  left: -20%;
  right: -20%;
  top: 34%;
  z-index: 4;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.75), transparent);
  box-shadow: 0 0 22px rgba(155, 223, 255, 0.42);
  animation: contactScan 4.8s ease-in-out infinite;
}

.contact-visual-caption {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: rgba(248, 242, 232, 0.7);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.contact-visual-caption span {
  color: rgba(155, 223, 255, 0.7);
}

.contact-terminal {
  display: grid;
  gap: 18px;
  padding: clamp(22px, 2.6vw, 34px);
  border: 1px solid rgba(248, 242, 232, 0.12);
  border-radius: 8px;
  background:
    radial-gradient(circle at 88% 12%, rgba(155, 223, 255, 0.075), transparent 160px),
    linear-gradient(135deg, rgba(248, 242, 232, 0.07), rgba(255, 255, 255, 0.012)),
    rgba(3, 3, 3, 0.56);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 28px 90px rgba(0, 0, 0, 0.32);
  backdrop-filter: blur(18px);
}

.contact-terminal::before {
  content: "";
  position: absolute;
  left: 24px;
  right: 24px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(155, 223, 255, 0.52), rgba(248, 242, 232, 0.16), transparent);
}

.contact-terminal-head {
  display: grid;
  gap: 14px;
}

.contact-terminal-head h2 {
  margin: 0;
  max-width: 100%;
  color: rgba(248, 242, 232, 0.98);
  font-size: clamp(54px, 5.6vw, 86px);
  line-height: 0.88;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  text-shadow:
    0 0 28px rgba(155, 223, 255, 0.12),
    0 22px 70px rgba(0, 0, 0, 0.34);
}

.contact-terminal-head .section-lead {
  max-width: 58ch;
  margin: -4px 0 0;
}

.contact-channel,
.platform-card {
  color: var(--ink);
  text-decoration: none;
}

.contact-channel-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.contact-channel {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 8px;
  min-height: 118px;
  padding: 16px;
  border: 1px solid rgba(248, 242, 232, 0.1);
  border-radius: 8px;
  background:
    radial-gradient(circle at 90% 18%, rgba(155, 223, 255, 0.08), transparent 88px),
    linear-gradient(145deg, rgba(248, 242, 232, 0.052), rgba(255, 255, 255, 0.012)),
    rgba(0, 0, 0, 0.24);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.contact-channel::before {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(155, 223, 255, 0.44), transparent);
  opacity: 0.48;
}

.contact-channel span,
.platform-card span,
.contact-footer {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.contact-channel strong,
.platform-card strong {
  font-size: 15px;
}

.contact-channel strong {
  color: rgba(248, 242, 232, 0.96);
  font-size: clamp(17px, 1.5vw, 22px);
  line-height: 1.12;
}

.contact-channel em {
  align-self: end;
  color: rgba(155, 223, 255, 0.56);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.media-account-console {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(248, 242, 232, 0.1);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(155, 223, 255, 0.052), rgba(255, 255, 255, 0.012)),
    rgba(0, 0, 0, 0.26);
}

.media-console-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(248, 242, 232, 0.08);
}

.media-console-head span,
.media-console-head strong {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.media-console-head span {
  color: rgba(155, 223, 255, 0.7);
}

.media-console-head strong {
  color: rgba(248, 242, 232, 0.66);
  text-align: right;
}

.media-account-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.media-account-grid span {
  display: grid;
  place-items: center;
  min-height: 42px;
  border: 1px solid rgba(248, 242, 232, 0.08);
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 0, rgba(155, 223, 255, 0.06), transparent 70%),
    rgba(3, 3, 3, 0.26);
  color: rgba(248, 242, 232, 0.72);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  transition:
    border-color 180ms ease,
    color 180ms ease,
    transform 180ms ease;
}

.contact-channel:hover {
  border-color: rgba(155, 223, 255, 0.34);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 0 38px rgba(155, 223, 255, 0.08),
    0 24px 82px rgba(0, 0, 0, 0.28);
  transform: translateY(-3px);
}

.media-account-grid span:hover {
  border-color: rgba(155, 223, 255, 0.28);
  color: rgba(248, 242, 232, 0.96);
  transform: translateY(-2px);
}

.contact-footer {
  width: min(1180px, 84vw);
  margin: 22px auto 0;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
}

.contact-hero-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 126%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.68;
  filter: saturate(0.78) contrast(1.08) brightness(0.58);
  transform: translateX(-33vw) scale(1.14);
  transform-origin: center;
  pointer-events: none;
}

.section-contact {
  min-height: 100svh;
  align-content: center;
  background:
    radial-gradient(ellipse 44% 48% at 30% 54%, rgba(155, 223, 255, 0.12), transparent 70%),
    radial-gradient(ellipse 46% 48% at 82% 54%, rgba(3, 3, 3, 0.5), transparent 72%),
    linear-gradient(180deg, rgba(2, 2, 2, 0.94), rgba(3, 3, 3, 0.98));
}

.section-contact::before {
  z-index: 1;
  opacity: 0.26;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.18) 0 0.8px, transparent 1.7px),
    radial-gradient(circle, rgba(155, 223, 255, 0.12) 0 0.7px, transparent 1.6px);
  background-size: 30px 30px, 60px 60px;
  background-position: 0 0, 15px 18px;
}

.section-contact::after {
  z-index: 1;
  opacity: 0.62;
  background:
    linear-gradient(90deg, rgba(3, 3, 3, 0.14), transparent 26%, rgba(3, 3, 3, 0.54) 62%, rgba(3, 3, 3, 0.9) 100%),
    linear-gradient(180deg, rgba(3, 3, 3, 0.44), transparent 24%, rgba(3, 3, 3, 0.7) 100%);
  mix-blend-mode: normal;
}

.section-contact > :not(.contact-hero-backdrop) {
  z-index: 2;
}

.contact-dock {
  grid-template-columns: minmax(380px, 0.76fr) minmax(520px, 560px);
  gap: clamp(34px, 5vw, 88px);
  width: min(1180px, 84vw);
  min-height: min(680px, 72vh);
}

.contact-dock::before {
  left: 34%;
  top: 55%;
  width: min(680px, 48vw);
  opacity: 0.24;
}

.contact-visual {
  min-height: min(640px, 68vh);
  align-content: end;
  overflow: visible;
  padding-bottom: clamp(18px, 3vw, 44px);
}

.contact-avatar-node {
  position: absolute;
  left: 68%;
  top: 50%;
  width: 13px;
  height: 13px;
  border: 1px solid rgba(155, 223, 255, 0.76);
  border-radius: 50%;
  background: rgba(248, 242, 232, 0.88);
  box-shadow:
    0 0 18px rgba(155, 223, 255, 0.55),
    0 0 44px rgba(155, 223, 255, 0.18);
}

.contact-avatar-node::before,
.contact-avatar-node::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.contact-avatar-node::before {
  inset: -12px;
  border: 1px solid rgba(155, 223, 255, 0.22);
}

.contact-avatar-node::after {
  inset: -26px;
  border: 1px solid rgba(155, 223, 255, 0.1);
}

.contact-signal-line {
  position: absolute;
  left: calc(68% + 16px);
  right: calc(-1 * clamp(34px, 5vw, 88px) - 18px);
  top: calc(50% + 1px);
  height: 1px;
  background:
    linear-gradient(90deg, rgba(155, 223, 255, 0.78), rgba(248, 242, 232, 0.42) 46%, rgba(155, 223, 255, 0.12) 82%, transparent);
  box-shadow: 0 0 18px rgba(155, 223, 255, 0.24);
}

.contact-signal-line::before {
  content: "";
  position: absolute;
  left: 0;
  top: -2px;
  width: 46px;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.9), transparent);
  filter: blur(0.3px);
  animation: contactSignalPulse 3.2s ease-in-out infinite;
}

.contact-visual-caption {
  position: absolute;
  left: calc(68% + 34px);
  top: calc(50% - 54px);
  display: grid;
  gap: 4px;
  width: min(218px, 64%);
  margin-left: 0;
  padding: 10px 12px 10px 16px;
  border-left: 1px solid rgba(155, 223, 255, 0.54);
  background:
    linear-gradient(90deg, rgba(155, 223, 255, 0.12), rgba(0, 0, 0, 0.02)),
    linear-gradient(180deg, rgba(248, 242, 232, 0.035), transparent);
  clip-path: polygon(0 0, calc(100% - 11px) 0, 100% 11px, 100% 100%, 0 100%);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-shadow: 0 0 14px rgba(155, 223, 255, 0.18);
}

.contact-terminal {
  align-self: center;
  isolation: isolate;
  max-width: 580px;
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
  background:
    radial-gradient(circle at 0 50%, rgba(155, 223, 255, 0.13), transparent 190px),
    radial-gradient(circle at 92% 8%, rgba(155, 223, 255, 0.1), transparent 170px),
    linear-gradient(90deg, rgba(155, 223, 255, 0.06), transparent 2px 28px, rgba(248, 242, 232, 0.016) 28px 29px, transparent 29px),
    linear-gradient(160deg, rgba(155, 223, 255, 0.07), transparent 36%),
    linear-gradient(135deg, rgba(248, 242, 232, 0.07), rgba(255, 255, 255, 0.012)),
    rgba(3, 3, 3, 0.68);
  background-size: auto, auto, 56px 100%, auto, auto, auto;
  border-color: rgba(155, 223, 255, 0.18);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    inset 0 0 0 1px rgba(155, 223, 255, 0.035),
    0 0 0 1px rgba(0, 0, 0, 0.5),
    0 34px 100px rgba(0, 0, 0, 0.42),
    0 0 72px rgba(155, 223, 255, 0.055);
}

.contact-visual-caption::before {
  content: "";
  position: absolute;
  left: -36px;
  top: 50%;
  width: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.62));
  box-shadow: 0 0 14px rgba(155, 223, 255, 0.24);
}

.contact-visual-caption::after {
  content: "";
  position: absolute;
  left: -3px;
  top: calc(50% - 3px);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(155, 223, 255, 0.84);
  box-shadow: 0 0 16px rgba(155, 223, 255, 0.46);
}

.contact-terminal::before {
  content: "";
  position: absolute;
  inset: 12px;
  z-index: 0;
  border: 1px solid rgba(155, 223, 255, 0.055);
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  background:
    linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.035), transparent),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), transparent 28%);
  pointer-events: none;
}

.contact-terminal::after {
  content: "";
  position: absolute;
  left: -18px;
  top: calc(50% - 6px);
  width: 12px;
  height: 12px;
  border: 1px solid rgba(155, 223, 255, 0.42);
  border-radius: 50%;
  background: rgba(3, 3, 3, 0.86);
  box-shadow: 0 0 20px rgba(155, 223, 255, 0.18);
}

.contact-visual-caption span {
  color: rgba(155, 223, 255, 0.76);
}

.contact-visual-caption strong {
  color: rgba(248, 242, 232, 0.66);
  font-size: 10px;
  letter-spacing: 0.12em;
}

.contact-terminal-head {
  position: relative;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(248, 242, 232, 0.08);
}

.contact-terminal-head::before,
.contact-terminal-head::after {
  content: "";
  position: absolute;
  bottom: -1px;
  width: 54px;
  height: 1px;
  background: rgba(155, 223, 255, 0.46);
  box-shadow: 0 0 18px rgba(155, 223, 255, 0.18);
}

.contact-terminal-head::before {
  left: 0;
}

.contact-terminal-head::after {
  right: 0;
}

.contact-channel-list {
  position: relative;
  counter-reset: contactChannel;
}

.contact-channel-list::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 10px;
  bottom: 10px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(155, 223, 255, 0.34), transparent);
}

.contact-channel {
  counter-increment: contactChannel;
  background:
    radial-gradient(circle at 86% 22%, rgba(155, 223, 255, 0.12), transparent 78px),
    linear-gradient(90deg, rgba(155, 223, 255, 0.07), transparent 32%),
    linear-gradient(145deg, rgba(248, 242, 232, 0.064), rgba(255, 255, 255, 0.012)),
    rgba(0, 0, 0, 0.24);
  border-color: rgba(155, 223, 255, 0.12);
  border-radius: 0;
  clip-path: polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
}

.contact-channel::before {
  content: "0" counter(contactChannel);
  position: absolute;
  right: 15px;
  bottom: 13px;
  left: auto;
  top: auto;
  width: auto;
  height: auto;
  background: transparent;
  color: rgba(155, 223, 255, 0.42);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.12em;
  opacity: 1;
}

.contact-channel::after {
  content: "";
  position: absolute;
  right: 14px;
  top: 14px;
  width: 34px;
  aspect-ratio: 1;
  border: 1px solid rgba(155, 223, 255, 0.14);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.16) 0 1px, transparent 2px),
    radial-gradient(circle at 50% 50%, transparent 0 54%, rgba(155, 223, 255, 0.18) 55% 57%, transparent 60%);
  background-size: 8px 8px, 100% 100%;
  opacity: 0.5;
}

.media-account-console {
  position: relative;
  overflow: hidden;
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 0 100%);
  background:
    radial-gradient(circle at 96% 0, rgba(155, 223, 255, 0.105), transparent 128px),
    linear-gradient(135deg, rgba(155, 223, 255, 0.064), rgba(255, 255, 255, 0.012)),
    rgba(0, 0, 0, 0.26);
  border-color: rgba(155, 223, 255, 0.12);
}

.media-account-console::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0 38%, rgba(155, 223, 255, 0.055) 38.2% 38.5%, transparent 39%),
    linear-gradient(180deg, transparent 0 56%, rgba(248, 242, 232, 0.04) 56.2% 56.4%, transparent 57%);
  opacity: 0.72;
}

.media-account-grid span {
  border-radius: 0;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 0 100%);
  background:
    radial-gradient(circle at 50% 0, rgba(155, 223, 255, 0.09), transparent 72%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent),
    rgba(3, 3, 3, 0.3);
}

.contact-footer {
  position: absolute;
  left: clamp(42px, 9vw, 130px);
  right: clamp(42px, 9vw, 130px);
  bottom: clamp(28px, 4vw, 54px);
  z-index: 3;
  width: auto;
  margin: 0;
  padding-top: 0;
  border-top: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(64px, 0.18fr) minmax(0, 1fr);
  align-items: center;
}

.contact-footer::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -15px;
  height: 1px;
  background:
    linear-gradient(90deg, rgba(155, 223, 255, 0.42), rgba(248, 242, 232, 0.13) 20%, transparent 43%, transparent 57%, rgba(248, 242, 232, 0.13) 80%, rgba(155, 223, 255, 0.34));
  opacity: 0.88;
}

.contact-footer::after {
  content: "";
  position: absolute;
  left: 50%;
  top: -18px;
  width: 78px;
  height: 7px;
  border-top: 1px solid rgba(155, 223, 255, 0.28);
  border-bottom: 1px solid rgba(155, 223, 255, 0.12);
  transform: translateX(-50%);
  background:
    linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.18), transparent);
}

.contact-footer span {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 32px;
  padding: 0 0 9px;
  color: rgba(248, 242, 232, 0.68);
}

.contact-footer span:first-child {
  justify-self: start;
  grid-column: 1;
}

.contact-footer span:last-child {
  justify-self: end;
  grid-column: 3;
}

.contact-footer span::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(155, 223, 255, 0.72);
  box-shadow: 0 0 14px rgba(155, 223, 255, 0.32);
}

.contact-footer span::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 2px;
  width: min(180px, 100%);
  background: linear-gradient(90deg, rgba(155, 223, 255, 0.64), rgba(248, 242, 232, 0.18), transparent);
  box-shadow: 0 0 16px rgba(155, 223, 255, 0.16);
}

.contact-footer span:first-child::after {
  left: 0;
}

.contact-footer span:last-child::after {
  right: 0;
  background: linear-gradient(270deg, rgba(155, 223, 255, 0.64), rgba(248, 242, 232, 0.18), transparent);
}

.contact-line-terminal {
  align-self: center;
  display: grid;
  gap: 24px;
  max-width: 640px;
  padding: 0 0 0 clamp(18px, 2.4vw, 32px);
  border: 0;
  border-radius: 0;
  clip-path: none;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  transform: translateY(62px);
}

.contact-line-terminal ~ * {
  pointer-events: auto;
}

.contact-line-terminal .contact-terminal-head,
.contact-line-terminal .media-account-console {
  display: none;
}

.contact-line-terminal::before,
.contact-line-terminal::after {
  display: none;
}

.contact-line-terminal + .contact-visual-caption,
.section-contact .contact-visual-caption {
  display: none;
}

.contact-code-stream {
  position: relative;
  width: min(680px, 48vw);
  min-height: 42px;
  padding: 0 0 13px;
  border-bottom: 1px solid rgba(155, 223, 255, 0.26);
  color: rgba(155, 223, 255, 0.78);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: clamp(12px, 1.08vw, 15px);
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: lowercase;
}

.contact-code-stream::before {
  content: "";
  position: absolute;
  left: clamp(-270px, -20vw, -170px);
  right: 100%;
  top: 13px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.44));
  box-shadow: 0 0 18px rgba(155, 223, 255, 0.16);
}

.contact-code-stream span {
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  white-space: nowrap;
  border-right: 1px solid rgba(248, 242, 232, 0.76);
  animation:
    contactCodeTyping 2.8s steps(46, end) 420ms both,
    contactCursor 820ms steps(1, end) infinite;
}

.contact-line-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  counter-reset: none;
}

.contact-line-list::before {
  display: none;
}

.contact-line-item {
  display: grid;
  grid-template-columns: 44px minmax(108px, 0.36fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(14px, 2vw, 28px);
  min-height: 54px;
  padding: 0 0 14px;
  border: 0;
  border-bottom: 1px solid rgba(248, 242, 232, 0.11);
  border-radius: 0;
  clip-path: none;
  background: transparent;
  color: rgba(248, 242, 232, 0.92);
  box-shadow: none;
  overflow: visible;
  transform: none;
}

.contact-line-item::before {
  content: "";
  position: absolute;
  left: clamp(-270px, -20vw, -170px);
  right: 0;
  top: 50%;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.42) 25%, rgba(248, 242, 232, 0.16) 66%, rgba(155, 223, 255, 0.04));
  box-shadow: 0 0 14px rgba(155, 223, 255, 0.12);
  opacity: 0.82;
}

.contact-line-item::after {
  content: "";
  position: absolute;
  left: clamp(-275px, -20.4vw, -175px);
  top: calc(50% - 3px);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(155, 223, 255, 0.76);
  box-shadow: 0 0 16px rgba(155, 223, 255, 0.28);
  opacity: 0.78;
}

.contact-line-item:nth-child(2)::before,
.contact-line-item:nth-child(2)::after {
  opacity: 0.68;
}

.contact-line-item:nth-child(3)::before,
.contact-line-item:nth-child(3)::after {
  opacity: 0.56;
}

.contact-line-item:nth-child(4)::before,
.contact-line-item:nth-child(4)::after {
  opacity: 0.46;
}

.contact-line-item:nth-child(5)::before,
.contact-line-item:nth-child(5)::after {
  opacity: 0.62;
}

.contact-line-item:hover {
  border-color: rgba(155, 223, 255, 0.36);
  box-shadow: none;
  transform: translateX(6px);
}

.contact-line-item:hover::before {
  opacity: 1;
  background:
    linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.72) 24%, rgba(248, 242, 232, 0.22) 68%, rgba(155, 223, 255, 0.08));
}

.contact-line-item em,
.contact-line-item span,
.contact-line-item strong {
  position: relative;
  z-index: 1;
}

.contact-line-item em {
  color: rgba(155, 223, 255, 0.56);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: 0.16em;
}

.contact-line-item span {
  color: rgba(248, 242, 232, 0.58);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.contact-line-item strong {
  color: rgba(248, 242, 232, 0.92);
  font-size: clamp(15px, 1.32vw, 20px);
  line-height: 1.2;
}

.contact-line-wide strong {
  color: rgba(248, 242, 232, 0.72);
  font-size: clamp(12px, 1vw, 14px);
  letter-spacing: 0.02em;
}

.contact-footer {
  display: flex;
  justify-content: space-between;
  bottom: clamp(34px, 4.4vw, 58px);
}

.contact-footer::before,
.contact-footer::after,
.contact-footer span::before,
.contact-footer span::after {
  display: none;
}

.contact-footer span {
  min-height: 0;
  padding: 0;
  color: rgba(248, 242, 232, 0.66);
  letter-spacing: 0.13em;
}

.contact-minimal {
  min-height: 100svh;
  padding: clamp(58px, 6vw, 92px) clamp(38px, 6vw, 96px);
  align-content: center;
  color: #292929;
  background:
    radial-gradient(ellipse 64% 58% at 70% 32%, rgba(255, 82, 31, 0.05), transparent 68%),
    #f4f2ed;
}

.contact-minimal::before {
  z-index: 0;
  opacity: 0.5;
  background:
    radial-gradient(ellipse 54% 98% at 68% -10%, transparent 0 49%, rgba(255, 82, 31, 0.13) 49.2% 49.7%, transparent 50%),
    radial-gradient(ellipse 38% 86% at 90% 78%, transparent 0 55%, rgba(255, 82, 31, 0.1) 55.2% 55.6%, transparent 56%),
    radial-gradient(ellipse 28% 74% at 18% 74%, transparent 0 58%, rgba(255, 82, 31, 0.09) 58.2% 58.7%, transparent 59%);
  background-size: 100% 100%;
  mask-image: none;
}

.contact-minimal::after {
  display: none;
}

.contact-minimal > * {
  position: relative;
  z-index: 1;
}

.contact-minimal-wrap {
  display: grid;
  grid-template-columns: minmax(420px, 0.9fr) minmax(560px, 1.1fr);
  gap: clamp(44px, 6vw, 96px);
  align-items: center;
  width: min(1500px, 100%);
  margin: 0 auto;
}

.contact-build-copy {
  display: grid;
  gap: 18px;
}

.contact-build-copy p {
  margin: 0;
  color: rgba(41, 41, 41, 0.46);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.contact-build-copy h2 {
  margin: 0;
  color: #ff4f1f;
  font-size: clamp(74px, 7vw, 126px);
  font-weight: 950;
  line-height: 0.94;
  letter-spacing: 0;
  text-transform: uppercase;
}

.contact-build-copy span {
  max-width: 46ch;
  color: rgba(41, 41, 41, 0.58);
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 1.6;
}

.contact-simple-list {
  display: grid;
  align-self: center;
  padding-top: clamp(12px, 2vw, 26px);
}

.contact-simple-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.34fr) minmax(0, 1fr);
  align-items: center;
  gap: clamp(24px, 4vw, 78px);
  min-height: clamp(58px, 6vw, 74px);
  border-bottom: 1px solid rgba(41, 41, 41, 0.1);
  color: #292929;
  text-decoration: none;
}

.contact-simple-row:first-child {
  border-top: 1px solid rgba(41, 41, 41, 0.08);
}

.contact-simple-row span {
  color: rgba(41, 41, 41, 0.34);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.contact-simple-row strong {
  justify-self: end;
  color: rgba(41, 41, 41, 0.78);
  font-family: "SFMono-Regular", Consolas, monospace;
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 900;
  letter-spacing: 0.04em;
  text-align: right;
}

.contact-simple-row:hover span,
.contact-simple-row:hover strong {
  color: #ff4f1f;
}

.contact-minimal .contact-footer {
  left: clamp(38px, 6vw, 96px);
  right: clamp(38px, 6vw, 96px);
  bottom: clamp(24px, 3vw, 40px);
}

.contact-minimal .contact-footer span {
  color: rgba(41, 41, 41, 0.42);
}

/* Contact keeps the reference layout, but returns to the site's dark sci-fi palette. */
.contact-minimal {
  color: rgba(248, 242, 232, 0.92);
  background:
    radial-gradient(ellipse 60% 54% at 72% 38%, rgba(155, 223, 255, 0.075), transparent 68%),
    radial-gradient(ellipse 46% 54% at 17% 64%, rgba(248, 242, 232, 0.035), transparent 72%),
    linear-gradient(180deg, rgba(3, 5, 8, 0.98), rgba(1, 2, 4, 1) 82%);
  overflow: hidden;
}

.contact-minimal .contact-hero-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 50%;
  opacity: 0.54;
  filter: saturate(0.78) contrast(1.1) brightness(0.48);
  transform: scale(1.03);
  transform-origin: center;
  pointer-events: none;
}

.contact-minimal::before {
  z-index: 1;
  opacity: 0.34;
  background:
    radial-gradient(circle, rgba(248, 242, 232, 0.2) 0 0.8px, transparent 1.6px),
    radial-gradient(circle, rgba(155, 223, 255, 0.18) 0 0.65px, transparent 1.4px),
    radial-gradient(ellipse 54% 98% at 68% -10%, transparent 0 49%, rgba(155, 223, 255, 0.14) 49.2% 49.5%, transparent 50%),
    radial-gradient(ellipse 38% 86% at 90% 78%, transparent 0 55%, rgba(248, 242, 232, 0.08) 55.2% 55.5%, transparent 56%),
    radial-gradient(ellipse 28% 74% at 18% 74%, transparent 0 58%, rgba(155, 223, 255, 0.08) 58.2% 58.6%, transparent 59%);
  background-size: 34px 34px, 72px 72px, 100% 100%, 100% 100%, 100% 100%;
  background-position: 0 0, 17px 19px, 0 0, 0 0, 0 0;
  mask-image: radial-gradient(ellipse 78% 72% at 50% 50%, #000 0 64%, transparent 100%);
}

.contact-minimal::after {
  display: block;
  z-index: 1;
  opacity: 0.78;
  background:
    radial-gradient(ellipse 34% 56% at 50% 52%, rgba(1, 2, 4, 0.08), rgba(1, 2, 4, 0.58) 76%, rgba(1, 2, 4, 0.82)),
    linear-gradient(90deg, rgba(1, 2, 4, 0.28), rgba(1, 2, 4, 0.18) 28%, rgba(1, 2, 4, 0.5) 64%, rgba(1, 2, 4, 0.76)),
    linear-gradient(180deg, rgba(1, 2, 4, 0.48), transparent 26%, rgba(1, 2, 4, 0.72));
  mix-blend-mode: normal;
}

.contact-minimal-wrap {
  position: relative;
  z-index: 2;
  grid-template-columns: minmax(620px, 0.94fr) minmax(610px, 0.86fr);
  gap: clamp(130px, 10.5vw, 190px);
}

.contact-build-copy p {
  color: rgba(155, 223, 255, 0.62);
}

.contact-build-copy h2 {
  color: rgba(248, 242, 232, 0.98);
  font-size: clamp(62px, 5.2vw, 96px);
  text-shadow:
    0 0 34px rgba(155, 223, 255, 0.12),
    0 34px 84px rgba(0, 0, 0, 0.38);
}

.contact-build-copy span {
  color: rgba(248, 242, 232, 0.58);
}

.contact-simple-row {
  border-bottom-color: rgba(248, 242, 232, 0.13);
  color: rgba(248, 242, 232, 0.92);
  background: linear-gradient(90deg, transparent, rgba(1, 2, 4, 0.18));
}

.contact-simple-row:first-child {
  border-top-color: rgba(248, 242, 232, 0.1);
}

.contact-simple-row span {
  color: rgba(155, 223, 255, 0.48);
}

.contact-simple-row strong {
  color: rgba(248, 242, 232, 0.78);
}

.contact-simple-row:hover span,
.contact-simple-row:hover strong {
  color: rgba(155, 223, 255, 0.92);
}

.contact-minimal .contact-footer span {
  color: rgba(248, 242, 232, 0.46);
}

@keyframes contactCodeTyping {
  0% {
    width: 0;
  }

  100% {
    width: 46ch;
  }
}

@keyframes contactCursor {
  50% {
    border-color: transparent;
  }
}

@keyframes cue {
  50% {
    opacity: 0.48;
    transform: translate(-50%, 12px);
  }
}

@keyframes contactSignalPulse {
  0% {
    opacity: 0;
    transform: translateX(0);
  }

  18%,
  72% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    transform: translateX(min(520px, 42vw));
  }
}

@keyframes contactScan {
  0%,
  100% {
    opacity: 0.18;
    transform: translateY(-180px) rotate(-4deg);
  }

  45%,
  55% {
    opacity: 0.82;
  }

  100% {
    transform: translateY(260px) rotate(-4deg);
  }
}

@keyframes scanPulse {
  0% {
    transform: translate(-50%, -50%) scale(0.72);
    box-shadow:
      0 0 0 0 rgba(155, 223, 255, 0.18),
      0 0 26px rgba(155, 223, 255, 0.12);
  }

  70% {
    transform: translate(-50%, -50%) scale(1.05);
    box-shadow:
      0 0 0 24px rgba(155, 223, 255, 0),
      0 0 32px rgba(245, 216, 167, 0.12);
  }

  100% {
    transform: translate(-50%, -50%) scale(0.82);
    box-shadow:
      0 0 0 0 rgba(155, 223, 255, 0),
      0 0 20px rgba(155, 223, 255, 0.08);
  }
}

@keyframes nebulaPulse {
  50% {
    opacity: 0.2;
    scale: 1.08;
  }
}

@keyframes aboutOrbit {
  to {
    rotate: 360deg;
  }
}

@keyframes aboutCorePulse {
  50% {
    box-shadow:
      0 0 52px rgba(155, 223, 255, 0.18),
      0 0 24px rgba(248, 242, 232, 0.08),
      inset 0 0 28px rgba(155, 223, 255, 0.08);
  }
}

@keyframes aboutBlackHoleSpin {
  to {
    rotate: 360deg;
  }
}

@keyframes aboutDiskSpin {
  to {
    transform: rotate(346deg) scaleY(0.3);
  }
}

@keyframes aboutNodeScan {
  50% {
    opacity: 0.45;
    transform: scale(1.045);
  }
}

@keyframes aboutPanelFlash {
  0% {
    border-color: rgba(155, 223, 255, 0.72);
    box-shadow:
      0 0 38px rgba(155, 223, 255, 0.14),
      inset 0 1px 0 rgba(255, 255, 255, 0.12);
  }
}

@keyframes aboutDotDrift {
  to {
    background-position:
      28px 28px,
      -42px 74px,
      0 0;
  }
}

@keyframes aboutFocusPulse {
  0% {
    opacity: calc(var(--about-focus-strength) * 0.42);
    filter: blur(0);
  }

  50% {
    opacity: calc(var(--about-focus-strength) * 0.82);
    filter: blur(0.2px);
  }

  100% {
    opacity: calc(var(--about-focus-strength) * 0.5);
    filter: blur(0);
  }
}

@keyframes aboutNoteIn {
  0% {
    opacity: 0;
    filter: blur(6px);
    transform: translate(-50%, 16px);
  }

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

@keyframes aboutTextReveal {
  0% {
    clip-path: inset(0 100% 0 0);
  }

  100% {
    clip-path: inset(0 0 0 0);
  }
}

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

@keyframes robotBlink {
  0%,
  83%,
  90%,
  100% {
    opacity: 0;
    transform: scaleY(0);
  }

  86%,
  88% {
    opacity: 0.95;
    transform: scaleY(1);
  }
}

@keyframes projectRadarSpin {
  to {
    transform: rotate(calc(360deg + var(--project-card-wake, 0) * 22deg));
  }
}

@keyframes projectStatusSweep {
  0%,
  34% {
    transform: translateX(0) skewX(-18deg);
  }

  70%,
  100% {
    transform: translateX(420%) skewX(-18deg);
  }
}

@keyframes projectDiskDrift {
  to {
    transform: rotate(348deg) scaleY(0.48);
  }
}

@keyframes workflowOrbitSpin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes workflowFieldScan {
  0%,
  100% {
    background-position: 0 0, 0 0, 50% 72%;
    opacity: 0.34;
  }

  50% {
    background-position: 18px 0, 0 18px, 50% 72%;
    opacity: 0.48;
  }
}

@keyframes workflowStatusScan {
  0%,
  42% {
    transform: translateX(-120%);
  }

  64%,
  100% {
    transform: translateX(240%);
  }
}

@keyframes workflowLaneSweep {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes workflowCorePulse {
  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
  }

  42% {
    border-color: rgb(155 223 255 / 0.48);
    box-shadow:
      inset 0 0 54px rgb(155 223 255 / 0.2),
      0 0 82px rgb(86 207 255 / 0.3);
    transform: translate(-50%, -50%) scale(1.045);
  }
}

@keyframes workflowCorePing {
  0% {
    opacity: 0.78;
    transform: scale(0.92);
  }

  100% {
    opacity: 0;
    transform: scale(1.18);
  }
}

@keyframes workflowBotIdle {
  0%,
  100% {
    opacity: 0.95;
  }

  50% {
    opacity: 1;
  }
}

@keyframes workflowBotScan {
  0%,
  100% {
    opacity: 0.34;
    transform: scaleX(0.74);
  }

  50% {
    opacity: 0.78;
    transform: scaleX(1);
  }
}

@keyframes workflowBotEye {
  0%,
  88%,
  100% {
    transform: scaleY(1);
  }

  92% {
    transform: scaleY(0.2);
  }
}

@keyframes workflowCrewFloat {
  0%,
  100% {
    margin-top: 0;
  }

  50% {
    margin-top: -10px;
  }
}

@keyframes workflowCrewPing {
  0% {
    opacity: 0.95;
    transform: translate(-50%, -50%) scale(0.92);
  }

  100% {
    opacity: 0.2;
    transform: translate(-50%, -50%) scale(1.16);
  }
}

@keyframes workflowDetailIn {
  0% {
    opacity: 0.72;
    transform: translateX(-50%) translateY(8px);
  }

  100% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

@keyframes abilityCardOrbit {
  0% {
    transform:
      translate(-50%, -50%)
      rotate(var(--angle))
      translateX(var(--ability-radius))
      rotate(var(--counter-angle))
      scale(var(--planet-scale, 1));
  }

  100% {
    transform:
      translate(-50%, -50%)
      rotate(calc(var(--angle) + 360deg))
      translateX(var(--ability-radius))
      rotate(calc(var(--counter-angle) - 360deg))
      scale(var(--planet-scale, 1));
  }
}

@media (max-width: 980px) {
  .card-grid,
  .contact-layout,
  .platform-grid {
    grid-template-columns: 1fr;
  }

  .contact-dock {
    grid-template-columns: 1fr;
    width: 100%;
  }

  .contact-dock::before {
    left: 50%;
    width: 86vw;
  }

  .contact-portrait-frame {
    min-height: 440px;
  }

  .about-shell {
    grid-template-columns: 1fr;
  }

  .about-console {
    min-height: 460px;
  }

  .about-shell-v2 {
    grid-template-columns: 1fr;
  }

  .about-shell-v3 {
    grid-template-columns: 1fr;
    gap: clamp(14px, 2.8vw, 26px);
  }

  .about-console-v2 {
    min-height: 640px;
  }

  .about-console-v3,
  .about-keyword-field {
    min-height: 460px;
  }

  .about-keyword-detail {
    width: min(380px, 38vw);
  }

  .keyword-node::after {
    width: 54px;
    right: -78px;
  }

  .keyword-ai::after,
  .keyword-content::after,
  .keyword-explorer::after {
    left: -78px;
  }

  .ability-showcase {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .ability-copy {
    justify-self: start;
    transform: none;
  }

  .ability-copy .section-lead,
  .ability-status {
    max-width: 100%;
  }

  .ability-stage {
    --ability-radius: clamp(150px, 24vw, 220px);
    min-height: 560px;
    transform: none;
  }

  .ability-orbit {
    width: 100%;
    height: 500px;
  }

  .card-grid article {
    min-height: auto;
  }

  .section-thinking .section-lead {
    max-width: 100%;
  }

  .project-archive-status {
    width: 100%;
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "index"
      "title"
      "body"
      "state";
    gap: 8px;
  }

  .project-archive-status p {
    white-space: normal;
  }

  .project-archive-status em {
    justify-self: start;
  }

  .project-competency-line {
    width: 100%;
  }

  .section-thinking .signal-list {
    width: 100%;
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .section-thinking .signal-list article:first-child {
    grid-row: auto;
    min-height: 260px;
  }

  .section-thinking .signal-list article:first-child .project-singularity {
    width: clamp(92px, 20vw, 136px);
  }

  .workflow-engine {
    grid-template-columns: 1fr;
    width: 100%;
  }

  .workflow-engine::before,
  .workflow-engine::after {
    display: none;
  }

  .workflow-copy .section-lead,
  .workflow-status p {
    max-width: 100%;
  }

  .workflow-status {
    width: 100%;
  }

  .workflow-core {
    position: relative;
    left: auto;
    top: auto;
    width: min(230px, 54vw);
    margin: 0 0 4px;
    transform: none;
  }

  .section-ai .timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .section-ai .timeline::before,
  .section-ai .timeline::after {
    display: none;
  }

  .section-ai .timeline article {
    min-height: 320px;
  }

  .workflow-scene .workflow-copy {
    top: clamp(46px, 6svh, 70px);
  }

  .workflow-bot {
    --bot-size: 86px;
    width: 122px;
  }

  .crew-01 {
    --x: 18%;
    --y: 31%;
  }

  .crew-02 {
    --x: 14%;
    --y: 47%;
  }

  .crew-03 {
    --x: 17%;
    --y: 63%;
  }

  .crew-04 {
    --x: 24%;
    --y: 79%;
  }

  .crew-05 {
    --x: 82%;
    --y: 31%;
  }

  .crew-06 {
    --x: 86%;
    --y: 47%;
  }

  .crew-07 {
    --x: 83%;
    --y: 63%;
  }

  .crew-08 {
    --x: 76%;
    --y: 79%;
  }
}

@media (max-width: 760px) {
  .hero {
    min-height: 140svh;
  }

  .hero-image {
    object-position: center;
    transform:
      translate3d(
        calc(var(--mouse-x) * -5px),
        calc(var(--scroll) * -0.046px + var(--mouse-y) * -3px + var(--space-warp) * -18px),
        0
      )
      scale(calc(1.12 + var(--hero-progress) * 0.04 + var(--space-warp) * 0.025));
  }

  .hero-foreground {
    object-position: center;
    transform:
      translate3d(
        calc(var(--mouse-x) * -5px),
        calc(var(--scroll) * -0.046px + var(--mouse-y) * -3px + var(--space-warp) * -18px),
        0
      )
      scale(calc(1.12 + var(--hero-progress) * 0.04 + var(--space-warp) * 0.025));
    -webkit-mask-image:
      radial-gradient(ellipse 28% 40% at 51% 55%, #000 0 62%, rgba(0, 0, 0, 0.76) 72%, transparent 89%),
      linear-gradient(180deg, transparent 0 62%, #000 78% 100%);
    mask-image:
      radial-gradient(ellipse 28% 40% at 51% 55%, #000 0 62%, rgba(0, 0, 0, 0.76) 72%, transparent 89%),
      linear-gradient(180deg, transparent 0 62%, #000 78% 100%);
  }

  .portrait-particles {
    opacity: calc(var(--portrait-particles-opacity) * var(--foreground-opacity) * 0.78);
    -webkit-mask-image:
      radial-gradient(ellipse 27% 40% at 52% 55%, #000 0 55%, rgba(0, 0, 0, 0.7) 68%, transparent 88%),
      linear-gradient(180deg, transparent 0 38%, #000 54% 88%, transparent 100%);
    mask-image:
      radial-gradient(ellipse 27% 40% at 52% 55%, #000 0 55%, rgba(0, 0, 0, 0.7) 68%, transparent 88%),
      linear-gradient(180deg, transparent 0 38%, #000 54% 88%, transparent 100%);
  }

  .space-webgl {
    opacity: 0.9;
  }

  .planet-hotspot {
    min-width: 82px;
    min-height: 42px;
    gap: 8px;
  }

  .planet-hotspot::before {
    left: -34px;
    width: 34px;
  }

  .planet-ai::before {
    left: auto;
    right: -34px;
  }

  .hotspot-dot {
    display: none;
  }

  .hotspot-word {
    font-size: 10px;
    letter-spacing: 0.08em;
  }

  .hotspot-subtitle {
    display: none;
  }

  .space-cursor,
  .robot-pointer,
  .robot-scan {
    display: none;
  }

  .robot-companion {
    z-index: 23;
    width: clamp(66px, 16vw, 92px);
    max-width: 24vw;
    opacity: 0.84;
  }

  .robot-face {
    z-index: 23;
    width: clamp(66px, 16vw, 92px);
    max-width: 24vw;
    opacity: 0.84;
  }

  .signature-main,
  .signature-shadow {
    font-size: 112px;
  }

  .section {
    padding: 72px 20px;
  }

  .section-projects h2,
  .section-thinking h2,
  .section-ai h2,
  .section-contact h2 {
    max-width: 100%;
    font-size: clamp(34px, 11vw, 52px);
    line-height: 1.03;
  }

  .section-lead,
  .section-contact .section-lead {
    max-width: 100%;
    margin-top: -14px;
  }

  .workflow-status {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 13px 14px;
  }

  .workflow-copy > h2 {
    max-width: 100%;
    font-size: clamp(30px, 8.4vw, 44px);
    line-height: 1;
  }

  .workflow-status strong {
    white-space: normal;
  }

  .workflow-scene {
    min-height: 104svh;
  }

  .workflow-scene-image {
    object-position: center;
    filter: brightness(0.72) contrast(1.06) saturate(0.94);
  }

  .workflow-scene .workflow-copy {
    top: 58px;
    width: min(350px, calc(100vw - 32px));
    gap: 10px;
  }

  .workflow-scene .workflow-copy > h2 {
    font-size: clamp(30px, 8.4vw, 44px);
    line-height: 1;
  }

  .workflow-scene .workflow-copy .section-lead {
    max-width: 34ch;
    font-size: 13px;
    line-height: 1.7;
  }

  .workflow-core {
    width: min(190px, 62vw);
  }

  .section-ai .timeline {
    grid-template-columns: 1fr;
  }

  .section-ai .timeline article {
    grid-template-rows: auto 118px auto auto;
    min-height: auto;
  }

  .tool-bot {
    width: 132px;
    height: 118px;
  }

  .workflow-bot {
    --bot-size: 68px;
    width: 92px;
    gap: 6px;
  }

  .crew-robot-frame {
    width: calc(var(--bot-size) + 24px);
  }

  .crew-orbit {
    width: calc(var(--bot-size) + 26px);
  }

  .crew-label {
    min-width: 78px;
    padding: 6px 7px;
  }

  .crew-label strong {
    font-size: 13px;
  }

  .crew-label small {
    font-size: 8px;
  }

  .crew-badge {
    min-width: 20px;
    height: 15px;
    font-size: 8px;
  }

  .crew-signal {
    right: -2px;
    top: 22%;
    min-width: 23px;
    height: 18px;
    font-size: 7px;
  }

  .workflow-detail-card {
    top: calc(100svh - 250px);
    bottom: auto;
    width: min(340px, calc(100vw - 36px));
    padding: 12px 13px;
  }

  .workflow-detail-card span {
    font-size: 20px;
  }

  .workflow-detail-card p {
    font-size: 12px;
    line-height: 1.62;
  }

  .crew-01 {
    --x: 21%;
    --y: 32%;
  }

  .crew-02 {
    --x: 17%;
    --y: 48%;
  }

  .crew-03 {
    --x: 20%;
    --y: 64%;
  }

  .crew-04 {
    --x: 27%;
    --y: 80%;
  }

  .crew-05 {
    --x: 79%;
    --y: 32%;
  }

  .crew-06 {
    --x: 83%;
    --y: 48%;
  }

  .crew-07 {
    --x: 80%;
    --y: 64%;
  }

  .crew-08 {
    --x: 73%;
    --y: 80%;
  }

  .ability-showcase {
    gap: 28px;
  }

  .ability-copy {
    gap: 16px;
  }

  .ability-copy h2 {
    font-size: clamp(42px, 16vw, 66px);
    line-height: 0.92;
  }

  .ability-status {
    padding: 14px 0 14px 18px;
  }

  .ability-stage {
    min-height: auto;
    display: block;
    perspective: none;
    transform: none;
  }

  .ability-webgl {
    display: none;
  }

  .ability-stage::before,
  .ability-stage::after,
  .ability-core {
    display: none;
  }

  .ability-orbit {
    display: grid;
    gap: 12px;
    width: 100%;
    height: auto;
    transform: none;
  }

  .ability-card {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    min-height: 150px;
    border-radius: 8px;
    animation: none;
    opacity: 1;
    transform: none;
    text-align: left;
  }

  .ability-card strong {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    font-size: clamp(24px, 8vw, 34px);
  }

  .ability-card small {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
  }

  .signal-list article,
  .timeline article {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .section-thinking {
    gap: 18px;
  }

  .project-archive-status {
    min-height: 0;
    padding: 14px;
  }

  .section-thinking .signal-list {
    gap: 12px;
  }

  .section-thinking .signal-list article {
    min-height: 220px;
    padding: 22px;
  }

  .section-thinking .signal-list article:first-child {
    min-height: 260px;
    padding: 24px;
  }

  .section-thinking .signal-list .project-singularity {
    width: clamp(76px, 24vw, 104px);
    opacity: 0.58;
  }

  .section-thinking .signal-list article:not(:first-child) .project-singularity {
    top: auto;
    right: -8px;
    bottom: 18px;
    width: clamp(68px, 21vw, 84px);
    opacity: 0.34;
  }

  .section-thinking .project-module-copy {
    max-width: 100%;
  }

  .card-points {
    margin-top: 18px;
  }

  .about-tabs {
    grid-template-columns: repeat(2, 1fr);
  }

  .about-console {
    min-height: 430px;
  }

  .about-console-v2 {
    min-height: auto;
    grid-template-rows: auto auto auto;
    gap: 14px;
    padding: 14px;
  }

  .about-constellation {
    min-height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    padding-top: 152px;
  }

  .about-core {
    top: 16px;
    width: 118px;
    transform: translateX(-50%);
  }

  .about-ring-one,
  .about-ring-two {
    top: 75px;
    width: 220px;
    height: 82px;
  }

  .about-link {
    display: none;
  }

  .about-node {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    min-height: 78px;
  }

  .about-card-v2 {
    min-height: auto;
  }

  .about-metrics {
    display: grid;
    grid-template-columns: 1fr;
  }

  .about-shell-v3 {
    min-height: auto;
    gap: 16px;
  }

  .about-keyword-head {
    justify-items: start;
    text-align: left;
    transform: none;
  }

  .about-keyword-head h2 {
    font-size: clamp(56px, 18vw, 86px);
  }

  .about-console-v3,
  .about-keyword-field {
    min-height: auto;
  }

  .about-keyword-field {
    display: grid;
    gap: 12px;
    padding: 0 0 168px;
  }

  .about-letter-cloud,
  .about-core-v3,
  .about-keyword-field > .about-ring {
    display: none;
  }

  .about-core-v3 {
    top: 0;
    width: 112px;
    transform: translateX(-50%);
  }

  .keyword-node {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    min-width: 0;
    width: 100%;
    padding: 10px 0;
    text-align: left;
    justify-items: start;
  }

  .keyword-node::before,
  .keyword-node::after {
    display: none;
  }

  .keyword-node strong {
    font-size: clamp(30px, 9vw, 44px);
  }

  .about-keyword-detail {
    left: 0;
    top: auto;
    bottom: 0;
    width: 100%;
    min-height: 144px;
    padding: 14px 16px;
    text-align: left;
    justify-items: start;
    transform: translateY(8px);
  }

  .about-console-v3.has-active .about-keyword-detail {
    transform: translateY(0);
  }

  .about-console-v3.is-scanning .about-keyword-detail {
    animation: none;
  }

  .about-keyword-detail h3 {
    font-size: clamp(22px, 7vw, 34px);
  }

  .platform-card {
    min-height: 112px;
  }

  .contact-dock {
    gap: 18px;
  }

  .contact-portrait-frame {
    min-height: 360px;
  }

  .contact-terminal {
    padding: 18px;
  }

  .contact-terminal-head h2 {
    font-size: clamp(44px, 14vw, 64px);
  }

  .contact-channel-list,
  .media-account-grid {
    grid-template-columns: 1fr;
  }

  .media-console-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .media-console-head strong {
    text-align: left;
  }

  .contact-footer {
    flex-direction: column;
  }
}

/* Final confirmed #thinking override: cinematic black-hole project field. */
.section-thinking {
  --project-focus-x: 50%;
  --project-focus-y: 52%;
  align-content: center;
  justify-items: center;
  min-height: 100svh;
  padding: clamp(44px, 4.6vw, 72px) clamp(18px, 5vw, 78px);
  overflow: hidden;
  background:
    radial-gradient(circle at var(--project-focus-x) var(--project-focus-y), rgba(255, 237, 202, 0.09), transparent 290px),
    radial-gradient(ellipse 76% 52% at 50% 48%, rgba(255, 255, 255, 0.04), transparent 64%),
    linear-gradient(180deg, rgba(5, 8, 11, 0.96), rgba(1, 2, 4, 1) 78%);
}

.section-thinking::before {
  opacity: 0.72;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.8) 0 0.7px, transparent 1.6px),
    radial-gradient(circle, rgba(155, 223, 255, 0.5) 0 0.55px, transparent 1.4px),
    linear-gradient(112deg, transparent 0 20%, rgba(255, 255, 255, 0.22) 20.1% 20.25%, transparent 20.7%),
    linear-gradient(68deg, transparent 0 69%, rgba(255, 255, 255, 0.16) 69.08% 69.2%, transparent 69.8%);
  background-size: 38px 38px, 76px 76px, 100% 100%, 100% 100%;
  background-position: 0 0, 19px 17px, 0 0, 0 0;
  mask-image: radial-gradient(ellipse 70% 58% at 50% 48%, #000 0 62%, transparent 100%);
}

.section-thinking::after {
  opacity: 0.86;
  background:
    radial-gradient(ellipse 86% 64% at 50% 53%, transparent 0 54%, rgba(0, 0, 0, 0.62) 78%, rgba(0, 0, 0, 0.94) 100%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.62), transparent 26% 74%, rgba(0, 0, 0, 0.62));
  mix-blend-mode: normal;
}

.blackhole-archive {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  justify-items: center;
  align-content: center;
  gap: clamp(10px, 1.2vw, 16px);
  width: min(1280px, 92vw);
  min-height: min(780px, calc(100svh - 80px));
}

.thinking-copy {
  position: relative;
  z-index: 5;
  display: grid;
  justify-items: center;
  gap: 8px;
  text-align: center;
}

.thinking-copy .section-kicker {
  color: rgba(248, 242, 232, 0.72);
  letter-spacing: 0;
}

.thinking-copy h2 {
  max-width: min(980px, 82vw);
  margin: 0;
  color: rgba(250, 246, 236, 0.98);
  font-size: clamp(58px, 7.3vw, 112px);
  line-height: 0.84;
  letter-spacing: 0;
  text-align: center;
  text-transform: uppercase;
  text-shadow:
    0 22px 48px rgba(0, 0, 0, 0.76),
    0 0 34px rgba(255, 244, 220, 0.16);
}

.section-thinking .project-archive-status {
  z-index: 6;
  grid-template-columns: minmax(92px, auto) minmax(0, 1fr) auto;
  grid-template-areas:
    "index title state"
    "index body state";
  width: min(1040px, 82vw);
  min-height: 62px;
  margin: 0;
  padding: 11px 16px;
  border-color: rgba(255, 244, 220, 0.24);
  background:
    linear-gradient(90deg, rgba(255, 247, 229, 0.11), rgba(255, 203, 154, 0.055), rgba(155, 223, 255, 0.035)),
    rgba(3, 5, 8, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 22px 70px rgba(0, 0, 0, 0.34),
    0 0 44px rgba(255, 244, 220, 0.08);
}

.section-thinking .project-archive-status::before {
  background: linear-gradient(90deg, rgba(255, 255, 248, 0.82), rgba(255, 198, 145, 0.34), transparent);
}

.section-thinking .project-archive-status::after {
  background: linear-gradient(90deg, transparent, rgba(255, 244, 220, 0.2), transparent);
}

.section-thinking .project-archive-status span,
.section-thinking .project-archive-status em {
  color: rgba(180, 224, 245, 0.9);
  letter-spacing: 0;
}

.section-thinking .project-archive-status strong {
  color: rgba(255, 249, 238, 0.98);
}

.section-thinking .project-archive-status p {
  color: rgba(248, 242, 232, 0.66);
}

.section-thinking .project-event-field {
  position: relative;
  width: min(1180px, 88vw);
  height: clamp(430px, 45vw, 560px);
  margin-top: clamp(-24px, -1.6vw, -12px);
}

.project-black-hole {
  position: absolute;
  left: 50%;
  top: 48%;
  width: min(1120px, 96vw);
  height: min(520px, 46vw);
  pointer-events: none;
  transform: translate(-50%, -50%);
  filter:
    drop-shadow(0 0 34px rgba(255, 244, 220, 0.16))
    drop-shadow(0 0 74px rgba(0, 0, 0, 0.86));
}

.project-black-hole::before,
.project-black-hole::after,
.project-black-hole i {
  position: absolute;
  content: "";
  pointer-events: none;
}

.project-black-hole::before {
  left: -8%;
  right: -8%;
  top: 48%;
  height: 24%;
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent 0 4%, rgba(63, 37, 28, 0.34) 10%, rgba(255, 192, 128, 0.7) 25%, rgba(255, 255, 245, 0.98) 41%, rgba(255, 251, 230, 0.94) 52%, rgba(192, 111, 65, 0.46) 70%, rgba(25, 17, 16, 0.86) 88%, transparent 100%),
    radial-gradient(ellipse at center, rgba(255, 255, 252, 0.95) 0 16%, rgba(255, 207, 151, 0.38) 36%, transparent 72%);
  filter: blur(0.6px);
  transform: translateY(-50%) rotate(-1.6deg) scaleY(0.62);
}

.project-black-hole::after {
  left: 0;
  right: 0;
  top: 54%;
  height: 31%;
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.42) 17%, rgba(0, 0, 0, 0.9) 48% 58%, rgba(0, 0, 0, 0.62) 76%, transparent),
    radial-gradient(ellipse at center, rgba(35, 24, 20, 0.64), transparent 68%);
  filter: blur(10px);
  transform: translateY(-50%) rotate(-1.8deg) scaleY(0.34);
}

.event-horizon {
  left: 50%;
  top: 51%;
  z-index: 5;
  width: clamp(158px, 17vw, 244px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 48% 44%, rgba(255, 255, 255, 0.04), transparent 0 16%),
    radial-gradient(circle, #020202 0 58%, rgba(0, 0, 0, 0.98) 62%, rgba(15, 14, 15, 0.94) 68%, transparent 72%);
  box-shadow:
    0 0 0 2px rgba(0, 0, 0, 0.96),
    0 0 46px rgba(0, 0, 0, 0.96),
    0 0 82px rgba(255, 244, 220, 0.16);
  transform: translate(-50%, -50%);
}

.gravity-lens {
  left: 50%;
  top: 47%;
  z-index: 2;
  width: clamp(360px, 42vw, 610px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, transparent 0 42%, rgba(255, 255, 247, 0.72) 46%, rgba(255, 212, 166, 0.32) 52%, transparent 62%),
    conic-gradient(from 196deg, transparent 0 18%, rgba(255, 255, 248, 0.55), rgba(255, 214, 170, 0.24), transparent 44% 100%);
  filter: blur(6px);
  opacity: 0.82;
  transform: translate(-50%, -50%) rotate(-4deg) scaleY(0.72);
}

.accretion {
  left: 50%;
  top: 49%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.accretion-front {
  z-index: 6;
  width: min(1160px, 100vw);
  height: clamp(72px, 8vw, 116px);
  background:
    linear-gradient(90deg, transparent 0 8%, rgba(255, 188, 126, 0.44) 20%, rgba(255, 255, 244, 0.98) 38%, rgba(255, 251, 232, 0.92) 50%, rgba(159, 82, 48, 0.42) 67%, rgba(13, 11, 12, 0.88) 86%, transparent 100%);
  filter: blur(1px);
  opacity: 0.95;
  transform: translate(-50%, -50%) rotate(-1.8deg) scaleY(0.38);
}

.accretion-back {
  z-index: 1;
  width: clamp(430px, 52vw, 760px);
  height: clamp(240px, 27vw, 380px);
  background:
    radial-gradient(ellipse at center, transparent 0 43%, rgba(255, 255, 246, 0.72) 46%, rgba(255, 202, 154, 0.26) 53%, transparent 66%);
  filter: blur(4px);
  opacity: 0.76;
  transform: translate(-50%, -62%) rotate(-4deg) scaleY(0.72);
}

.particle-stream {
  z-index: 7;
  width: 52%;
  height: 30%;
  opacity: 0.7;
  background:
    repeating-linear-gradient(100deg, transparent 0 14px, rgba(255, 255, 255, 0.34) 15px 17px, transparent 18px 72px);
  filter: blur(0.4px);
}

.stream-one {
  right: -3%;
  top: 10%;
  transform: rotate(-13deg);
  mask-image: linear-gradient(90deg, transparent, #000 18%, transparent 92%);
}

.stream-two {
  left: -5%;
  bottom: 10%;
  transform: rotate(12deg);
  opacity: 0.36;
  mask-image: linear-gradient(90deg, transparent, #000 24%, transparent 88%);
}

.section-thinking .signal-list {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  max-width: none;
  margin: 0;
  pointer-events: none;
}

.section-thinking .signal-list::before,
.section-thinking .signal-list::after {
  display: none;
}

.section-thinking .signal-list article {
  --project-card-wake: 0;
  position: absolute;
  z-index: 8;
  display: grid;
  gap: 6px;
  width: clamp(178px, 17vw, 238px);
  min-height: 0;
  padding: 11px 13px;
  pointer-events: auto;
  border: 1px solid rgba(255, 244, 220, 0.16);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.08), rgba(155, 223, 255, 0.04)),
    rgba(3, 5, 8, 0.46);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 18px 42px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(12px);
  cursor: pointer;
  transform: translateY(calc(var(--project-card-wake) * -4px));
}

.section-thinking .signal-list article.has-link {
  cursor: pointer;
}

.section-thinking .signal-list article::before {
  left: 12px;
  top: 12px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 244, 220, 0.9);
  box-shadow:
    0 0 14px rgba(255, 244, 220, 0.48),
    0 0 24px rgba(255, 178, 113, 0.24);
  opacity: 0.86;
  transform: none;
}

.section-thinking .signal-list article::after {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: -1px;
  height: 1px;
  border-radius: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 244, 220, 0.58), rgba(155, 223, 255, 0.18), transparent);
  opacity: calc(0.2 + var(--project-card-wake) * 0.62);
  mix-blend-mode: screen;
}

.section-thinking .signal-list span {
  display: block;
  padding-left: 16px;
  color: rgba(180, 224, 245, 0.9);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.section-thinking .signal-list h3 {
  margin: 0;
  color: rgba(255, 249, 238, 0.97);
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.06;
}

.section-thinking .signal-list p {
  margin: 0;
  color: rgba(248, 242, 232, 0.66);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
}

.project-node-one {
  left: 2%;
  top: 58%;
}

.project-node-two {
  left: 10%;
  top: 19%;
}

.project-node-three {
  right: 5%;
  top: 19%;
}

.project-node-four {
  left: 18%;
  bottom: 5%;
}

.project-node-five {
  right: 15%;
  bottom: 6%;
}

.section-thinking .signal-list article:hover,
.section-thinking .signal-list article.is-active {
  --project-card-wake: 1;
  border-color: rgba(255, 244, 220, 0.54);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.14), rgba(255, 189, 132, 0.05), rgba(155, 223, 255, 0.06)),
    rgba(5, 7, 10, 0.58);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.14),
    0 0 34px rgba(255, 244, 220, 0.13),
    0 20px 54px rgba(0, 0, 0, 0.42);
}

.section-thinking .signal-list article:focus-visible {
  outline: 1px solid rgba(255, 244, 220, 0.72);
  outline-offset: 4px;
}

@media (max-width: 980px) {
  .blackhole-archive {
    width: 100%;
    min-height: auto;
  }

  .section-thinking .project-archive-status {
    width: 100%;
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
      "index"
      "title"
      "body"
      "state";
    gap: 8px;
  }

  .section-thinking .project-archive-status p {
    white-space: normal;
  }

  .section-thinking .project-archive-status em {
    justify-self: start;
  }

  .section-thinking .project-event-field {
    width: 100%;
    height: auto;
    min-height: 0;
    padding-top: clamp(360px, 56vw, 480px);
  }

  .project-black-hole {
    top: clamp(170px, 28vw, 235px);
    width: min(980px, 118vw);
    height: clamp(330px, 54vw, 470px);
  }

  .section-thinking .signal-list {
    position: relative;
    display: grid;
    gap: 12px;
    pointer-events: auto;
  }

  .section-thinking .signal-list article {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    bottom: auto;
    width: 100%;
    min-height: 0;
  }
}

@media (max-width: 760px) {
  .section-thinking {
    padding: 72px 20px;
  }

  .thinking-copy h2 {
    font-size: clamp(42px, 15vw, 62px);
    line-height: 0.92;
  }

  .section-thinking .project-event-field {
    padding-top: 300px;
  }

  .project-black-hole {
    top: 142px;
    width: 690px;
    max-width: none;
    height: 330px;
  }

  .event-horizon {
    width: 134px;
  }

  .gravity-lens {
    width: 330px;
  }

  .section-thinking .signal-list article {
    padding: 14px 16px;
  }
}

/* EOF #thinking first-node normalization after all legacy rules. */
.section-thinking .signal-list article:first-child {
  grid-row: auto;
  min-height: 0;
  padding: 11px 13px;
  border-color: rgba(255, 244, 220, 0.16);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.08), rgba(155, 223, 255, 0.04)),
    rgba(3, 5, 8, 0.46);
}

.section-thinking .signal-list article:first-child h3 {
  max-width: none;
  font-size: clamp(17px, 1.35vw, 21px);
  line-height: 1.06;
}

.section-thinking .signal-list article:first-child p {
  max-width: none;
  color: rgba(248, 242, 232, 0.66);
}

@media (max-width: 760px) {
  .section-thinking .signal-list article:first-child {
    padding: 14px 16px;
  }
}

.section-thinking::before {
  opacity: 0.74;
  background:
    radial-gradient(circle at 9% 18%, rgba(255, 255, 255, 0.72) 0 0.7px, transparent 1.5px),
    radial-gradient(circle at 18% 71%, rgba(155, 223, 255, 0.5) 0 0.75px, transparent 1.6px),
    radial-gradient(circle at 31% 26%, rgba(255, 255, 255, 0.62) 0 0.65px, transparent 1.5px),
    radial-gradient(circle at 44% 82%, rgba(255, 255, 255, 0.58) 0 0.7px, transparent 1.5px),
    radial-gradient(circle at 59% 13%, rgba(155, 223, 255, 0.48) 0 0.75px, transparent 1.5px),
    radial-gradient(circle at 76% 67%, rgba(255, 255, 255, 0.64) 0 0.7px, transparent 1.6px),
    radial-gradient(circle at 88% 30%, rgba(255, 255, 255, 0.58) 0 0.65px, transparent 1.5px),
    linear-gradient(102deg, transparent 0 18%, rgba(255, 255, 255, 0.18) 18.08% 18.18%, transparent 18.78%),
    linear-gradient(78deg, transparent 0 72%, rgba(255, 255, 255, 0.13) 72.08% 72.18%, transparent 72.84%);
  background-size:
    181px 131px,
    227px 169px,
    263px 197px,
    311px 241px,
    353px 283px,
    419px 307px,
    467px 349px,
    100% 100%,
    100% 100%;
  background-position:
    0 0,
    41px 23px,
    83px 61px,
    127px 89px,
    19px 137px,
    173px 43px,
    211px 151px,
    0 0,
    0 0;
  mask-image: radial-gradient(ellipse 76% 62% at 50% 50%, #000 0 64%, transparent 100%);
}

/* Use the generated wallpaper asset as the real black-hole visual. */
.section-thinking {
  background:
    radial-gradient(ellipse 90% 58% at 50% 55%, rgba(255, 237, 202, 0.055), transparent 62%),
    linear-gradient(180deg, #04070a 0%, #010204 72%, #000 100%);
}

.section-thinking::before {
  opacity: 0.18;
}

.section-thinking::after {
  opacity: 0.74;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.18) 0%, transparent 28%, transparent 68%, rgba(0, 0, 0, 0.76) 100%),
    radial-gradient(ellipse 94% 70% at 50% 54%, transparent 0 55%, rgba(0, 0, 0, 0.72) 86%, rgba(0, 0, 0, 0.96) 100%);
}

.section-thinking .project-event-field {
  isolation: isolate;
  height: clamp(440px, 45vw, 560px);
}

.section-thinking .project-event-field::before {
  content: "";
  position: absolute;
  inset: -7% -8% -8%;
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.12), transparent 28%, rgba(0, 0, 0, 0.2) 100%),
    url("assets/blackhole-cinematic-bg.png") center 54% / cover no-repeat;
  filter:
    saturate(0.96)
    contrast(1.03)
    brightness(0.94);
  pointer-events: none;
}

.section-thinking .project-event-field::after {
  content: "";
  position: absolute;
  inset: -7% -8% -8%;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.72), transparent 18% 82%, rgba(0, 0, 0, 0.72)),
    radial-gradient(ellipse 56% 38% at 50% 53%, transparent 0 48%, rgba(0, 0, 0, 0.2) 76%, rgba(0, 0, 0, 0.72) 100%);
  pointer-events: none;
}

.project-black-hole {
  display: none;
}

.section-thinking .signal-list {
  z-index: 2;
}

.section-thinking .signal-list article {
  border-color: rgba(255, 244, 220, 0.2);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.105), rgba(155, 223, 255, 0.035)),
    rgba(3, 5, 8, 0.56);
}

.section-thinking .signal-list article:first-child {
  border-color: rgba(255, 244, 220, 0.2);
  background:
    linear-gradient(135deg, rgba(255, 244, 220, 0.105), rgba(155, 223, 255, 0.035)),
    rgba(3, 5, 8, 0.56);
}

.project-node-one {
  left: 1%;
  top: 61%;
}

.project-node-two {
  left: 6%;
  top: 20%;
}

.project-node-three {
  right: 6%;
  top: 20%;
}

.project-node-four {
  left: 17%;
  bottom: 3%;
}

.project-node-five {
  right: 17%;
  bottom: 4%;
}

@media (max-width: 980px) {
  .section-thinking .project-event-field {
    padding-top: clamp(340px, 58vw, 500px);
  }

  .section-thinking .project-event-field::before,
  .section-thinking .project-event-field::after {
    inset: 0 -34%;
  }

  .section-thinking .project-event-field::before {
    background-position: center 52%;
  }
}

@media (max-width: 760px) {
  .section-thinking .project-event-field {
    padding-top: 320px;
  }

  .section-thinking .project-event-field::before,
  .section-thinking .project-event-field::after {
    inset: 0 -64%;
  }
}

.section-thinking .project-archive-status {
  width: min(920px, 72vw);
}

@media (max-width: 980px) {
  .section-thinking .project-archive-status {
    width: 100%;
  }
}

.section-about {
  --about-col-inset: clamp(188px, 19vw, 286px);
  --about-row-one: 31%;
  --about-row-two: 49%;
  --about-row-three: 67%;
  --about-note-left: 50%;
  --about-note-top: 72%;
  --about-note-x: -50%;
  z-index: 38;
  background: transparent !important;
}

.section-projects {
  border-top: 0;
  background: transparent !important;
}

.section-projects::before,
.section-projects::after {
  display: none !important;
}

.section-about::before,
.section-about::after,
.section-about .about-console-v3::before,
.section-about .about-console-v3::after,
.section-about .about-letter-cloud,
.section-about .about-core,
.section-about .about-keyword-field > .about-ring {
  display: none !important;
}

.section-about .about-keyword-head {
  top: clamp(48px, 7.6vh, 86px);
}

.section-about .about-keyword-head h2 {
  position: relative;
  display: inline-grid;
  place-items: center;
  padding: 0 12px 18px;
  color: rgba(250, 246, 236, 0.98);
  text-shadow:
    0 12px 30px rgba(0, 0, 0, 0.72),
    0 0 24px rgba(245, 216, 167, 0.22),
    0 0 44px rgba(155, 223, 255, 0.1);
}

.section-about .about-keyword-head h2::before,
.section-about .about-keyword-head h2::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.section-about .about-keyword-head h2::before {
  inset: -10px -30px 4px;
  background: linear-gradient(104deg, transparent 0 34%, rgba(255, 255, 255, 0.5) 46%, transparent 58% 100%);
  opacity: 0.36;
  mix-blend-mode: screen;
  transform: translateX(-56%) skewX(-12deg);
  animation: aboutTitleSweep 3.8s ease-in-out infinite;
}

.section-about .about-keyword-head h2::after {
  left: 8%;
  right: 8%;
  bottom: 0;
  height: 1px;
  background:
    linear-gradient(90deg, transparent, rgba(245, 216, 167, 0.95), rgba(155, 223, 255, 0.42), transparent);
  box-shadow:
    0 0 18px rgba(245, 216, 167, 0.36),
    0 0 32px rgba(155, 223, 255, 0.16);
}

.section-about .keyword-node {
  z-index: 8;
  min-width: clamp(204px, 18vw, 274px);
  padding: 0;
  color: rgba(248, 242, 232, 0.72);
  cursor: pointer;
  pointer-events: auto;
  filter: drop-shadow(0 12px 22px rgba(0, 0, 0, 0.56));
}

.section-about .keyword-node strong {
  position: relative;
  display: inline-block;
  width: max-content;
  max-width: 12ch;
  padding: 8px 16px 10px;
  border-top: 1px solid rgba(248, 242, 232, 0.14);
  border-bottom: 1px solid rgba(248, 242, 232, 0.1);
  background:
    linear-gradient(90deg, rgba(248, 242, 232, 0.07), rgba(248, 242, 232, 0.018) 58%, transparent);
  font-size: clamp(27px, 2.75vw, 45px);
  line-height: 1.06;
  white-space: normal;
  text-shadow:
    0 3px 14px rgba(0, 0, 0, 0.92),
    0 0 15px rgba(245, 216, 167, 0.14);
}

.section-about .keyword-ai strong,
.section-about .keyword-content strong,
.section-about .keyword-explorer strong {
  background:
    linear-gradient(270deg, rgba(248, 242, 232, 0.07), rgba(248, 242, 232, 0.018) 58%, transparent);
}

.section-about .keyword-node::before,
.section-about .keyword-node::after {
  content: "";
  position: absolute;
  top: 50%;
  display: block;
  pointer-events: none;
  transform: translateY(-50%);
  transition:
    opacity 180ms ease,
    box-shadow 180ms ease,
    width 180ms ease;
}

.section-about .keyword-node::before {
  right: -5px;
  z-index: 2;
  width: 7px;
  height: 7px;
  border: 1px solid rgba(245, 216, 167, 0.72);
  border-radius: 50%;
  background: rgba(248, 242, 232, 0.78);
  box-shadow:
    0 0 12px rgba(245, 216, 167, 0.42),
    0 0 24px rgba(155, 223, 255, 0.18);
}

.section-about .keyword-node::after {
  right: -86px;
  width: 78px;
  height: 1px;
  background: linear-gradient(90deg, rgba(245, 216, 167, 0.76), rgba(155, 223, 255, 0.22), transparent);
  opacity: 0.66;
}

.section-about .keyword-ai::before,
.section-about .keyword-content::before,
.section-about .keyword-explorer::before {
  right: auto;
  left: -5px;
}

.section-about .keyword-ai::after,
.section-about .keyword-content::after,
.section-about .keyword-explorer::after {
  right: auto;
  left: -86px;
  background: linear-gradient(270deg, rgba(245, 216, 167, 0.76), rgba(155, 223, 255, 0.22), transparent);
}

.section-about .keyword-node:hover,
.section-about .keyword-node.is-active {
  color: rgba(250, 246, 236, 1);
  transform: translateY(-4px);
}

.section-about .keyword-node:hover::before,
.section-about .keyword-node.is-active::before {
  box-shadow:
    0 0 18px rgba(245, 216, 167, 0.72),
    0 0 34px rgba(155, 223, 255, 0.34);
}

.section-about .keyword-node:hover::after,
.section-about .keyword-node.is-active::after {
  width: 78px;
  opacity: 0.95;
}

.section-about .keyword-node.is-active strong {
  border-color: rgba(245, 216, 167, 0.34);
  background:
    linear-gradient(90deg, rgba(245, 216, 167, 0.11), rgba(155, 223, 255, 0.035), transparent);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 0 26px rgba(245, 216, 167, 0.12);
}

.section-about .keyword-ai.is-active strong,
.section-about .keyword-content.is-active strong,
.section-about .keyword-explorer.is-active strong {
  background:
    linear-gradient(270deg, rgba(245, 216, 167, 0.11), rgba(155, 223, 255, 0.035), transparent);
}

.section-about .about-keyword-detail {
  left: var(--about-note-left);
  top: var(--about-note-top);
  bottom: auto;
  z-index: 9;
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: center;
  width: min(660px, 46vw);
  min-height: 0;
  padding: 9px 16px 10px 18px;
  border: 0;
  border-left: 1px solid rgba(245, 216, 167, 0.72);
  border-radius: 0;
  background:
    linear-gradient(90deg, rgba(3, 3, 3, 0.4), rgba(3, 3, 3, 0.18) 48%, transparent),
    linear-gradient(90deg, rgba(245, 216, 167, 0.08), transparent 64%);
  opacity: 0;
  backdrop-filter: none;
  box-shadow: none;
  transform: translate(var(--about-note-x), 8px);
}

.section-about[data-note-side="right"] .about-keyword-detail {
  grid-template-columns: 1fr;
  border-left: 0;
  border-right: 1px solid rgba(245, 216, 167, 0.72);
  padding-right: 18px;
  padding-left: 16px;
  text-align: right;
  background:
    linear-gradient(270deg, rgba(3, 3, 3, 0.4), rgba(3, 3, 3, 0.18) 48%, transparent),
    linear-gradient(270deg, rgba(245, 216, 167, 0.08), transparent 64%);
}

.section-about .about-keyword-detail::before {
  left: -1px;
  top: 0;
  width: 1px;
  height: 100%;
  background: linear-gradient(180deg, transparent, rgba(245, 216, 167, 0.92), transparent);
  box-shadow: 0 0 18px rgba(245, 216, 167, 0.42);
}

.section-about[data-note-side="right"] .about-keyword-detail::before {
  left: auto;
  right: -1px;
}

.section-about .about-keyword-detail h3 {
  display: none;
}

.section-about[data-note-side="right"] .about-keyword-detail h3 {
  grid-column: auto;
}

.section-about .about-keyword-detail p:last-of-type {
  max-width: 100%;
  color: rgba(248, 242, 232, 0.84);
  font-size: clamp(14px, 1vw, 16px);
  line-height: 1.5;
  overflow-wrap: anywhere;
  text-align: left;
  white-space: normal;
}

.section-about[data-note-side="right"] .about-keyword-detail p:last-of-type {
  justify-self: end;
  text-align: right;
}

.section-about .about-console-v3.has-active .about-keyword-detail {
  opacity: 0;
  transform: translate(var(--about-note-x), 8px);
}

.section-about .about-console-v3.is-scanning .about-keyword-detail {
  opacity: 1;
  animation: aboutSignalNoteIn 520ms ease both;
}

.section-about .keyword-taste,
.section-about .keyword-project,
.section-about .keyword-long {
  left: var(--about-col-inset);
}

.section-about .keyword-ai,
.section-about .keyword-content,
.section-about .keyword-explorer {
  right: var(--about-col-inset);
}

.section-about .keyword-taste,
.section-about .keyword-ai {
  top: var(--about-row-one);
}

.section-about .keyword-project,
.section-about .keyword-content {
  top: var(--about-row-two);
}

.section-about .keyword-long,
.section-about .keyword-explorer {
  top: var(--about-row-three);
}

@keyframes aboutTitleSweep {
  0%,
  18% {
    transform: translateX(-62%) skewX(-12deg);
    opacity: 0;
  }

  38% {
    opacity: 0.38;
  }

  64%,
  100% {
    transform: translateX(62%) skewX(-12deg);
    opacity: 0;
  }
}

@keyframes aboutSignalNoteIn {
  0% {
    opacity: 0;
    filter: blur(3px);
    transform: translate(var(--about-note-x), 12px);
  }

  100% {
    opacity: 1;
    filter: blur(0);
    transform: translate(var(--about-note-x), 0);
  }
}

@media (max-width: 760px) {
  .section-about {
    --about-col-inset: clamp(14px, 4.8vw, 22px);
    --about-row-one: 27%;
    --about-row-two: 45%;
    --about-row-three: 64%;
    min-height: 100svh;
    background-position: center top;
  }

  .section-about > .about-shell.about-shell-v3,
  .about-shell-v3,
  .about-console-v3,
  .about-keyword-field {
    min-height: 100svh;
  }

  .section-about > .about-shell.about-shell-v3 {
    padding: 0;
  }

  .about-keyword-head {
    left: 50%;
    top: clamp(12px, 3.8vh, 30px);
    width: max-content;
    max-width: 94vw;
    justify-items: center;
    text-align: center;
    transform: translateX(-50%);
  }

  .about-keyword-head h2 {
    font-size: clamp(33px, 10.6vw, 43px);
    line-height: 0.9;
    white-space: nowrap;
  }

  .about-keyword-field {
    display: block;
    padding: 0;
  }

  .section-about .keyword-node {
    position: absolute;
    min-width: 0;
    width: min(31vw, 116px);
    padding: 0;
  }

  .section-about .keyword-node strong {
    max-width: 8.8ch;
    padding: 3px 5px 5px;
    border-top: 0;
    background: transparent;
    font-size: clamp(14px, 4.4vw, 19px);
    line-height: 1.05;
  }

  .section-about .keyword-ai strong,
  .section-about .keyword-content strong,
  .section-about .keyword-explorer strong {
    background: transparent;
  }

  .section-about .keyword-node::after {
    width: 22px;
    right: -28px;
  }

  .section-about .keyword-ai::after,
  .section-about .keyword-content::after,
  .section-about .keyword-explorer::after {
    left: -28px;
  }

  .section-about .keyword-node:hover::after,
  .section-about .keyword-node.is-active::after {
    width: 30px;
  }

  .section-about .keyword-taste {
    left: var(--about-col-inset);
    top: var(--about-row-one);
  }

  .section-about .keyword-ai {
    right: var(--about-col-inset);
    top: var(--about-row-one);
    justify-items: end;
    text-align: right;
  }

  .section-about .keyword-project {
    left: var(--about-col-inset);
    top: var(--about-row-two);
  }

  .section-about .keyword-content {
    right: var(--about-col-inset);
    top: var(--about-row-two);
    justify-items: end;
    text-align: right;
  }

  .section-about .keyword-long {
    left: var(--about-col-inset);
    top: var(--about-row-three);
  }

  .section-about .keyword-explorer {
    right: var(--about-col-inset);
    top: var(--about-row-three);
    justify-items: end;
    text-align: right;
  }

  .section-about .about-keyword-detail {
    left: var(--about-note-left);
    top: var(--about-note-top);
    bottom: auto;
    grid-template-columns: 1fr;
    width: min(calc(100vw - 28px), 372px);
    min-height: 0;
    padding: 10px 13px 11px 15px;
    transform: translate(var(--about-note-x), 8px);
  }

  .section-about .about-keyword-detail h3 {
    grid-row: auto;
    min-width: 0;
  }

  .section-about .about-keyword-detail p:last-of-type {
    font-size: 12.5px;
    line-height: 1.48;
    white-space: normal;
  }

  .section-about .about-console-v3.has-active .about-keyword-detail {
    transform: translate(var(--about-note-x), 8px);
  }
}

/* Final world-continuity override: one fixed starship scene under every chapter. */
.world-backdrop {
  position: fixed !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100svh !important;
  object-fit: cover !important;
  object-position: center !important;
  pointer-events: none !important;
  opacity: calc(0.08 + var(--hero-progress) * 0.26) !important;
  filter: saturate(0.76) contrast(1.08) brightness(0.58) !important;
  transform:
    translate3d(
      calc(var(--mouse-x) * -5px),
      calc(var(--mouse-y) * -3px),
      0
    )
    scale(1.035) !important;
  transform-origin: center !important;
}

.section-about,
.section-thinking,
.section-ai,
.section-contact {
  background: transparent !important;
  isolation: isolate;
}

.section-thinking::before,
.section-ai::before,
.section-contact::before {
  opacity: 0.34 !important;
  mix-blend-mode: screen !important;
}

.section-thinking::after,
.section-ai::after,
.section-contact::after {
  opacity: 1 !important;
  background:
    radial-gradient(ellipse 54% 58% at 50% 50%, rgba(1, 3, 6, 0.18), rgba(1, 3, 6, 0.54) 68%, rgba(1, 3, 6, 0.84) 100%),
    linear-gradient(90deg, rgba(1, 3, 6, 0.72), rgba(1, 3, 6, 0.32) 28%, rgba(1, 3, 6, 0.44) 70%, rgba(1, 3, 6, 0.76)) !important;
  mix-blend-mode: normal !important;
}

.section-thinking::after {
  background:
    radial-gradient(circle at var(--project-focus-x, 50%) var(--project-focus-y, 52%), rgba(1, 3, 6, 0.18), rgba(1, 3, 6, 0.46) 48%, rgba(1, 3, 6, 0.78) 84%),
    linear-gradient(180deg, rgba(1, 3, 6, 0.54), rgba(1, 3, 6, 0.32) 42%, rgba(1, 3, 6, 0.76)) !important;
}

.section-ai::after {
  background:
    radial-gradient(ellipse 46% 58% at 50% 52%, rgba(155, 223, 255, 0.035), rgba(1, 3, 6, 0.46) 58%, rgba(1, 3, 6, 0.84) 100%),
    linear-gradient(90deg, rgba(1, 3, 6, 0.76), rgba(1, 3, 6, 0.36) 34%, rgba(1, 3, 6, 0.44) 66%, rgba(1, 3, 6, 0.78)) !important;
}

.contact-minimal::after {
  background:
    radial-gradient(ellipse 34% 56% at 50% 52%, rgba(1, 2, 4, 0.12), rgba(1, 2, 4, 0.5) 76%, rgba(1, 2, 4, 0.78)),
    linear-gradient(90deg, rgba(1, 2, 4, 0.38), rgba(1, 2, 4, 0.2) 28%, rgba(1, 2, 4, 0.44) 64%, rgba(1, 2, 4, 0.7)) !important;
}

.contact-minimal .contact-hero-backdrop {
  display: none !important;
}

/* The roaming robot doubles as a lightweight language switch. */
.robot-language-toggle {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 43;
  width: clamp(86px, 7.8vw, 144px);
  aspect-ratio: 1;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(248, 252, 255, 0.92);
  cursor: pointer;
  pointer-events: auto;
  transform:
    translate3d(var(--robot-x), var(--robot-y), 0)
    translate(-50%, -50%)
    scale(var(--robot-scale))
    rotate(var(--robot-tilt));
  transform-origin: 50% 58%;
  -webkit-tap-highlight-color: transparent;
}

.robot-language-toggle::before {
  content: "";
  position: absolute;
  inset: 11%;
  border-radius: 999px;
  border: 1px solid rgba(155, 223, 255, 0.22);
  box-shadow:
    0 0 18px rgba(155, 223, 255, 0.16),
    inset 0 0 20px rgba(155, 223, 255, 0.08);
  opacity: 0;
  transform: scale(0.82);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.robot-language-toggle:hover::before,
.robot-language-toggle:focus-visible::before,
.robot-language-toggle.is-switching::before {
  opacity: 1;
  transform: scale(1);
}

.robot-language-code {
  position: absolute;
  right: 2%;
  top: 12%;
  min-width: 34px;
  padding: 4px 8px;
  border: 1px solid rgba(155, 223, 255, 0.34);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(7, 15, 25, 0.78), rgba(255, 255, 255, 0.04));
  color: rgba(231, 249, 255, 0.96);
  font-family: "Space Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.16em;
  text-align: center;
  text-shadow: 0 0 12px rgba(155, 223, 255, 0.55);
  box-shadow:
    0 0 16px rgba(155, 223, 255, 0.22),
    inset 0 0 12px rgba(155, 223, 255, 0.08);
}

.robot-language-hint {
  position: absolute;
  left: 50%;
  top: calc(100% + 4px);
  padding: 4px 8px;
  border: 1px solid rgba(155, 223, 255, 0.18);
  border-radius: 999px;
  background: rgba(3, 8, 14, 0.72);
  color: rgba(226, 241, 246, 0.74);
  font-family: "Space Mono", "SFMono-Regular", Consolas, monospace;
  font-size: 9px;
  line-height: 1;
  letter-spacing: 0.12em;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(-50%) translateY(-4px);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
  backdrop-filter: blur(10px);
}

.robot-language-toggle:hover .robot-language-hint,
.robot-language-toggle:focus-visible .robot-language-hint {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.robot-language-toggle.is-switching .robot-language-code {
  animation: robotLanguagePulse 520ms ease;
}

body.is-language-switching [data-i18n],
body.is-language-switching #abilityTitle,
body.is-language-switching #abilityBody,
body.is-language-switching #aboutBody,
body.is-language-switching #projectStatusTitle,
body.is-language-switching #projectStatusBody,
body.is-language-switching #workflowDetailBody {
  animation: languageTextFlicker 420ms ease both;
}

body[data-language="cn"] .contact-copy-row strong::after {
  content: "复制";
}

body[data-language="cn"] .contact-copy-row.is-copied strong::after {
  content: "已复制";
}

@keyframes robotLanguagePulse {
  0%,
  100% {
    transform: translateY(0) scale(1);
    filter: brightness(1);
  }
  42% {
    transform: translateY(-2px) scale(1.12);
    filter: brightness(1.55);
  }
}

@keyframes languageTextFlicker {
  0% {
    opacity: 0.45;
    filter: blur(1.8px);
    transform: translateY(1px);
  }
  40% {
    opacity: 1;
    filter: blur(0);
  }
  64% {
    opacity: 0.72;
  }
  100% {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
  }
}

@media (max-width: 760px) {
  .robot-language-toggle {
    width: clamp(66px, 16vw, 94px);
  }

  .robot-language-code {
    min-width: 30px;
    padding: 4px 7px;
    font-size: 9px;
  }

  .robot-language-hint {
    display: none;
  }
}

.robot-audio-toggle {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 44;
  display: grid;
  width: 32px;
  height: 32px;
  min-width: 0;
  min-height: 0;
  place-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: rgba(248, 252, 255, 0.9);
  cursor: pointer;
  pointer-events: auto;
  transform:
    translate3d(var(--robot-x), var(--robot-y), 0)
    translate(calc(-50% - clamp(38px, 4.2vw, 64px)), calc(-50% + clamp(24px, 2.8vw, 42px)))
    scale(var(--robot-scale));
  transform-origin: center;
  -webkit-tap-highlight-color: transparent;
}

.robot-audio-toggle::before,
.robot-audio-toggle::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 999px;
  border: 1px solid rgba(245, 216, 167, 0.18);
  opacity: 0;
  transform: scale(0.78);
  transition:
    opacity 180ms ease,
    transform 180ms ease;
  pointer-events: none;
}

.robot-audio-toggle::after {
  inset: 0;
  border-color: rgba(155, 223, 255, 0.14);
}

.robot-audio-toggle:hover::before,
.robot-audio-toggle:focus-visible::before,
.robot-audio-toggle.is-playing::before {
  opacity: 1;
  transform: scale(1);
}

.robot-audio-toggle.is-playing::after {
  animation: robotAudioWave 1.8s ease-in-out infinite;
}

.robot-audio-code {
  position: relative;
  display: grid;
  width: 18px;
  height: 18px;
  min-width: 0;
  place-items: center;
  padding: 0;
  border: 1px solid rgba(245, 216, 167, 0.18);
  border-radius: 50%;
  background: rgba(7, 12, 18, 0.34);
  color: rgba(255, 241, 214, 0.9);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 15px;
  font-weight: 700;
  line-height: 18px;
  letter-spacing: 0;
  text-align: center;
  text-shadow: 0 0 10px rgba(245, 216, 167, 0.46);
  box-shadow:
    0 0 12px rgba(245, 216, 167, 0.08),
    inset 0 0 10px rgba(245, 216, 167, 0.05);
  backdrop-filter: blur(8px);
  transition:
    border-color 180ms ease,
    color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.robot-audio-hint {
  display: none;
}

.robot-audio-toggle.is-playing .robot-audio-code {
  border-color: rgba(245, 216, 167, 0.58);
  color: rgba(255, 247, 232, 0.98);
  box-shadow:
    0 0 16px rgba(245, 216, 167, 0.34),
    0 0 26px rgba(155, 223, 255, 0.16),
    inset 0 0 10px rgba(245, 216, 167, 0.14);
  animation: robotAudioPulse 1.8s ease-in-out infinite;
}

.robot-audio-toggle.is-unavailable .robot-audio-code {
  border-color: rgba(255, 112, 112, 0.42);
  color: rgba(255, 207, 207, 0.92);
}

body.is-bgm-playing .robot-companion {
  filter:
    drop-shadow(0 0 22px rgba(245, 216, 167, 0.46))
    drop-shadow(0 0 34px rgba(155, 223, 255, 0.22))
    drop-shadow(0 16px 28px rgba(0, 0, 0, 0.42));
}

.robot-companion.is-audio-pulse {
  animation: robotAudioGlow 760ms ease;
}

@keyframes robotAudioPulse {
  0%,
  100% {
    transform: translateY(0);
    filter: brightness(1);
  }
  50% {
    transform: translateY(-1px);
    filter: brightness(1.28);
  }
}

@keyframes robotAudioWave {
  0% {
    opacity: 0;
    transform: scale(0.72);
  }
  38% {
    opacity: 0.72;
  }
  100% {
    opacity: 0;
    transform: scale(1.24);
  }
}

@keyframes robotAudioGlow {
  0%,
  100% {
    transform:
      translate3d(var(--robot-x), var(--robot-y), 0)
      translate(-50%, -50%)
      scale(var(--robot-scale))
      rotate(var(--robot-tilt));
  }
  48% {
    transform:
      translate3d(var(--robot-x), var(--robot-y), 0)
      translate(-50%, -50%)
      scale(calc(var(--robot-scale) * 1.035))
      rotate(var(--robot-tilt));
  }
}

@media (max-width: 760px) {
  .robot-audio-toggle {
    width: 30px;
    height: 30px;
    transform:
      translate3d(var(--robot-x), var(--robot-y), 0)
      translate(calc(-50% - 32px), calc(-50% + 28px))
      scale(var(--robot-scale));
  }

  .robot-audio-code {
    width: 16px;
    height: 16px;
    font-size: 13px;
    line-height: 16px;
  }
}

/* #thinking black-hole motion overlay. */
.section-thinking {
  --blackhole-motion-boost: 0;
}

.section-thinking .project-event-field::before {
  animation: blackholeImageBreath 11s ease-in-out infinite !important;
  transform-origin: center 54%;
  will-change: filter, transform;
}

.blackhole-motion {
  position: absolute;
  inset: -7% -8% -8%;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: screen;
}

.blackhole-motion i {
  position: absolute;
  display: block;
  pointer-events: none;
}

.blackhole-flow {
  left: -16%;
  right: -16%;
  top: 47%;
  height: clamp(58px, 6.8vw, 96px);
  border-radius: 50%;
  opacity: calc(0.34 + var(--blackhole-motion-boost) * 0.18);
  background:
    repeating-linear-gradient(
      92deg,
      transparent 0 24px,
      rgba(255, 255, 246, 0.16) 26px 33px,
      rgba(255, 198, 139, 0.11) 34px 48px,
      transparent 50px 118px
    ),
    linear-gradient(90deg, transparent 0 10%, rgba(255, 255, 246, 0.38) 35%, rgba(255, 184, 113, 0.18) 68%, transparent 94%);
  filter: blur(1.8px);
  transform: translateY(-50%) rotate(-1.4deg) scaleY(0.46);
  animation: blackholeDiskFlow 8.5s linear infinite;
}

.blackhole-flow-b {
  top: 55%;
  height: clamp(70px, 8vw, 116px);
  opacity: calc(0.18 + var(--blackhole-motion-boost) * 0.14);
  filter: blur(5px);
  transform: translateY(-50%) rotate(-2deg) scaleY(0.34);
  animation-duration: 13s;
  animation-direction: reverse;
}

.blackhole-glow {
  left: 50%;
  top: 54%;
  width: clamp(360px, 45vw, 660px);
  aspect-ratio: 1;
  border-radius: 50%;
  opacity: calc(0.28 + var(--blackhole-motion-boost) * 0.1);
  background:
    radial-gradient(circle, transparent 0 42%, rgba(255, 255, 246, 0.24) 47%, rgba(255, 197, 143, 0.12) 58%, transparent 70%);
  filter: blur(10px);
  transform: translate(-50%, -50%) scaleY(0.72);
  animation: blackholeGlowPulse 7.6s ease-in-out infinite;
}

.blackhole-stars {
  inset: -10%;
  opacity: calc(0.26 + var(--blackhole-motion-boost) * 0.1);
  background:
    repeating-linear-gradient(105deg, transparent 0 56px, rgba(255, 255, 255, 0.32) 58px 61px, transparent 63px 156px),
    repeating-linear-gradient(72deg, transparent 0 92px, rgba(155, 223, 255, 0.14) 94px 96px, transparent 98px 220px);
  filter: blur(0.3px);
  mask-image: radial-gradient(ellipse 82% 66% at 50% 54%, #000 0 58%, transparent 100%);
  transform: translate3d(0, 0, 0);
  animation: blackholeStarDrift 18s linear infinite;
}

.blackhole-stars-b {
  opacity: calc(0.16 + var(--blackhole-motion-boost) * 0.12);
  transform: rotate(180deg);
  animation-duration: 27s;
  animation-direction: reverse;
}

.section-thinking:has(.project-module:hover) {
  --blackhole-motion-boost: 1;
}

.section-thinking:has(.project-module:hover) .blackhole-flow {
  animation-duration: 5.6s;
}

.section-thinking:has(.project-module:hover) .blackhole-glow {
  opacity: 0.42;
}

@keyframes blackholeImageBreath {
  0%,
  100% {
    filter: saturate(0.96) contrast(1.03) brightness(0.92);
    transform: scale(1);
  }

  50% {
    filter: saturate(1.03) contrast(1.08) brightness(1);
    transform: scale(1.018);
  }
}

@keyframes blackholeDiskFlow {
  from {
    background-position: 0 0, 0 0;
  }

  to {
    background-position: 360px 0, 0 0;
  }
}

@keyframes blackholeGlowPulse {
  0%,
  100% {
    transform: translate(-50%, -50%) scaleY(0.68) scale(0.98);
    filter: blur(12px);
  }

  50% {
    transform: translate(-50%, -50%) scaleY(0.75) scale(1.04);
    filter: blur(8px);
  }
}

@keyframes blackholeStarDrift {
  from {
    background-position: 0 0, 0 0;
  }

  to {
    background-position: 460px -180px, -260px 160px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .section-thinking .project-event-field::before,
  .blackhole-flow,
  .blackhole-glow,
  .blackhole-stars {
    animation: none !important;
  }
}

/* Tone the motion down so the generated black-hole asset stays dominant. */
.blackhole-flow {
  opacity: calc(0.18 + var(--blackhole-motion-boost) * 0.16);
  filter: blur(2.6px);
}

.blackhole-flow-b {
  opacity: calc(0.1 + var(--blackhole-motion-boost) * 0.1);
  filter: blur(7px);
}

.blackhole-stars {
  inset: -6% -10%;
  opacity: calc(0.08 + var(--blackhole-motion-boost) * 0.05);
  background:
    repeating-linear-gradient(104deg, transparent 0 108px, rgba(255, 255, 255, 0.18) 110px 112px, transparent 114px 260px),
    repeating-linear-gradient(72deg, transparent 0 180px, rgba(155, 223, 255, 0.1) 182px 184px, transparent 186px 360px);
  filter: blur(0.8px);
  mask-image:
    linear-gradient(180deg, transparent 0 18%, #000 32%, #000 76%, transparent 100%),
    radial-gradient(ellipse 86% 58% at 50% 56%, #000 0 48%, transparent 100%);
}

.blackhole-stars-b {
  opacity: calc(0.05 + var(--blackhole-motion-boost) * 0.04);
}

.section-thinking:has(.project-module:hover) .blackhole-stars {
  opacity: 0.13;
}

/* Canvas layer owns the visible black-hole motion; the old CSS streaks stay quiet. */
.section-thinking .project-event-field {
  width: min(1280px, 92vw);
  overflow: visible;
}

.section-thinking .project-event-field::before,
.section-thinking .project-event-field::after,
.blackhole-flow-canvas,
.blackhole-motion {
  top: clamp(-86px, -6vw, -48px);
  right: auto;
  bottom: auto;
  left: 50%;
  width: min(2080px, 118vw);
  height: calc(100% + clamp(112px, 13vw, 170px));
  transform: translateX(-50%);
}

.section-thinking .project-event-field::before {
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.08), transparent 30%, rgba(0, 0, 0, 0.18) 100%),
    url("assets/blackhole-cinematic-bg.png") center 55% / cover no-repeat;
  filter:
    saturate(1.02)
    contrast(1.06)
    brightness(0.95);
  -webkit-mask-image: radial-gradient(ellipse 78% 66% at 50% 55%, #000 0 58%, rgba(0, 0, 0, 0.82) 72%, transparent 100%);
  mask-image: radial-gradient(ellipse 78% 66% at 50% 55%, #000 0 58%, rgba(0, 0, 0, 0.82) 72%, transparent 100%);
}

.section-thinking .project-event-field::after {
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.86), rgba(0, 0, 0, 0.22) 13%, transparent 28% 72%, rgba(0, 0, 0, 0.22) 87%, rgba(0, 0, 0, 0.86)),
    radial-gradient(ellipse 60% 42% at 50% 54%, transparent 0 48%, rgba(0, 0, 0, 0.1) 74%, rgba(0, 0, 0, 0.66) 100%);
}

.blackhole-flow-canvas {
  position: absolute;
  z-index: 3;
  display: block;
  pointer-events: none;
  opacity: 0.96;
  mix-blend-mode: screen;
  filter: saturate(1.08) contrast(1.06);
  -webkit-mask-image: radial-gradient(ellipse 74% 62% at 50% 56%, #000 0 54%, rgba(0, 0, 0, 0.86) 70%, transparent 100%);
  mask-image: radial-gradient(ellipse 74% 62% at 50% 56%, #000 0 54%, rgba(0, 0, 0, 0.86) 70%, transparent 100%);
}

.blackhole-motion {
  z-index: 4;
  opacity: 0.58;
}

.blackhole-flow,
.blackhole-stars {
  display: none;
}

.blackhole-glow {
  opacity: calc(0.22 + var(--blackhole-motion-boost) * 0.08);
}

@keyframes blackholeImageBreath {
  0%,
  100% {
    filter: saturate(1) contrast(1.05) brightness(0.92);
    transform: translateX(-50%) scale(1.01);
  }

  50% {
    filter: saturate(1.08) contrast(1.1) brightness(1);
    transform: translateX(-50%) scale(1.035);
  }
}

@media (max-width: 760px) {
  .section-thinking .project-event-field::before,
  .section-thinking .project-event-field::after,
  .blackhole-flow-canvas,
  .blackhole-motion {
    top: -34px;
    width: min(1280px, 206vw);
    height: calc(100% + 88px);
  }

  .blackhole-flow-canvas {
    opacity: 0.86;
  }
}

/* The black hole now belongs to the whole #thinking space, not the card stage. */
.section-thinking {
  --thinking-enter: 1;
  --thinking-exit: 0;
  --thinking-presence: 1;
  --thinking-edge: 0;
  --thinking-depth: 1;
  --thinking-content-y: 0px;
  --thinking-content-scale: 1;
  box-shadow: none;
}

.thinking-blackhole-bg {
  position: absolute !important;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  opacity: 0.96;
  transform: translateZ(0) scale(1.04);
  transform-origin: center 56%;
  will-change: auto;
  contain: paint;
  backface-visibility: hidden;
}

.section-thinking .blackhole-archive {
  opacity: calc(0.16 + var(--thinking-presence) * 0.84);
  transform:
    translate3d(0, var(--thinking-content-y), 0)
    scale(var(--thinking-content-scale));
  transform-origin: center center;
  will-change: opacity, transform;
}

.thinking-blackhole-bg::before,
.thinking-blackhole-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.thinking-blackhole-bg::before {
  z-index: 0;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.1), transparent 32%, rgba(0, 0, 0, 0.22) 100%),
    url("assets/blackhole-cinematic-bg.png") center 58% / cover no-repeat;
  opacity: 0.96;
  transform-origin: center 58%;
  transform: scale(1.025);
}

.thinking-blackhole-bg::after {
  display: none;
  z-index: 5;
  opacity: 0.82;
  background:
    linear-gradient(180deg, rgb(1 3 6 / 0.96) 0%, rgb(1 3 6 / 0.56) 18%, transparent 38% 66%, rgb(1 3 6 / 0.56) 86%, rgb(1 3 6 / 0.96) 100%),
    linear-gradient(90deg, rgba(1, 3, 6, 0.78), rgba(1, 3, 6, 0.16) 18%, transparent 34% 66%, rgba(1, 3, 6, 0.16) 82%, rgba(1, 3, 6, 0.78)),
    radial-gradient(ellipse 62% 48% at 50% 58%, transparent 0 54%, rgba(1, 3, 6, 0.22) 76%, rgba(1, 3, 6, 0.64) 100%);
}

.section-thinking .project-event-field::before,
.section-thinking .project-event-field::after {
  content: none !important;
  display: none !important;
}

.section-projects {
  --projects-thinking-handoff: 0;
  --projects-thinking-fade: 0;
  box-shadow: none;
}

.section-projects .ability-showcase {
  opacity: 1;
  transform: none;
  will-change: auto;
}

.section-projects::after {
  display: none !important;
}

.thinking-blackhole-bg .blackhole-flow-canvas,
.thinking-blackhole-bg .blackhole-motion {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: none;
}

.thinking-blackhole-bg .blackhole-flow-canvas {
  z-index: 2;
  opacity: 0.62;
  mix-blend-mode: normal;
}

.thinking-blackhole-bg .blackhole-motion {
  display: none;
}

.thinking-blackhole-bg .blackhole-glow {
  left: 50%;
  top: 58%;
  width: clamp(520px, 52vw, 940px);
}

@keyframes blackholeImageBreath {
  0%,
  100% {
    filter: saturate(1) contrast(1.05) brightness(0.9);
    transform: scale(1.015);
  }

  50% {
    filter: saturate(1.08) contrast(1.1) brightness(0.99);
    transform: scale(1.045);
  }
}

@media (max-width: 760px) {
  .thinking-blackhole-bg::before {
    background-position: center 62%;
  }

  .thinking-blackhole-bg .blackhole-flow-canvas {
    opacity: 0.78;
  }

  .thinking-blackhole-bg .blackhole-glow {
    top: 60%;
    width: 760px;
  }
}

.contact-minimal-wrap {
  width: min(1240px, 88vw) !important;
  grid-template-columns: minmax(360px, 0.82fr) minmax(460px, 0.88fr) !important;
  gap: clamp(34px, 4.4vw, 70px) !important;
}

.contact-build-copy h2 {
  font-size: clamp(58px, 4.9vw, 88px) !important;
}

.contact-simple-row {
  grid-template-columns: minmax(108px, 0.34fr) minmax(0, 1fr) !important;
  gap: clamp(18px, 2.8vw, 52px) !important;
}

.contact-copy-row strong::after {
  content: "COPY";
  display: inline-block;
  margin-left: 12px;
  color: rgba(155, 223, 255, 0.52);
  font-size: 10px;
  letter-spacing: 0.12em;
  vertical-align: 0.08em;
}

.contact-copy-row.is-copied strong::after {
  content: "COPIED";
  color: rgba(155, 223, 255, 0.92);
}

/* Workflow should be only an overlay crew, not a new background scene. */
.section-ai,
.workflow-scene {
  background: transparent !important;
}

.section-ai::before,
.section-ai::after,
.workflow-scene::before,
.workflow-scene::after,
.workflow-scene-shade,
.workflow-scene-image {
  display: none !important;
}

.workflow-scene {
  isolation: auto !important;
}

.workflow-scene .workflow-copy {
  top: clamp(58px, 7svh, 86px) !important;
}

.workflow-detail-card {
  background:
    linear-gradient(135deg, rgba(3, 10, 17, 0.46), rgba(255, 255, 255, 0.018)) !important;
  backdrop-filter: blur(8px) !important;
}

/* Contact returns to the same world, but anchored lower like a final frame. */
.contact-minimal {
  align-content: end !important;
  min-height: 100svh !important;
  padding-top: clamp(48px, 6svh, 72px) !important;
  padding-bottom: clamp(104px, 11svh, 138px) !important;
}

.contact-minimal .contact-hero-backdrop {
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center bottom !important;
  opacity: 0.28 !important;
  filter: saturate(0.72) contrast(1.08) brightness(0.52) !important;
  transform: translateY(4svh) scale(1.01) !important;
  pointer-events: none !important;
}

.contact-minimal-wrap {
  align-items: end !important;
  transform: translateY(clamp(34px, 5svh, 62px));
}

.contact-minimal .contact-footer {
  left: max(5.5vw, calc((100vw - 1240px) / 2)) !important;
  right: max(5.5vw, calc((100vw - 1240px) / 2)) !important;
  bottom: clamp(26px, 4svh, 42px) !important;
}

.hero-image {
  opacity: calc(1 - var(--hero-progress)) !important;
}

.contact-minimal {
  align-content: center !important;
  padding-bottom: clamp(76px, 8svh, 108px) !important;
}

.contact-minimal-wrap {
  transform: translateY(clamp(24px, 4svh, 46px)) !important;
}

.contact-minimal .contact-hero-backdrop {
  opacity: 0.2 !important;
  transform: translateY(5svh) scale(1.01) !important;
}

.contact-minimal .contact-footer {
  position: absolute !important;
  top: auto !important;
  z-index: 3 !important;
  display: flex !important;
  width: auto !important;
  margin: 0 !important;
}

/* Keep the site as one continuous space: no section cuts, no duplicate contact portrait. */
.section {
  border-top: 0 !important;
}

.contact-minimal .contact-hero-backdrop {
  display: none !important;
}

/* Preview: make the final contact frame fully transparent. */
.contact-minimal {
  background: transparent !important;
}

.section-contact::before,
.section-contact::after,
.contact-minimal::before,
.contact-minimal::after {
  opacity: 0 !important;
  background: none !important;
}

.contact-minimal .contact-hero-backdrop {
  display: block !important;
  opacity: 0 !important;
}

/* Contact readability pass: make the channels clearer than the oversized headline. */
.contact-minimal-wrap {
  grid-template-columns: minmax(300px, 0.66fr) minmax(560px, 1.12fr) !important;
  gap: clamp(28px, 3.8vw, 58px) !important;
  align-items: center !important;
}

.contact-build-copy {
  gap: 14px !important;
}

.contact-build-copy h2 {
  max-width: min(560px, 38vw);
  color: rgba(248, 242, 232, 0.78) !important;
  font-size: clamp(46px, 4.1vw, 72px) !important;
  font-weight: 780 !important;
  line-height: 1 !important;
  text-shadow:
    0 18px 48px rgba(0, 0, 0, 0.32),
    0 0 20px rgba(155, 223, 255, 0.08) !important;
}

.contact-build-copy span {
  max-width: 40ch;
  color: rgba(248, 242, 232, 0.64) !important;
  font-size: clamp(14px, 1.05vw, 16px) !important;
}

.contact-simple-list {
  width: 100%;
  gap: 10px;
  padding-top: 0 !important;
}

.contact-simple-row {
  position: relative;
  min-height: clamp(64px, 5.4vw, 78px);
  padding: 0 clamp(14px, 1.6vw, 22px) !important;
  border: 1px solid rgba(248, 242, 232, 0.13) !important;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(8, 16, 24, 0.48), rgba(8, 16, 24, 0.22) 56%, rgba(155, 223, 255, 0.055)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.07),
    0 14px 42px rgba(0, 0, 0, 0.18);
}

.contact-simple-row::before {
  content: "";
  position: absolute;
  left: -1px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(155, 223, 255, 0.86), rgba(248, 242, 232, 0.18));
  opacity: 0.72;
}

.contact-simple-row span {
  color: rgba(155, 223, 255, 0.74) !important;
  font-size: 12px !important;
  letter-spacing: 0.14em !important;
}

.contact-simple-row strong {
  color: rgba(248, 242, 232, 0.94) !important;
  font-size: clamp(16px, 1.35vw, 20px) !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em !important;
  overflow-wrap: anywhere;
}

.contact-copy-row strong::after {
  color: rgba(155, 223, 255, 0.66);
  font-weight: 800;
}

.contact-simple-row:hover {
  border-color: rgba(155, 223, 255, 0.38) !important;
  background:
    linear-gradient(90deg, rgba(9, 22, 32, 0.58), rgba(11, 27, 39, 0.3) 56%, rgba(155, 223, 255, 0.09)) !important;
}

@media (max-width: 980px) {
  .contact-minimal-wrap {
    grid-template-columns: 1fr !important;
    width: min(720px, 88vw) !important;
    transform: translateY(0) !important;
  }

  .contact-build-copy h2 {
    max-width: 100%;
    font-size: clamp(38px, 10vw, 58px) !important;
  }

  .contact-simple-row {
    grid-template-columns: minmax(92px, 0.3fr) minmax(0, 1fr) !important;
  }

  .contact-simple-row strong {
    font-size: clamp(14px, 4vw, 17px) !important;
  }
}

/* Launch loader: the companion robot boots the space before landing beside the avatar. */
body.is-launch-loading {
  overflow: hidden;
}

body.is-launch-loading:not(.is-launch-landing) .robot-companion,
body.is-launch-loading:not(.is-launch-landing) .robot-face,
body.is-launch-loading:not(.is-launch-landing) .robot-language-toggle,
body.is-launch-loading:not(.is-launch-landing) .robot-audio-toggle,
body.is-launch-loading:not(.is-launch-landing) .robot-pointer,
body.is-launch-loading:not(.is-launch-landing) .robot-scan,
body.is-launch-loading:not(.is-launch-landing) .robot-trail {
  opacity: 0 !important;
}

body.is-launch-loading .robot-language-toggle,
body.is-launch-loading .robot-audio-toggle {
  opacity: 0 !important;
  pointer-events: none !important;
}

.launch-loader {
  --launch-orbit-radius: clamp(68px, 7.2vw, 112px);
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: rgba(248, 252, 255, 0.94);
  background:
    radial-gradient(ellipse 62% 38% at 50% 46%, rgba(155, 223, 255, 0.07), transparent 54%),
    radial-gradient(ellipse 44% 28% at 52% 56%, rgba(255, 226, 184, 0.035), transparent 64%),
    linear-gradient(180deg, #000103 0%, #010307 48%, #000102 100%);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    opacity 680ms ease,
    visibility 680ms ease;
}

.launch-loader::before,
.launch-loader::after {
  content: "";
  position: absolute;
  inset: -8%;
  pointer-events: none;
}

.launch-loader::before {
  background:
    radial-gradient(circle at 8% 18%, rgba(248, 252, 255, 0.68) 0 1px, transparent 1.6px),
    radial-gradient(circle at 18% 68%, rgba(155, 223, 255, 0.5) 0 1px, transparent 1.7px),
    radial-gradient(circle at 34% 28%, rgba(248, 242, 232, 0.72) 0 1.2px, transparent 1.9px),
    radial-gradient(circle at 49% 76%, rgba(248, 252, 255, 0.44) 0 1px, transparent 1.6px),
    radial-gradient(circle at 62% 16%, rgba(155, 223, 255, 0.54) 0 1px, transparent 1.8px),
    radial-gradient(circle at 74% 58%, rgba(248, 242, 232, 0.72) 0 1.1px, transparent 1.8px),
    radial-gradient(circle at 91% 32%, rgba(248, 252, 255, 0.58) 0 1px, transparent 1.6px);
  background-size: 360px 280px, 420px 320px, 520px 360px, 460px 340px, 380px 300px, 560px 420px, 440px 340px;
  opacity: 0.84;
  animation: launchStarDrift 22s linear infinite;
}

.launch-loader::after {
  background:
    radial-gradient(ellipse 46% 12% at 64% 42%, rgba(248, 242, 232, 0.12), transparent 70%),
    radial-gradient(ellipse 34% 8% at 28% 60%, rgba(155, 223, 255, 0.08), transparent 72%);
  filter: blur(1px);
  opacity: 0.62;
  transform: rotate(-12deg);
}

.launch-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.launch-loader.is-revealing {
  background:
    radial-gradient(ellipse 42% 34% at var(--launch-land-x, 65vw) var(--launch-land-y, 50svh), rgba(155, 223, 255, 0.11), transparent 62%),
    rgba(0, 2, 5, 0.32);
  backdrop-filter: blur(1px);
}

.launch-loader.is-revealing::before {
  opacity: 0.26;
}

.launch-loader.is-revealing::after,
.launch-loader.is-revealing .launch-loader-grid {
  opacity: 0.08;
}

.launch-loader-grid {
  position: absolute;
  inset: -10%;
  background:
    linear-gradient(rgba(155, 223, 255, 0.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(155, 223, 255, 0.018) 1px, transparent 1px),
    radial-gradient(circle at 50% 50%, transparent 0 28%, rgba(155, 223, 255, 0.045) 28.2% 28.6%, transparent 28.8%);
  background-size: 74px 74px, 74px 74px, 820px 820px;
  mask-image: radial-gradient(circle at 50% 46%, #000 0 42%, transparent 76%);
  opacity: 0.24;
  animation: launchGridDrift 13s linear infinite;
}

.launch-loader-robot-field {
  position: fixed;
  left: 50vw;
  top: 42svh;
  z-index: 2;
  width: clamp(218px, 21vw, 328px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%) scale(1);
  transform-origin: center;
  transition:
    left 1080ms cubic-bezier(0.2, 0.78, 0.2, 1),
    top 1080ms cubic-bezier(0.2, 0.78, 0.2, 1),
    transform 1080ms cubic-bezier(0.2, 0.78, 0.2, 1),
    opacity 520ms ease;
}

.launch-loader.is-landing .launch-loader-robot-field {
  left: var(--launch-land-x, 68vw);
  top: var(--launch-land-y, 50svh);
  transform: translate(-50%, -50%) scale(0.48);
  opacity: 0.96;
}

.launch-loader-robot {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  display: block;
  width: clamp(78px, 7.4vw, 122px);
  height: auto;
  filter:
    drop-shadow(0 0 18px rgba(155, 223, 255, 0.5))
    drop-shadow(0 18px 32px rgba(0, 0, 0, 0.54));
  transform:
    translate(-50%, -50%)
    rotate(0deg)
    translateX(var(--launch-orbit-radius))
    rotate(0deg);
  animation: launchRobotOrbit 2.15s linear infinite;
  transform-origin: 50% 58%;
}

.launch-loader.is-fast .launch-loader-robot {
  animation-duration: 0.54s;
}

.launch-loader.is-landing .launch-loader-robot {
  animation: launchRobotDock 880ms cubic-bezier(0.18, 0.82, 0.22, 1) forwards;
}

.launch-loader-orbit {
  position: absolute;
  left: 50%;
  top: 50%;
  border: 1px solid rgba(155, 223, 255, 0.34);
  border-radius: 50%;
  transform: translate(-50%, -50%) rotate(-18deg);
  pointer-events: none;
  transition:
    opacity 420ms ease,
    transform 420ms ease;
}

.launch-loader-orbit-one {
  width: 76%;
  height: 76%;
  box-shadow: 0 0 18px rgba(155, 223, 255, 0.16);
  animation: launchOrbitSpin 2.8s linear infinite;
}

.launch-loader-orbit-two {
  width: 106%;
  height: 106%;
  border-color: rgba(255, 226, 184, 0.2);
  opacity: 0.62;
  animation: launchOrbitSpin 3.6s linear infinite reverse;
}

.launch-loader.is-fast .launch-loader-orbit-one,
.launch-loader.is-fast .launch-loader-orbit-two {
  animation-duration: 0.7s;
}

.launch-loader.is-landing .launch-loader-orbit {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(240deg) scale(0.18);
}

.launch-loader-copy {
  position: absolute;
  left: 50%;
  top: calc(42svh + clamp(94px, 9vw, 150px));
  z-index: 3;
  width: min(520px, 82vw);
  text-align: center;
  transition:
    opacity 380ms ease,
    transform 380ms ease;
}

.launch-loader.is-landing .launch-loader-copy,
.launch-loader.is-landing .launch-loader-lines {
  opacity: 0;
  transform: translateY(12px);
}

.launch-loader-copy p,
.launch-loader-lines span,
.launch-loader-copy span {
  font-family: "Space Mono", "SFMono-Regular", Consolas, monospace;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.launch-loader-copy p {
  margin: 0 0 8px;
  color: rgba(155, 223, 255, 0.76);
  font-size: clamp(11px, 0.9vw, 14px);
  font-weight: 800;
}

.launch-loader-copy h1 {
  margin: 0;
  font-size: clamp(44px, 6.2vw, 92px);
  line-height: 0.92;
  letter-spacing: 0.02em;
  text-shadow:
    0 0 22px rgba(155, 223, 255, 0.24),
    0 0 52px rgba(255, 226, 184, 0.12);
}

.launch-loader-copy span {
  display: inline-block;
  margin-top: 16px;
  color: rgba(248, 242, 232, 0.74);
  font-size: clamp(10px, 0.78vw, 12px);
}

.launch-loader-lines {
  position: absolute;
  left: max(28px, 4vw);
  bottom: max(28px, 5svh);
  z-index: 3;
  display: grid;
  gap: 8px;
  color: rgba(155, 223, 255, 0.55);
  font-size: 10px;
  transition:
    opacity 380ms ease,
    transform 380ms ease;
}

@keyframes launchRobotOrbit {
  to {
    transform:
      translate(-50%, -50%)
      rotate(360deg)
      translateX(var(--launch-orbit-radius))
      rotate(-360deg);
  }
}

@keyframes launchRobotDock {
  0% {
    transform:
      translate(-50%, -50%)
      rotate(0deg)
      translateX(var(--launch-orbit-radius))
      rotate(0deg)
      scale(1);
  }

  55% {
    transform:
      translate(-50%, -50%)
      rotate(720deg)
      translateX(calc(var(--launch-orbit-radius) * 0.34))
      rotate(-720deg)
      scale(0.94);
  }

  100% {
    transform:
      translate(-50%, -50%)
      rotate(0deg)
      translateX(0)
      rotate(0deg)
      scale(0.86);
  }
}

@keyframes launchOrbitSpin {
  to {
    transform: translate(-50%, -50%) rotate(342deg);
  }
}

@keyframes launchGridDrift {
  to {
    transform: translate3d(-74px, -74px, 0);
  }
}

@keyframes launchStarDrift {
  to {
    transform: translate3d(-120px, 80px, 0);
  }
}

@media (max-width: 760px) {
  .launch-loader {
    --launch-orbit-radius: clamp(48px, 15vw, 72px);
  }

  .launch-loader-robot-field {
    top: 39svh;
    width: clamp(168px, 52vw, 236px);
  }

  .launch-loader-robot {
    width: clamp(62px, 18vw, 88px);
  }

  .launch-loader-copy {
    top: calc(39svh + 96px);
  }

  .launch-loader-lines {
    display: none;
  }
}

/* Loader revision: use the homepage universe as the stage, then fly the robot home. */
.launch-loader {
  --launch-orbit-radius: clamp(24px, 2.2vw, 36px);
  background:
    radial-gradient(ellipse 44% 28% at 54% 44%, rgba(155, 223, 255, 0.08), transparent 64%),
    linear-gradient(180deg, rgba(0, 1, 4, 0.46), rgba(0, 1, 4, 0.58));
  backdrop-filter: brightness(0.68) saturate(1.05) blur(0.4px);
}

.launch-loader::before {
  opacity: 0.12;
  animation: none;
}

.launch-loader::after {
  background:
    radial-gradient(ellipse 58% 46% at 54% 46%, transparent 0 36%, rgba(0, 0, 0, 0.28) 80%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.46), transparent 34%, transparent 64%, rgba(0, 0, 0, 0.42));
  opacity: 0.92;
  filter: none;
  transform: none;
}

.launch-loader-grid {
  opacity: 0.05;
}

.launch-loader.is-revealing {
  background:
    radial-gradient(ellipse 42% 34% at var(--launch-land-x, 65vw) var(--launch-land-y, 50svh), rgba(155, 223, 255, 0.11), transparent 64%),
    rgba(0, 1, 4, 0.2);
  backdrop-filter: brightness(0.86) saturate(1.04) blur(0.2px);
}

.launch-loader-robot-field {
  left: var(--launch-start-x, 10vw);
  top: var(--launch-start-y, 64svh);
  width: clamp(104px, 9.4vw, 148px);
  transform: translate(-50%, -50%) scale(0.46) rotate(-24deg);
  animation: launchRobotCruise 1680ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
  transition: none;
  will-change: left, top, transform;
}

.launch-loader-robot-field::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 1;
  width: clamp(86px, 8vw, 136px);
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(155, 223, 255, 0.4), rgba(248, 242, 232, 0.58));
  filter: blur(1px);
  opacity: 0.52;
  transform: translate(-118%, -50%) rotate(-12deg);
  transform-origin: right center;
  transition: opacity 320ms ease;
}

.launch-loader.is-fast .launch-loader-robot-field {
  left: var(--launch-hold-x, 46vw);
  top: var(--launch-hold-y, 37svh);
  animation: launchRobotHold 640ms ease-in-out infinite alternate;
}

.launch-loader.is-landing .launch-loader-robot-field {
  animation: launchRobotLand 1040ms cubic-bezier(0.18, 0.82, 0.2, 1) forwards;
}

.launch-loader.is-hidden .launch-loader-robot-field {
  opacity: 0;
}

.launch-loader-robot {
  left: 50%;
  top: 50%;
  width: 100%;
  transform: translate(-50%, -50%) rotate(-4deg);
  animation: launchRobotBank 820ms ease-in-out infinite alternate;
}

.launch-loader.is-fast .launch-loader-robot {
  animation: launchRobotCalibration 620ms linear infinite;
}

.launch-loader.is-landing .launch-loader-robot {
  animation: launchRobotSettle 1040ms cubic-bezier(0.18, 0.82, 0.2, 1) forwards;
}

.launch-loader-orbit {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(-18deg) scale(0.72);
}

.launch-loader.is-fast .launch-loader-orbit {
  opacity: 0.72;
  transform: translate(-50%, -50%) rotate(-18deg) scale(1);
}

.launch-loader.is-landing .launch-loader-orbit {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(240deg) scale(0.2);
}

.launch-loader-orbit-one {
  width: 122%;
  height: 122%;
}

.launch-loader-orbit-two {
  width: 168%;
  height: 62%;
}

.launch-loader-copy {
  top: auto;
  right: clamp(56px, 8vw, 120px);
  bottom: clamp(84px, 11svh, 138px);
  left: auto;
  width: min(520px, 42vw);
  text-align: left;
}

.launch-loader-copy h1 {
  font-size: clamp(46px, 5.4vw, 86px);
}

@keyframes launchRobotCruise {
  0% {
    left: var(--launch-start-x, 10vw);
    top: var(--launch-start-y, 64svh);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.42) rotate(-24deg);
  }

  14% {
    opacity: 1;
  }

  42% {
    left: var(--launch-arc-a-x, 30vw);
    top: var(--launch-arc-a-y, 22svh);
    transform: translate(-50%, -50%) scale(0.84) rotate(11deg);
  }

  76% {
    left: var(--launch-arc-b-x, 52vw);
    top: var(--launch-arc-b-y, 28svh);
    transform: translate(-50%, -50%) scale(0.76) rotate(-7deg);
  }

  100% {
    left: var(--launch-hold-x, 46vw);
    top: var(--launch-hold-y, 37svh);
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.82) rotate(0deg);
  }
}

@keyframes launchRobotHold {
  from {
    transform: translate(-50%, -50%) scale(0.82) rotate(-2deg);
  }

  to {
    transform: translate(-50%, -50%) scale(0.9) rotate(2deg);
  }
}

@keyframes launchRobotLand {
  0% {
    left: var(--launch-hold-x, 46vw);
    top: var(--launch-hold-y, 37svh);
    transform: translate(-50%, -50%) scale(0.86) rotate(0deg);
  }

  42% {
    left: var(--launch-approach-x, 54vw);
    top: var(--launch-approach-y, 40svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(10deg);
  }

  76% {
    left: var(--launch-near-x, 61vw);
    top: var(--launch-near-y, 47svh);
    transform: translate(-50%, -50%) scale(0.56) rotate(-4deg);
  }

  100% {
    left: var(--launch-land-x, 65vw);
    top: var(--launch-land-y, 50svh);
    transform: translate(-50%, -50%) scale(0.48) rotate(0deg);
  }
}

@keyframes launchRobotBank {
  from {
    transform: translate(-50%, -50%) rotate(-6deg) translateY(0);
  }

  to {
    transform: translate(-50%, -50%) rotate(7deg) translateY(-4px);
  }
}

@keyframes launchRobotCalibration {
  to {
    transform:
      translate(-50%, -50%)
      rotate(360deg)
      translateX(var(--launch-orbit-radius))
      rotate(-360deg);
  }
}

@keyframes launchRobotSettle {
  0% {
    transform:
      translate(-50%, -50%)
      rotate(0deg)
      translateX(var(--launch-orbit-radius))
      rotate(0deg)
      scale(1);
  }

  52% {
    transform:
      translate(-50%, -50%)
      rotate(540deg)
      translateX(calc(var(--launch-orbit-radius) * 0.24))
      rotate(-540deg)
      scale(0.92);
  }

  100% {
    transform: translate(-50%, -50%) rotate(0deg) translateX(0) scale(0.9);
  }
}

@media (max-width: 760px) {
  .launch-loader {
    --launch-orbit-radius: clamp(18px, 6vw, 28px);
  }

  .launch-loader-robot-field {
    width: clamp(78px, 22vw, 104px);
  }

  .launch-loader-copy {
    left: 24px;
    right: 24px;
    bottom: clamp(64px, 10svh, 92px);
    width: auto;
  }
}

/* Arrival loader: the robot enters the existing homepage world instead of covering it. */
.launch-loader {
  --launch-orbit-radius: 28px;
  display: block;
  background:
    radial-gradient(ellipse 42% 34% at var(--launch-land-x, 65vw) var(--launch-land-y, 50svh), rgba(126, 218, 255, 0.13), transparent 62%),
    radial-gradient(ellipse 60% 40% at 56% 48%, rgba(248, 242, 232, 0.035), transparent 70%),
    linear-gradient(90deg, rgba(0, 1, 4, 0.56), rgba(0, 1, 4, 0.32) 48%, rgba(0, 1, 4, 0.6)),
    linear-gradient(180deg, rgba(0, 1, 4, 0.24), rgba(0, 1, 4, 0.62));
  backdrop-filter: brightness(0.72) saturate(1.06) blur(0.2px);
}

.launch-loader::before {
  z-index: 0;
  opacity: 0.08;
  animation: launchStarDrift 28s linear infinite;
}

.launch-loader::after {
  z-index: 0;
  background:
    radial-gradient(ellipse 54% 44% at 50% 44%, transparent 0 42%, rgba(0, 0, 0, 0.34) 78%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.22), transparent 34%, rgba(0, 0, 0, 0.36));
  opacity: 0.86;
  filter: none;
  transform: none;
  transition:
    opacity 520ms ease,
    transform 520ms ease;
}

.launch-loader-route {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.76;
  filter:
    drop-shadow(0 0 8px rgba(126, 218, 255, 0.22))
    drop-shadow(0 0 18px rgba(126, 218, 255, 0.12));
  transition:
    opacity 460ms ease,
    transform 460ms ease;
}

.launch-loader-route-base,
.launch-loader-route-light {
  fill: none;
  vector-effect: non-scaling-stroke;
}

.launch-loader-route-base {
  stroke: rgba(126, 218, 255, 0.16);
  stroke-width: 1;
  stroke-dasharray: 2 9;
}

.launch-loader-route-light {
  stroke: rgba(248, 252, 255, 0.78);
  stroke-width: 1.35;
  stroke-linecap: round;
  stroke-dasharray: 18 138;
  stroke-dashoffset: 142;
  animation: launchRouteTrace 1920ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
}

.launch-loader-scan {
  position: absolute;
  inset: -12%;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, transparent 0 44%, rgba(126, 218, 255, 0.14) 49%, rgba(248, 252, 255, 0.1) 50%, transparent 56%),
    linear-gradient(90deg, transparent, rgba(126, 218, 255, 0.035), transparent);
  mix-blend-mode: screen;
  opacity: 0.42;
  transform: translateX(-110%);
  animation: launchWideScan 2020ms cubic-bezier(0.18, 0.82, 0.22, 1) forwards;
}

.launch-loader-grid {
  z-index: 1;
  opacity: 0.045;
  mask-image: radial-gradient(ellipse 58% 44% at 55% 45%, #000 0 38%, transparent 78%);
}

.launch-loader-robot-field {
  z-index: 4;
  left: var(--launch-start-x, -5vw);
  top: var(--launch-start-y, 78svh);
  width: clamp(88px, 7vw, 118px);
  transform: translate(-50%, -50%) scale(0.36) rotate(-22deg);
  animation: launchRobotCruise 1920ms cubic-bezier(0.14, 0.82, 0.18, 1) forwards;
}

.launch-loader-robot-field::before {
  content: "";
  position: absolute;
  inset: 12%;
  z-index: 0;
  border: 1px solid rgba(126, 218, 255, 0.28);
  border-radius: 50%;
  box-shadow:
    0 0 22px rgba(126, 218, 255, 0.16),
    inset 0 0 18px rgba(126, 218, 255, 0.1);
  opacity: 0;
  transform: scale(0.62);
  transition:
    opacity 260ms ease,
    transform 260ms ease;
}

.launch-loader-robot-field::after {
  width: clamp(112px, 10vw, 172px);
  height: 2px;
  background:
    linear-gradient(90deg, transparent, rgba(126, 218, 255, 0.58), rgba(248, 252, 255, 0.8));
  filter: blur(0.9px);
  opacity: 0.66;
  transform: translate(-126%, -50%) rotate(-14deg);
}

.launch-loader.is-fast .launch-loader-robot-field {
  left: var(--launch-hold-x, 82vw);
  top: var(--launch-hold-y, 34svh);
  animation: launchRobotHold 820ms ease-in-out infinite alternate;
}

.launch-loader.is-fast .launch-loader-robot-field::before {
  opacity: 0.6;
  transform: scale(1);
  animation: launchFieldPulse 1180ms ease-out infinite;
}

.launch-loader.is-landing .launch-loader-robot-field {
  animation: launchRobotLand 1180ms cubic-bezier(0.18, 0.82, 0.2, 1) forwards;
}

.launch-loader.is-revealing .launch-loader-robot-field {
  opacity: 0.46;
}

.launch-loader-robot {
  width: 100%;
  filter:
    drop-shadow(0 0 18px rgba(126, 218, 255, 0.56))
    drop-shadow(0 18px 30px rgba(0, 0, 0, 0.52));
  transform: translate(-50%, -50%) rotate(-6deg);
  animation: launchRobotBank 860ms ease-in-out infinite alternate;
}

.launch-loader.is-fast .launch-loader-robot {
  animation: launchRobotSignal 760ms ease-in-out infinite alternate;
}

.launch-loader.is-landing .launch-loader-robot {
  animation: launchRobotSettle 1180ms cubic-bezier(0.18, 0.82, 0.2, 1) forwards;
}

.launch-loader-orbit {
  z-index: 1;
  border-color: rgba(126, 218, 255, 0.32);
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.7);
}

.launch-loader-orbit-one {
  width: 126%;
  height: 126%;
  box-shadow: 0 0 18px rgba(126, 218, 255, 0.12);
}

.launch-loader-orbit-two {
  width: 166%;
  height: 68%;
  border-color: rgba(248, 242, 232, 0.22);
}

.launch-loader.is-fast .launch-loader-orbit-one {
  opacity: 0.54;
  animation: launchDockPulse 1180ms ease-out infinite;
}

.launch-loader.is-fast .launch-loader-orbit-two {
  opacity: 0.34;
  animation: launchDockPulse 1480ms ease-out infinite 180ms;
}

.launch-loader.is-landing .launch-loader-orbit {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.18);
}

.launch-loader-copy {
  left: clamp(34px, 5vw, 76px);
  right: auto;
  bottom: clamp(42px, 7svh, 78px);
  top: auto;
  z-index: 3;
  width: min(360px, 34vw);
  padding-left: 18px;
  border-left: 1px solid rgba(126, 218, 255, 0.34);
  text-align: left;
}

.launch-loader-copy p,
.launch-loader-copy span,
.launch-loader-lines span {
  letter-spacing: 0.18em;
}

.launch-loader-copy p {
  margin-bottom: 10px;
  color: rgba(126, 218, 255, 0.78);
  font-size: 12px;
}

.launch-loader-copy h1 {
  display: none;
}

.launch-loader-copy span {
  position: relative;
  margin-top: 0;
  color: rgba(248, 252, 255, 0.86);
  font-size: 11px;
}

.launch-loader-copy span::after {
  content: "";
  display: inline-block;
  width: 7px;
  height: 1em;
  margin-left: 8px;
  vertical-align: -2px;
  background: rgba(126, 218, 255, 0.78);
  animation: launchCursorBlink 760ms steps(2, end) infinite;
}

.launch-loader-lines {
  left: auto;
  right: clamp(34px, 5vw, 78px);
  top: clamp(38px, 7svh, 72px);
  bottom: auto;
  z-index: 3;
  gap: 10px;
  color: rgba(248, 252, 255, 0.58);
  font-size: 10px;
  text-align: right;
}

.launch-loader-lines span {
  position: relative;
  display: block;
}

.launch-loader-lines span::before {
  content: "";
  position: absolute;
  top: 50%;
  right: calc(100% + 12px);
  width: 34px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(126, 218, 255, 0.54));
}

.launch-loader.is-landing .launch-loader-copy,
.launch-loader.is-landing .launch-loader-lines {
  opacity: 0;
  transform: translateY(10px);
}

.launch-loader.is-revealing {
  background:
    radial-gradient(circle at var(--launch-land-x, 65vw) var(--launch-land-y, 50svh), rgba(126, 218, 255, 0.16), transparent 18%, rgba(0, 1, 4, 0.08) 42%, transparent 72%),
    rgba(0, 1, 4, 0.04);
  backdrop-filter: brightness(0.96) saturate(1.03) blur(0);
}

.launch-loader.is-revealing::after {
  opacity: 0.14;
  transform: scale(1.04);
}

.launch-loader.is-revealing .launch-loader-route,
.launch-loader.is-revealing .launch-loader-scan,
.launch-loader.is-revealing .launch-loader-grid {
  opacity: 0;
}

@keyframes launchRouteTrace {
  0% {
    stroke-dashoffset: 148;
    opacity: 0;
  }

  16% {
    opacity: 1;
  }

  100% {
    stroke-dashoffset: 0;
    opacity: 0.72;
  }
}

@keyframes launchWideScan {
  0% {
    transform: translateX(-112%);
    opacity: 0;
  }

  18% {
    opacity: 0.42;
  }

  100% {
    transform: translateX(112%);
    opacity: 0;
  }
}

@keyframes launchRobotCruise {
  0% {
    left: var(--launch-start-x, -5vw);
    top: var(--launch-start-y, 78svh);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.32) rotate(-22deg);
  }

  12% {
    opacity: 1;
  }

  42% {
    left: var(--launch-arc-a-x, 18vw);
    top: var(--launch-arc-a-y, 28svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(12deg);
  }

  72% {
    left: var(--launch-arc-b-x, 55vw);
    top: var(--launch-arc-b-y, 16svh);
    transform: translate(-50%, -50%) scale(0.82) rotate(-8deg);
  }

  100% {
    left: var(--launch-hold-x, 82vw);
    top: var(--launch-hold-y, 34svh);
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg);
  }
}

@keyframes launchRobotHold {
  from {
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg) translateY(0);
  }

  to {
    transform: translate(-50%, -50%) scale(0.82) rotate(2deg) translateY(-5px);
  }
}

@keyframes launchRobotLand {
  0% {
    left: var(--launch-hold-x, 82vw);
    top: var(--launch-hold-y, 34svh);
    transform: translate(-50%, -50%) scale(0.8) rotate(-2deg);
  }

  36% {
    left: var(--launch-approach-x, 76vw);
    top: var(--launch-approach-y, 43svh);
    transform: translate(-50%, -50%) scale(0.68) rotate(11deg);
  }

  74% {
    left: var(--launch-near-x, 70vw);
    top: var(--launch-near-y, 48svh);
    transform: translate(-50%, -50%) scale(0.56) rotate(-4deg);
  }

  100% {
    left: var(--launch-land-x, 65vw);
    top: var(--launch-land-y, 50svh);
    transform: translate(-50%, -50%) scale(0.5) rotate(0deg);
  }
}

@keyframes launchRobotBank {
  from {
    transform: translate(-50%, -50%) rotate(-7deg) translateY(0);
  }

  to {
    transform: translate(-50%, -50%) rotate(6deg) translateY(-4px);
  }
}

@keyframes launchRobotSignal {
  from {
    transform: translate(-50%, -50%) rotate(-3deg) translateY(0) scale(1);
  }

  to {
    transform: translate(-50%, -50%) rotate(3deg) translateY(-3px) scale(1.04);
  }
}

@keyframes launchRobotSettle {
  0% {
    transform: translate(-50%, -50%) rotate(4deg) translateY(-2px) scale(1);
  }

  62% {
    transform: translate(-50%, -50%) rotate(-5deg) translateY(1px) scale(0.94);
  }

  100% {
    transform: translate(-50%, -50%) rotate(0deg) translateY(0) scale(0.88);
  }
}

@keyframes launchDockPulse {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.62);
  }

  28% {
    opacity: 0.56;
  }

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

@keyframes launchFieldPulse {
  0% {
    opacity: 0;
    transform: scale(0.62);
  }

  28% {
    opacity: 0.56;
  }

  100% {
    opacity: 0;
    transform: scale(1.28);
  }
}

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

@media (max-width: 760px) {
  .launch-loader {
    --launch-orbit-radius: 22px;
  }

  .launch-loader-route {
    opacity: 0.52;
  }

  .launch-loader-robot-field {
    width: clamp(74px, 21vw, 98px);
  }

  .launch-loader-copy {
    left: 24px;
    right: 24px;
    bottom: 46px;
    width: auto;
  }

  .launch-loader-lines {
    display: none;
  }
}

body.is-launch-loading .robot-companion,
body.is-launch-loading .robot-face,
body.is-launch-loading .robot-language-toggle,
body.is-launch-loading .robot-audio-toggle,
body.is-launch-loading .robot-pointer,
body.is-launch-loading .robot-scan,
body.is-launch-loading .robot-trail {
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Four-point arrival: Projects -> Thinking -> AI -> avatar. */
.launch-loader {
  --launch-orbit-radius: 22px;
}

.launch-loader-route {
  opacity: 0.72;
}

.launch-loader-route-light {
  stroke-dasharray: 24 184;
  stroke-dashoffset: 188;
  animation: launchRouteTrace 3580ms cubic-bezier(0.12, 0.74, 0.16, 1) forwards;
}

.launch-loader-waypoints {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}

.launch-loader-waypoint {
  position: absolute;
  left: 50%;
  top: 50%;
  width: clamp(54px, 5.2vw, 86px);
  aspect-ratio: 1;
  border: 1px solid rgba(126, 218, 255, 0.42);
  border-radius: 50%;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.35);
  box-shadow:
    0 0 20px rgba(126, 218, 255, 0.14),
    inset 0 0 18px rgba(126, 218, 255, 0.08);
}

.launch-loader-waypoint::before,
.launch-loader-waypoint::after {
  content: "";
  position: absolute;
  inset: 50%;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.launch-loader-waypoint::before {
  width: 6px;
  height: 6px;
  background: rgba(248, 252, 255, 0.92);
  box-shadow: 0 0 14px rgba(126, 218, 255, 0.82);
}

.launch-loader-waypoint::after {
  width: 1px;
  height: 86%;
  background: linear-gradient(transparent, rgba(126, 218, 255, 0.58), transparent);
}

.launch-loader-waypoint-projects {
  left: var(--launch-project-x, 18vw);
  top: var(--launch-project-y, 39svh);
  animation: launchWaypointPulse 940ms ease-out 560ms forwards;
}

.launch-loader-waypoint-thinking {
  left: var(--launch-thinking-x, 49vw);
  top: var(--launch-thinking-y, 20svh);
  animation: launchWaypointPulse 940ms ease-out 1480ms forwards;
}

.launch-loader-waypoint-ai {
  left: var(--launch-ai-x, 82vw);
  top: var(--launch-ai-y, 40svh);
  animation: launchWaypointPulse 1080ms ease-out 2460ms forwards;
}

.launch-loader.is-hidden .launch-loader-waypoints,
.launch-loader.is-revealing .launch-loader-waypoints {
  opacity: 0;
}

.launch-loader-robot-field {
  animation: launchRobotCruise 3600ms cubic-bezier(0.12, 0.74, 0.14, 1) forwards;
}

.launch-loader.is-fast .launch-loader-robot-field {
  left: var(--launch-ai-x, 82vw);
  top: var(--launch-ai-y, 40svh);
}

.launch-loader.is-landing .launch-loader-robot-field {
  animation: launchRobotLand 1280ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
}

.launch-loader.is-fast .launch-loader-route {
  opacity: 0.2;
}

@keyframes launchRobotCruise {
  0% {
    left: var(--launch-start-x, -10vw);
    top: var(--launch-start-y, 82svh);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.16) rotate(-26deg);
  }

  7% {
    opacity: 1;
  }

  17% {
    left: var(--launch-project-x, 18vw);
    top: var(--launch-project-y, 39svh);
    transform: translate(-50%, -50%) scale(0.58) rotate(13deg);
  }

  24% {
    left: var(--launch-project-x, 18vw);
    top: var(--launch-project-y, 39svh);
    transform: translate(-50%, -50%) scale(0.55) rotate(-4deg);
  }

  43% {
    left: var(--launch-thinking-x, 49vw);
    top: var(--launch-thinking-y, 20svh);
    transform: translate(-50%, -50%) scale(0.66) rotate(16deg);
  }

  50% {
    left: var(--launch-thinking-x, 49vw);
    top: var(--launch-thinking-y, 20svh);
    transform: translate(-50%, -50%) scale(0.62) rotate(-5deg);
  }

  72% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.82) rotate(-14deg);
  }

  82% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.78) rotate(5deg);
  }

  100% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg);
  }
}

@keyframes launchRobotLand {
  0% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.8) rotate(-2deg);
  }

  32% {
    left: var(--launch-approach-x, 85vw);
    top: var(--launch-approach-y, 42svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(14deg);
  }

  66% {
    left: var(--launch-near-x, 73vw);
    top: var(--launch-near-y, 47svh);
    transform: translate(-50%, -50%) scale(0.58) rotate(-7deg);
  }

  100% {
    left: var(--launch-land-x, 65vw);
    top: var(--launch-land-y, 50svh);
    transform: translate(-50%, -50%) scale(0.5) rotate(0deg);
  }
}

@keyframes launchWaypointPulse {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.35) rotate(0deg);
  }

  24% {
    opacity: 0.78;
  }

  100% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(1.28) rotate(160deg);
  }
}

/* Cinematic arrival pass: wide arc, far-to-near scale, short docking hover. */
.launch-loader {
  --launch-orbit-radius: 24px;
  background:
    radial-gradient(ellipse 40% 30% at var(--launch-land-x, 65vw) var(--launch-land-y, 50svh), rgba(126, 218, 255, 0.12), transparent 62%),
    radial-gradient(ellipse 52% 24% at 54% 18%, rgba(126, 218, 255, 0.055), transparent 66%),
    linear-gradient(90deg, rgba(0, 1, 4, 0.64), rgba(0, 1, 4, 0.28) 44%, rgba(0, 1, 4, 0.58)),
    linear-gradient(180deg, rgba(0, 1, 4, 0.22), rgba(0, 1, 4, 0.66));
  backdrop-filter: brightness(0.7) saturate(1.08) blur(0.25px);
}

.launch-loader::after {
  background:
    radial-gradient(ellipse 48% 34% at 49% 44%, transparent 0 46%, rgba(0, 0, 0, 0.36) 82%),
    linear-gradient(180deg, rgba(0, 0, 0, 0.34), transparent 22%, transparent 68%, rgba(0, 0, 0, 0.52));
  opacity: 0.9;
}

.launch-loader-route {
  opacity: 0.66;
  filter:
    drop-shadow(0 0 10px rgba(126, 218, 255, 0.2))
    drop-shadow(0 0 28px rgba(126, 218, 255, 0.12));
}

.launch-loader-route-base {
  stroke: rgba(126, 218, 255, 0.12);
  stroke-width: 0.85;
  stroke-dasharray: 1.5 8;
}

.launch-loader-route-light {
  stroke: rgba(220, 247, 255, 0.82);
  stroke-width: 1.1;
  stroke-dasharray: 26 176;
  stroke-dashoffset: 178;
  animation: launchRouteTrace 2560ms cubic-bezier(0.13, 0.76, 0.16, 1) forwards;
}

.launch-loader-scan {
  opacity: 0.32;
  animation: launchWideScan 2480ms cubic-bezier(0.14, 0.78, 0.2, 1) forwards;
}

.launch-loader-robot-field {
  width: clamp(82px, 6.7vw, 116px);
  animation: launchRobotCruise 2520ms cubic-bezier(0.12, 0.74, 0.14, 1) forwards;
}

.launch-loader-robot-field::after {
  width: clamp(132px, 13vw, 220px);
  opacity: 0.74;
  transform: translate(-132%, -50%) rotate(-10deg);
  box-shadow: 0 0 22px rgba(126, 218, 255, 0.18);
}

.launch-loader.is-fast .launch-loader-robot-field {
  left: var(--launch-hold-x, 86vw);
  top: var(--launch-hold-y, 28svh);
  animation: launchRobotHold 760ms ease-in-out infinite alternate;
}

.launch-loader.is-fast .launch-loader-route {
  opacity: 0.3;
}

.launch-loader.is-landing .launch-loader-robot-field {
  animation: launchRobotLand 1280ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
}

.launch-loader.is-landing .launch-loader-robot-field::after {
  opacity: 0.36;
  width: clamp(72px, 7vw, 118px);
}

.launch-loader-robot {
  animation: launchRobotBank 980ms ease-in-out infinite alternate;
}

.launch-loader.is-fast .launch-loader-robot {
  animation: launchRobotSignal 680ms ease-in-out infinite alternate;
}

.launch-loader.is-landing .launch-loader-robot {
  animation: launchRobotSettle 1280ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
}

.launch-loader.is-hidden .launch-loader-robot-field,
.launch-loader.is-hidden .launch-loader-route,
.launch-loader.is-hidden .launch-loader-scan,
.launch-loader.is-hidden .launch-loader-copy,
.launch-loader.is-hidden .launch-loader-lines {
  opacity: 0;
}

.launch-loader-copy {
  opacity: 0.92;
}

@keyframes launchRouteTrace {
  0% {
    stroke-dashoffset: 190;
    opacity: 0;
  }

  9% {
    opacity: 0.92;
  }

  78% {
    opacity: 0.86;
  }

  100% {
    stroke-dashoffset: 0;
    opacity: 0.42;
  }
}

@keyframes launchRobotCruise {
  0% {
    left: var(--launch-start-x, -10vw);
    top: var(--launch-start-y, 82svh);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.18) rotate(-28deg);
  }

  8% {
    opacity: 1;
  }

  22% {
    left: var(--launch-arc-a-x, 13vw);
    top: var(--launch-arc-a-y, 58svh);
    transform: translate(-50%, -50%) scale(0.36) rotate(-2deg);
  }

  48% {
    left: var(--launch-arc-b-x, 34vw);
    top: var(--launch-arc-b-y, 18svh);
    transform: translate(-50%, -50%) scale(0.56) rotate(16deg);
  }

  72% {
    left: var(--launch-arc-c-x, 66vw);
    top: var(--launch-arc-c-y, 11svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(-12deg);
  }

  90% {
    left: calc(var(--launch-hold-x, 86vw) + 18px);
    top: calc(var(--launch-hold-y, 28svh) - 8px);
    transform: translate(-50%, -50%) scale(0.86) rotate(8deg);
  }

  100% {
    left: var(--launch-hold-x, 86vw);
    top: var(--launch-hold-y, 28svh);
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg);
  }
}

@keyframes launchRobotHold {
  from {
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg) translate3d(0, 0, 0);
  }

  to {
    transform: translate(-50%, -50%) scale(0.83) rotate(3deg) translate3d(-8px, -5px, 0);
  }
}

@keyframes launchRobotLand {
  0% {
    left: var(--launch-hold-x, 86vw);
    top: var(--launch-hold-y, 28svh);
    transform: translate(-50%, -50%) scale(0.8) rotate(-2deg);
  }

  30% {
    left: var(--launch-approach-x, 89vw);
    top: var(--launch-approach-y, 40svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(16deg);
  }

  62% {
    left: var(--launch-near-x, 75vw);
    top: var(--launch-near-y, 47svh);
    transform: translate(-50%, -50%) scale(0.58) rotate(-8deg);
  }

  100% {
    left: var(--launch-land-x, 65vw);
    top: var(--launch-land-y, 50svh);
    transform: translate(-50%, -50%) scale(0.5) rotate(0deg);
  }
}

@keyframes launchRobotBank {
  from {
    transform: translate(-50%, -50%) rotate(-8deg) translateY(0) scale(1);
  }

  to {
    transform: translate(-50%, -50%) rotate(7deg) translateY(-5px) scale(1.02);
  }
}

/* Final route override: four homepage checkpoints before docking beside the avatar. */
.launch-loader-route {
  opacity: 0.72;
}

.launch-loader-route-light {
  stroke-dasharray: 24 184;
  stroke-dashoffset: 188;
  animation: launchRouteTrace 3580ms cubic-bezier(0.12, 0.74, 0.16, 1) forwards;
}

.launch-loader-robot-field {
  animation: launchRobotCruise 3600ms cubic-bezier(0.12, 0.74, 0.14, 1) forwards;
}

.launch-loader.is-fast .launch-loader-robot-field {
  left: var(--launch-ai-x, 82vw);
  top: var(--launch-ai-y, 40svh);
}

.launch-loader.is-landing .launch-loader-robot-field {
  animation: launchRobotLand 1280ms cubic-bezier(0.16, 0.82, 0.18, 1) forwards;
}

@keyframes launchRouteTrace {
  0% {
    stroke-dashoffset: 190;
    opacity: 0;
  }

  10% {
    opacity: 0.92;
  }

  82% {
    opacity: 0.82;
  }

  100% {
    stroke-dashoffset: 0;
    opacity: 0.36;
  }
}

@keyframes launchRobotCruise {
  0% {
    left: var(--launch-start-x, -10vw);
    top: var(--launch-start-y, 82svh);
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.16) rotate(-26deg);
  }

  7% {
    opacity: 1;
  }

  17% {
    left: var(--launch-project-x, 18vw);
    top: var(--launch-project-y, 39svh);
    transform: translate(-50%, -50%) scale(0.58) rotate(13deg);
  }

  24% {
    left: var(--launch-project-x, 18vw);
    top: var(--launch-project-y, 39svh);
    transform: translate(-50%, -50%) scale(0.55) rotate(-4deg);
  }

  43% {
    left: var(--launch-thinking-x, 49vw);
    top: var(--launch-thinking-y, 20svh);
    transform: translate(-50%, -50%) scale(0.66) rotate(16deg);
  }

  50% {
    left: var(--launch-thinking-x, 49vw);
    top: var(--launch-thinking-y, 20svh);
    transform: translate(-50%, -50%) scale(0.62) rotate(-5deg);
  }

  72% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.82) rotate(-14deg);
  }

  82% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.78) rotate(5deg);
  }

  100% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    opacity: 1;
    transform: translate(-50%, -50%) scale(0.78) rotate(-2deg);
  }
}

@keyframes launchRobotLand {
  0% {
    left: var(--launch-ai-x, 82vw);
    top: var(--launch-ai-y, 40svh);
    transform: translate(-50%, -50%) scale(0.8) rotate(-2deg);
  }

  32% {
    left: var(--launch-approach-x, 85vw);
    top: var(--launch-approach-y, 42svh);
    transform: translate(-50%, -50%) scale(0.72) rotate(14deg);
  }

  66% {
    left: var(--launch-near-x, 73vw);
    top: var(--launch-near-y, 47svh);
    transform: translate(-50%, -50%) scale(0.58) rotate(-7deg);
  }

  100% {
    left: var(--launch-land-x, 65vw);
    top: var(--launch-land-y, 50svh);
    transform: translate(-50%, -50%) scale(0.5) rotate(0deg);
  }
}
