/* [PWR] LABS — cell colony + interior */

:root {
  --void: #020204;
  --text: #eceaf4;
  --muted: #8f8aa3;
  /* Notion baseline — nucleus/docs/NUCLEUS_DESIGN_LANGUAGE_BASELINE.md */
  --pwr: #7956da;
  --orange: #e07c4c;
  --mito: #3dffb8;
  --gold: #dfab10;
  --nucleus: #f2c4a8;
  --font: "Inter", system-ui, sans-serif;
  --yellow: #dfab10;
  --brown: #997655;
  --blue: #2383e2;
  --green: #2d9c4a;
  --pink: #b42858;
  --purple: #9b6dff;
  --red: #e84545;
  --section-gap: 1.25rem;
  --panel: rgba(7, 9, 16, 0.58);
  --panel-strong: rgba(10, 12, 20, 0.76);
  --hairline: rgba(255, 255, 255, 0.11);
  --hairline-bright: rgba(255, 255, 255, 0.2);
  --ease-out: cubic-bezier(0.2, 0.72, 0.22, 1);
  --mobile-dock-inset: 0.42rem;
  --mobile-dock-pad: 0.14rem;
  --mobile-dock-size: 2.35rem;
  --mobile-dock-gap: 0.32rem;
  --mobile-dock-block: calc(
    var(--mobile-dock-inset) + var(--mobile-dock-size) + (2 * var(--mobile-dock-pad))
  );
  --mobile-scroll-fade: rgb(2, 7, 18);
  --mobile-scroll-fade-height: calc(
    var(--mobile-dock-block) + 1.35rem + env(safe-area-inset-bottom)
  );
}

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

html {
  scroll-behavior: smooth;
}

/* Lowercase body copy only — brand marks opt out via .text-as-written / .brand-mark */
.copy-lowercase {
  text-transform: lowercase;
}

.text-as-written,
.brand-mark {
  text-transform: none;
}

.brand-mark {
  font-weight: 700;
  color: var(--pwr);
}

.brand-mark--skills {
  color: var(--red);
}

.brand-mark--nmaito {
  color: color-mix(in srgb, #ff4fd8 58%, #8f7cff);
}

body {
  margin: 0;
  font-family: var(--font);
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--text);
  background: var(--void);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

body:not(.has-entered),
body.has-entered {
  overflow: hidden;
  height: 100svh;
}

body.has-entered {
  font-size: 1.23rem;
  line-height: 1.69;
}

/* World / colony stage */
.world-stage {
  position: fixed;
  inset: 0;
  z-index: 100;
}

.world-stage.is-interior-bg {
  z-index: 0;
  pointer-events: none;
}

#world-canvas {
  width: 100%;
  height: 100%;
  display: block;
}

.colony-ui {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  transition: opacity 0.55s var(--ease-out);
}

.colony-ui__anchor {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
  opacity: 0;
  will-change: transform, opacity;
  pointer-events: none;
  backface-visibility: hidden;
  transition: opacity 0.42s var(--ease-out);
}

.colony-ui__anchor.is-ready {
  opacity: 1;
}

.colony-ui.is-descending,
.colony-ui.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.hero-lockup {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.28rem, 0.85vh, 0.58rem);
  width: min(96vw, 48rem);
  max-width: 100%;
}

.colony-ui__copy {
  --stack-gap: clamp(0.72rem, 1.65vh, 1.12rem);
  --message-gap: clamp(0.38rem, 0.85vh, 0.62rem);
  --logo-message-gap: clamp(0rem, 0.25vh, 0.2rem);
  --message-cta-gap: clamp(1.7rem, 4vh, 2.55rem);
  pointer-events: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: min(96vw, 48rem);
  padding: 0;
  transform: translateZ(0);
  backface-visibility: hidden;
}

[data-realism="hyper"] .colony-ui__copy {
  filter:
    drop-shadow(0 1px 3px rgba(0, 0, 0, 0.9))
    drop-shadow(0 0 18px rgba(6, 10, 18, 0.98));
}

.colony-ui__copy > .descend-btn {
  margin-top: var(--message-cta-gap);
}

.colony-ui__logo {
  width: min(82vw, 640px);
  display: block;
  margin-block: clamp(-8rem, -11.2vw, -4.4rem) clamp(-8.25rem, -10.4vw, -4.9rem);
  filter: drop-shadow(0 0 28px color-mix(in srgb, var(--pwr) 50%, transparent));
}

[data-realism="hyper"] .colony-ui__logo {
  filter:
    drop-shadow(0 0 18px color-mix(in srgb, var(--pwr) 72%, transparent))
    drop-shadow(0 0 42px rgba(92, 224, 255, 0.22));
}

.colony-ui__message {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--message-gap);
  margin-top: var(--logo-message-gap);
}

.organelle-page__mark {
  width: min(88vw, 480px);
  height: auto;
  display: block;
  filter: drop-shadow(0 0 28px color-mix(in srgb, var(--pwr) 50%, transparent));
}

/* Nucleus home (after dive) — trim SVG viewBox padding under logo */
.organelle-page[data-organelle-page="nucleus"] .hero-lockup .organelle-page__mark {
  margin-bottom: -4.25rem;
}

.colony-ui__headline {
  margin: 0;
  font-size: clamp(1.2rem, 4.2vw, 3.05rem);
  font-weight: 500;
  letter-spacing: 0.015em;
  line-height: 1.1;
  white-space: nowrap;
  color: rgba(255, 255, 255, 0.96);
  text-shadow:
    0 2px 8px rgba(0, 0, 0, 0.88),
    0 0 22px rgba(92, 224, 255, 0.12);
}

.hero-lockup .colony-ui__headline,
.hero-lockup .organelle-page__title {
  margin-top: 0;
}

.colony-ui__lead {
  margin: 0;
  font-size: clamp(1rem, 1.74vw, 1.28rem);
  font-weight: 400;
  color: rgba(236, 234, 244, 0.76);
  line-height: 1.42;
  text-shadow:
    0 1px 6px rgba(0, 0, 0, 0.92),
    0 0 18px rgba(6, 10, 18, 0.84);
}

.colony-ui__lead-line1,
.colony-ui__lead-line2 {
  display: block;
}

.colony-ui__lead-line1 {
  white-space: nowrap;
}

@media (max-width: 520px) {
  .colony-ui__lead-line1 {
    white-space: normal;
  }
}

.impossible {
  font-style: italic;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.96);
}

.impossible strong {
  font-weight: 700;
}

[data-realism="hyper"] .impossible {
  text-shadow:
    0 0 14px rgba(155, 109, 255, 0.45),
    0 0 22px rgba(92, 224, 255, 0.18);
}

.descend-btn {
  margin: 0;
  font: inherit;
  font-size: clamp(0.76rem, 1.2vw, 0.9rem);
  font-weight: 600;
  letter-spacing: 0.08rem;
  padding: 0.68rem 1.18rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--pwr) 26%, var(--hairline));
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.035)),
    color-mix(in srgb, var(--pwr) 24%, rgba(7, 9, 16, 0.72));
  backdrop-filter: blur(22px) saturate(1.3);
  -webkit-backdrop-filter: blur(22px) saturate(1.3);
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 1px 5px rgba(0, 0, 0, 0.85);
  cursor: pointer;
  box-shadow:
    0 18px 50px rgba(0, 0, 0, 0.34),
    0 0 28px color-mix(in srgb, var(--pwr) 24%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition: background 0.22s var(--ease-out), box-shadow 0.22s var(--ease-out), transform 0.22s var(--ease-out), border-color 0.22s var(--ease-out);
}

@media (max-height: 760px) {
  .colony-ui__logo {
    width: min(70vw, 500px);
    margin-block: clamp(-6.5rem, -10.2vw, -3.6rem) clamp(-6.4rem, -9vw, -3.6rem);
  }

  .colony-ui__headline {
    font-size: clamp(1.05rem, 3.25vw, 2.15rem);
  }

  .colony-ui__lead {
    font-size: clamp(0.86rem, 1.35vw, 1rem);
  }

  .descend-btn {
    font-size: 0.78rem;
    letter-spacing: 0.13rem;
    padding: 0.44rem 1.05rem;
  }
}

.descend-btn:hover:not(:disabled) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05)),
    color-mix(in srgb, var(--pwr) 31%, rgba(7, 9, 16, 0.72));
  border-color: color-mix(in srgb, var(--pwr) 54%, rgba(255, 255, 255, 0.34));
  box-shadow:
    0 22px 58px rgba(0, 0, 0, 0.4),
    0 0 36px color-mix(in srgb, var(--pwr) 34%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transform: translateY(-2px);
}

.descend-btn:disabled {
  opacity: 0.55;
  cursor: wait;
}

.descend-btn:not(:disabled) {
  animation: pulse-cue 3.8s var(--ease-out) infinite;
}

@keyframes pulse-cue {
  0%,
  100% {
    opacity: 0.92;
    transform: translateY(0);
  }
  50% {
    opacity: 1;
    transform: translateY(1px);
  }
}

.interior-chrome--hidden {
  opacity: 0;
  pointer-events: none;
}

/* Organelle dock */
.organelle-dock {
  position: fixed;
  bottom: calc(0.92rem + env(safe-area-inset-bottom));
  left: 50%;
  right: auto;
  z-index: 300;
  display: flex;
  justify-content: center;
  gap: 0.3rem;
  padding: 0.28rem;
  border: 1px solid var(--hairline);
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel-strong) 84%, transparent);
  backdrop-filter: blur(26px) saturate(1.35);
  -webkit-backdrop-filter: blur(26px) saturate(1.35);
  box-shadow:
    0 18px 50px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.12);
  transform: translateX(-50%);
}

.organelle-dock__btn {
  font: inherit;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: 2rem;
  padding: 0.34rem 0.72rem;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(236, 234, 244, 0.58);
  cursor: pointer;
  transition: color 0.22s var(--ease-out), border-color 0.22s var(--ease-out), background 0.22s var(--ease-out), transform 0.22s var(--ease-out);
}

.organelle-dock__btn.is-active {
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.035);
  box-shadow:
    0 10px 26px rgba(0, 0, 0, 0.26),
    inset 0 1px 0 rgba(255, 255, 255, 0.13);
}

.organelle-dock__btn:hover {
  color: rgba(255, 255, 255, 0.86);
  transform: translateY(-1px);
}

.organelle-dock__btn[data-accent="purple"].is-active {
  border-color: color-mix(in srgb, var(--purple) 55%, transparent);
}
.organelle-dock__btn[data-accent="orange"].is-active {
  border-color: color-mix(in srgb, var(--orange) 55%, transparent);
}
.organelle-dock__btn[data-accent="mito"].is-active {
  border-color: color-mix(in srgb, var(--mito) 55%, transparent);
}
.organelle-dock__btn[data-accent="gold"].is-active {
  border-color: color-mix(in srgb, var(--gold) 55%, transparent);
}

.organelle-dock__orb {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.5;
}

.organelle-dock__btn.is-active .organelle-dock__orb {
  opacity: 1;
  box-shadow: 0 0 10px currentColor;
}

.organelle-dock__label {
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.01em;
}

@media (max-width: 640px) {
  .organelle-dock__label {
    display: none;
  }
}

/* Interior pages */
.interior {
  position: relative;
  z-index: 200;
  height: 100svh;
  overflow: hidden;
  padding: clamp(1rem, 2vw, 1.8rem) clamp(1rem, 2.4vw, 2rem) 5.9rem;
}

.interior::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 72% 58% at 74% 48%, rgba(2, 2, 4, 0.04), rgba(2, 2, 4, 0.48) 74%),
    linear-gradient(90deg, rgba(2, 2, 4, 0.46), rgba(2, 2, 4, 0.12) 48%, rgba(2, 2, 4, 0.52));
}

[data-realism="hyper"] .interior::before {
  background:
    radial-gradient(ellipse 84% 72% at 72% 45%, rgba(2, 7, 18, 0.025), rgba(2, 7, 18, 0.5) 78%),
    linear-gradient(90deg, rgba(2, 7, 18, 0.52), rgba(2, 7, 18, 0.14) 50%, rgba(2, 7, 18, 0.48));
}

.interior.interior--hidden,
.interior[hidden] {
  display: none !important;
}

.organelle-page {
  display: none;
  max-width: 1040px;
  margin: 0 auto;
  position: relative;
  height: 100%;
  overflow: hidden;
}

.organelle-page.is-active {
  display: flex;
  flex-direction: column;
  animation: page-in 0.62s var(--ease-out);
}

.organelle-page[data-organelle-page="chromosomes"] {
  max-width: 1200px;
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] {
  max-width: 1160px;
  overflow: visible;
}

@keyframes page-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.organelle-page__glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.35;
  pointer-events: none;
}

.organelle-page__glow--nucleus {
  width: 420px;
  height: 420px;
  top: -10%;
  left: 20%;
  background: radial-gradient(circle, var(--nucleus) 0%, transparent 70%);
}

.organelle-page__glow--mito {
  position: fixed;
  width: min(62vw, 720px);
  height: min(62vw, 720px);
  left: max(-8rem, -8vw);
  top: 6%;
  z-index: 0;
  opacity: 0.18;
  filter: blur(110px);
  background:
    radial-gradient(circle at 36% 40%, rgba(255, 69, 216, 0.22), transparent 34%),
    radial-gradient(circle at 58% 54%, rgba(155, 109, 255, 0.2), transparent 48%),
    radial-gradient(circle at 64% 36%, rgba(92, 224, 255, 0.14), transparent 62%);
}

.organelle-page__inner--split > * {
  position: relative;
  z-index: 1;
}

.organelle-page__visual {
  position: relative;
}

.organelle-page__visual::before,
.organelle-page__visual::after {
  content: "";
  position: absolute;
  inset: 50% auto auto 50%;
  width: min(90%, 390px);
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
  display: none;
  transform: translate(-50%, -50%);
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual {
  min-height: clamp(12rem, 34vw, 22rem);
  isolation: isolate;
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual::before,
[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual::after {
  display: block;
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual::before {
  z-index: 0;
  width: min(122%, 520px);
  background:
    radial-gradient(circle at 32% 38%, rgba(255, 66, 214, 0.26), transparent 28%),
    radial-gradient(circle at 56% 52%, rgba(155, 109, 255, 0.24), transparent 48%),
    radial-gradient(circle at 70% 38%, rgba(92, 224, 255, 0.16), transparent 66%);
  filter: blur(58px);
  opacity: 0.72;
  mix-blend-mode: screen;
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual::after {
  display: none;
}

.organelle-page__glow--gold {
  width: 400px;
  height: 400px;
  right: -10%;
  top: 0;
  background: radial-gradient(circle, var(--gold) 0%, transparent 70%);
}

.organelle-page__inner {
  position: relative;
}

.organelle-page__inner--center {
  --stack-gap: clamp(0.75rem, 2vh, 1.2rem);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(0.72rem, 1.9vh, 1.12rem);
  flex: 1;
  min-height: 0;
  overflow: hidden;
  padding: 0.5rem 0;
}

.organelle-page__inner--center .organelle-page__title,
.organelle-page__inner--center .organelle-page__lede,
.organelle-page__inner--center .organelle-page__meta {
  margin: 0;
}

.organelle-page__inner--split {
  display: grid;
  grid-template-columns: minmax(200px, 0.95fr) 1.15fr;
  gap: clamp(2.2rem, 5.8vw, 5.2rem);
  align-items: center;
  flex: 1;
  min-height: 0;
  width: 100%;
  padding: clamp(1rem, 3vh, 2.5rem) 0;
}

@media (max-width: 820px) {
  .organelle-page__inner--split {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .organelle-page__visual {
    order: -1;
  }
  .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__title {
    white-space: normal;
  }
}

.organelle-page__kicker {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.09em;
  color: rgba(236, 234, 244, 0.52);
}

.organelle-page__kicker--mito {
  color: var(--mito);
}
.organelle-page__kicker--gold {
  color: var(--gold);
}

.organelle-page__visual {
  display: flex;
  align-items: center;
  justify-content: center;
}

.organelle-page__portrait {
  width: min(85%, 380px);
  max-height: min(52vh, 420px);
  height: auto;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  filter: drop-shadow(0 0 36px color-mix(in srgb, var(--mito) 40%, transparent));
}

.founder-coin {
  position: relative;
  width: min(82vw, 380px);
  aspect-ratio: 1;
  outline: none;
  filter:
    drop-shadow(0 22px 54px rgba(2, 7, 18, 0.64))
    drop-shadow(0 0 34px rgba(61, 255, 184, 0.14));
}

[data-realism="hyper"] .founder-coin {
  filter:
    drop-shadow(0 30px 70px rgba(2, 7, 18, 0.76))
    drop-shadow(0 0 24px rgba(255, 69, 216, 0.3))
    drop-shadow(0 0 44px rgba(155, 109, 255, 0.22))
    drop-shadow(0 0 62px rgba(92, 224, 255, 0.16));
}

.founder-coin__disc {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  animation: coin-presence 8.5s ease-in-out infinite;
  transition: transform 0.62s var(--ease-out);
}

.founder-coin.is-flipped .founder-coin__disc {
  animation: none;
  transform: translateY(-3px) scale(1.012);
}

.founder-coin.is-flipped .founder-coin__face--front {
  opacity: 0;
  filter: brightness(0.9);
}

.founder-coin.is-flipped .founder-coin__face--back {
  opacity: 1;
  filter: brightness(1.08);
}

@media (hover: hover) and (pointer: fine) {
  .founder-coin:hover .founder-coin__disc,
  .founder-coin:focus .founder-coin__disc,
  .founder-coin:focus-within .founder-coin__disc {
    animation: none;
    transform: translateY(-3px) scale(1.012);
  }

  .founder-coin:hover .founder-coin__face--front,
  .founder-coin:focus .founder-coin__face--front,
  .founder-coin:focus-within .founder-coin__face--front {
    opacity: 0;
    filter: brightness(0.9);
  }

  .founder-coin:hover .founder-coin__face--back,
  .founder-coin:focus .founder-coin__face--back,
  .founder-coin:focus-within .founder-coin__face--back {
    opacity: 1;
    filter: brightness(1.08);
  }
}

@media (hover: none), (pointer: coarse) {
  .founder-coin:hover .founder-coin__disc,
  .founder-coin:focus .founder-coin__disc,
  .founder-coin:focus-within .founder-coin__disc {
    animation: coin-presence 8.5s ease-in-out infinite;
    transform: none;
  }

  .founder-coin:hover .founder-coin__face--front,
  .founder-coin:focus .founder-coin__face--front,
  .founder-coin:focus-within .founder-coin__face--front {
    opacity: 1;
    filter: none;
  }

  .founder-coin:hover .founder-coin__face--back,
  .founder-coin:focus .founder-coin__face--back,
  .founder-coin:focus-within .founder-coin__face--back {
    opacity: 0;
    filter: none;
  }

  .founder-coin.is-flipped:hover .founder-coin__disc,
  .founder-coin.is-flipped:focus .founder-coin__disc,
  .founder-coin.is-flipped:focus-within .founder-coin__disc {
    animation: none;
    transform: translateY(-3px) scale(1.012);
  }

  .founder-coin.is-flipped:hover .founder-coin__face--front,
  .founder-coin.is-flipped:focus .founder-coin__face--front,
  .founder-coin.is-flipped:focus-within .founder-coin__face--front {
    opacity: 0;
    filter: brightness(0.9);
  }

  .founder-coin.is-flipped:hover .founder-coin__face--back,
  .founder-coin.is-flipped:focus .founder-coin__face--back,
  .founder-coin.is-flipped:focus-within .founder-coin__face--back {
    opacity: 1;
    filter: brightness(1.08);
  }
}

.founder-coin__face {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  border-radius: 50%;
  overflow: hidden;
  -webkit-mask-image: radial-gradient(
    circle at 50% 50%,
    #000 0 58%,
    rgba(0, 0, 0, 0.96) 66%,
    rgba(0, 0, 0, 0.58) 76%,
    rgba(0, 0, 0, 0.16) 84%,
    transparent 91%
  );
  mask-image: radial-gradient(
    circle at 50% 50%,
    #000 0 58%,
    rgba(0, 0, 0, 0.96) 66%,
    rgba(0, 0, 0, 0.58) 76%,
    rgba(0, 0, 0, 0.16) 84%,
    transparent 91%
  );
  transition:
    opacity 0.42s var(--ease-out),
    filter 0.42s var(--ease-out);
}

.founder-coin__face--front {
  opacity: 1;
}

.founder-coin__face--back {
  z-index: 2;
  opacity: 0;
  -webkit-mask-image: none;
  mask-image: none;
}

.founder-coin__headshot,
.founder-coin__logo {
  width: 100%;
  height: 100%;
  display: block;
}

.founder-coin__headshot {
  object-fit: cover;
  object-position: 50% 36%;
  transform: scale(1.04);
  filter: saturate(0.98) contrast(1.03) brightness(0.98);
}

.founder-coin__logo {
  width: 88%;
  height: 88%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 14px rgba(255, 111, 242, 0.32))
    drop-shadow(0 0 30px rgba(61, 255, 184, 0.14));
}

@keyframes coin-presence {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  45% {
    transform: translateY(-2px) scale(1.004);
  }
  68% {
    transform: translateY(-0.75px) scale(1.0015);
  }
}

.organelle-page__inner--split .organelle-page__copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.35rem;
  padding: clamp(0.75rem, 1.6vw, 1.15rem) 0;
}

.organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__copy {
  max-width: 43rem;
}

.organelle-page__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.9rem, 3.95vw, 2.82rem);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.08;
  color: rgba(255, 255, 255, 0.94);
  text-shadow: 0 1px 18px rgba(0, 0, 0, 0.38);
}

.organelle-page__title-tail {
  display: block;
  margin-top: 0.28rem;
  font-size: 0.64em;
  font-weight: 500;
  color: rgba(236, 234, 244, 0.58);
  line-height: 1.28;
}

.organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__title {
  white-space: nowrap;
}

@media (max-width: 980px) {
  .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__title {
    white-space: normal;
  }
}

.hero-lockup .organelle-page__title {
  margin: 0;
  white-space: nowrap;
  line-height: 1.1;
}

.organelle-page__lede {
  margin: 0 0 1.2rem;
  color: rgba(236, 234, 244, 0.66);
  max-width: 36rem;
  font-weight: 400;
  line-height: 1.55;
}

.organelle-page__meta {
  margin: 1rem 0 0;
  font-size: 0.78rem;
  color: rgba(236, 234, 244, 0.52);
  max-width: 28rem;
  opacity: 0.85;
}

.organelle-page__inner--center .organelle-page__meta {
  margin-left: auto;
  margin-right: auto;
}

.organelle-page__inner--center .organelle-page__lede {
  margin-left: auto;
  margin-right: auto;
}

.organelle-page__prose p {
  margin: 0 0 0.85rem;
  color: rgba(255, 255, 255, 0.82);
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__lede,
[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__prose {
  font-size: clamp(0.94rem, 1.08vw, 1.02rem);
  line-height: 1.74;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.68);
}

[data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__prose p {
  margin-bottom: 1rem;
}

/* Lattice */
.lattice {
  list-style: none;
  margin: 1.25rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  justify-content: center;
}

.lattice__chip {
  font-size: 0.74rem;
  font-weight: 600;
  padding: 0.34rem 0.68rem;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025)),
    rgba(255, 255, 255, 0.025);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.lattice__chip[data-hue="yellow"] {
  color: var(--yellow);
  border-color: color-mix(in srgb, var(--yellow) 45%, transparent);
}
.lattice__chip[data-hue="brown"] {
  color: var(--brown);
  border-color: color-mix(in srgb, var(--brown) 45%, transparent);
}
.lattice__chip[data-hue="purple"] {
  color: var(--purple);
  border-color: color-mix(in srgb, var(--purple) 45%, transparent);
}
.lattice__chip[data-hue="orange"] {
  color: var(--orange);
  border-color: color-mix(in srgb, var(--orange) 45%, transparent);
}
.lattice__chip[data-hue="blue"] {
  color: var(--blue);
  border-color: color-mix(in srgb, var(--blue) 45%, transparent);
}
.lattice__chip[data-hue="green"] {
  color: var(--green);
  border-color: color-mix(in srgb, var(--green) 45%, transparent);
}
.lattice__chip[data-hue="pink"] {
  color: var(--pink);
  border-color: color-mix(in srgb, var(--pink) 45%, transparent);
}

/* Catalog */
.catalog-panel {
  margin-top: var(--section-gap);
  border-radius: 8px;
  border: 1px solid color-mix(in srgb, var(--gold) 18%, var(--hairline));
  background: var(--panel-strong);
  backdrop-filter: blur(24px) saturate(1.22);
  -webkit-backdrop-filter: blur(24px) saturate(1.22);
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  overflow: hidden;
}

.catalog-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  padding: 0.85rem 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.075);
}

.catalog-panel__btn {
  font: inherit;
  font-size: 0.78rem;
  padding: 0.46rem 0.86rem;
  border-radius: 6px;
  text-decoration: none;
  color: #0a0804;
  background: linear-gradient(180deg, color-mix(in srgb, var(--gold) 94%, white), var(--gold));
  font-weight: 600;
  box-shadow:
    0 10px 28px color-mix(in srgb, var(--gold) 18%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.32);
}

.catalog-panel__btn--ghost {
  background: transparent;
  color: var(--gold);
  border: 1px solid color-mix(in srgb, var(--gold) 45%, transparent);
  box-shadow: none;
}

.organelle-page[data-organelle-page="chromosomes"] .organelle-page__inner {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--section-gap);
  overflow: hidden;
  padding-bottom: var(--section-gap);
}

.organelle-page[data-organelle-page="chromosomes"] .organelle-page__title,
.organelle-page[data-organelle-page="chromosomes"] .organelle-page__lede {
  margin: 0;
}

.organelle-page[data-organelle-page="chromosomes"] .catalog-panel {
  flex: 1 1 auto;
  min-height: min(58vh, 540px);
  max-height: calc(100svh - 12rem);
  margin-top: 0;
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
}

.catalog-panel__table {
  flex: 1;
  min-height: 0;
  max-height: none;
  overflow: auto;
  padding: 0.5rem 1rem 1rem;
}


.skills-catalog-loading,
.skills-catalog-error {
  padding: 1.25rem;
  color: rgba(236, 234, 244, 0.58);
  font-size: 0.9rem;
}

.skills-catalog-section {
  margin-top: 1rem;
}

.skills-catalog-heading {
  margin: 0 0 0.45rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.skills-catalog-heading[data-accent="yellow"],
.skills-catalog-section[data-accent="yellow"] .skills-catalog-heading {
  color: var(--yellow);
}
.skills-catalog-heading[data-accent="brown"],
.skills-catalog-section[data-accent="brown"] .skills-catalog-heading {
  color: var(--brown);
}
.skills-catalog-heading[data-accent="blue"],
.skills-catalog-section[data-accent="blue"] .skills-catalog-heading {
  color: var(--blue);
}
.skills-catalog-heading[data-accent="green"],
.skills-catalog-section[data-accent="green"] .skills-catalog-heading {
  color: var(--green);
}
.skills-catalog-heading[data-accent="pink"],
.skills-catalog-section[data-accent="pink"] .skills-catalog-heading {
  color: var(--pink);
}
.skills-catalog-heading[data-accent="purple"],
.skills-catalog-section[data-accent="purple"] .skills-catalog-heading {
  color: var(--purple);
}
.skills-catalog-heading[data-accent="red"],
.skills-catalog-section[data-accent="red"] .skills-catalog-heading {
  color: var(--red);
}

.skills-catalog-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8rem;
}

.skills-catalog-table th {
  text-align: left;
  padding: 0.42rem 0.48rem;
  color: rgba(236, 234, 244, 0.48);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.075);
}

.skills-catalog-table td {
  padding: 0.48rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  color: rgba(255, 255, 255, 0.78);
}

.skills-catalog-table code {
  color: var(--gold);
  font-size: 0.78rem;
}

.skills-catalog-table a {
  color: color-mix(in srgb, var(--mito) 75%, var(--text));
  text-decoration: none;
}

/* Contact */
.contact-orbs {
  list-style: none;
  margin: 1.05rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.44rem;
}

.contact-orbs__row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.42rem;
  justify-content: center;
}

.contact-orbs a {
  padding: 0.34rem 0.72rem;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 500;
  text-decoration: none;
  color: rgba(236, 234, 244, 0.76);
  border: 1px solid var(--hairline);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.02)),
    rgba(255, 255, 255, 0.025);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: color 0.2s var(--ease-out), border-color 0.2s var(--ease-out), background 0.2s var(--ease-out);
}

.contact-orbs a:hover {
  color: rgba(255, 255, 255, 0.94);
  border-color: color-mix(in srgb, var(--pwr) 45%, transparent);
  background: rgba(255, 255, 255, 0.055);
}

.interior-foot {
  position: fixed;
  bottom: calc(3.62rem + env(safe-area-inset-bottom));
  left: 0;
  right: 0;
  z-index: 250;
  display: flex;
  justify-content: center;
  gap: 0.74rem;
  padding: 0.5rem 1.5rem;
  font-size: 0.68rem;
  font-weight: 600;
  color: rgba(236, 234, 244, 0.46);
  pointer-events: none;
}

.interior-foot a {
  pointer-events: auto;
  color: color-mix(in srgb, var(--pwr) 72%, white);
  text-decoration: none;
}

@media (max-height: 780px) {
  .organelle-page__inner--center .organelle-page__mark {
    width: min(72vw, 400px);
  }
  .organelle-page__inner--center .organelle-page__title {
    font-size: clamp(1.35rem, 3.5vw, 1.85rem);
  }
  .lattice {
    margin-top: 0.75rem;
  }
  .contact-orbs {
    margin-top: 0.75rem;
  }
}

/* Mobile — scrollable interior, tighter splash, safe areas */
@media (max-width: 768px) {
  body.has-entered {
    font-size: 1rem;
    line-height: 1.55;
  }

  .colony-ui__copy {
    width: min(94vw, 100%);
    padding-inline: 0.35rem;
    --message-cta-gap: clamp(1rem, 3vh, 1.45rem);
  }

  .colony-ui__logo {
    width: min(86vw, 400px);
    margin-block: clamp(-5rem, -13vw, -2.75rem) clamp(-4.75rem, -12vw, -2.5rem);
  }

  .colony-ui__headline {
    font-size: clamp(1.05rem, 5.8vw, 1.75rem);
    white-space: normal;
    max-width: 16.5rem;
  }

  .colony-ui__lead {
    font-size: clamp(0.88rem, 3.4vw, 1.02rem);
    max-width: 19rem;
    line-height: 1.45;
  }

  .descend-btn {
    max-width: calc(100vw - 2.5rem);
    letter-spacing: 0.06rem;
  }

  .interior {
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
  }

  /* Scrollable organelles — content fades under the dock */
  .interior:not(.interior--hidden):not([hidden])[data-active-organelle]:not(
      [data-active-organelle="nucleus"]
    ) {
    overflow-y: auto;
    padding: 0.85rem 0.85rem
      calc(var(--mobile-dock-block) + 0.35rem + env(safe-area-inset-bottom));
  }

  .interior:not(.interior--hidden):not([hidden])[data-active-organelle]:not(
      [data-active-organelle="nucleus"]
    )::after {
    content: "";
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    height: var(--mobile-scroll-fade-height);
    z-index: 290;
    pointer-events: none;
    background: linear-gradient(
      to bottom,
      rgb(2 7 18 / 0) 0%,
      rgb(2 7 18 / 0.52) 38%,
      rgb(2 7 18 / 0.88) 72%,
      var(--mobile-scroll-fade) 100%
    );
  }

  :root:not([data-realism="hyper"])
    .interior:not(.interior--hidden):not([hidden])[data-active-organelle]:not(
      [data-active-organelle="nucleus"]
    )::after {
    --mobile-scroll-fade: rgb(2, 2, 4);
    background: linear-gradient(
      to bottom,
      rgb(2 2 4 / 0) 0%,
      rgb(2 2 4 / 0.52) 38%,
      rgb(2 2 4 / 0.88) 72%,
      var(--mobile-scroll-fade) 100%
    );
  }

  /* Nucleus home — one screen, no scroll */
  .interior:not(.interior--hidden):not([hidden])[data-active-organelle="nucleus"] {
    display: flex;
    flex-direction: column;
    overflow-y: hidden;
    padding: clamp(0.35rem, 1.4svh, 0.72rem) 0.85rem
      calc(var(--mobile-dock-block) + 0.2rem + env(safe-area-inset-bottom));
  }

  .interior[data-active-organelle="nucleus"] .organelle-page[data-organelle-page="nucleus"] {
    flex: 1;
    min-height: 0;
    height: auto;
    overflow: hidden;
  }

  .organelle-page__inner--split,
  .organelle-page[data-organelle-page="chromosomes"] .organelle-page__inner {
    padding-bottom: 0.5rem;
  }

  .organelle-page {
    overflow: visible;
    height: auto;
    min-height: 0;
  }

  .organelle-page__inner--center {
    overflow: visible;
    justify-content: flex-start;
    flex: 1 0 auto;
    gap: 0.62rem;
    padding: 0.15rem 0 0.85rem;
  }

  .interior[data-active-organelle="nucleus"] .organelle-page__inner--center {
    height: 100%;
    min-height: 0;
    justify-content: center;
    gap: clamp(0.22rem, 1.05svh, 0.46rem);
    padding: 0;
    overflow: hidden;
  }

  .organelle-page[data-organelle-page="nucleus"] .organelle-page__kicker {
    margin: 0;
    font-size: clamp(0.62rem, 2.6vw, 0.68rem);
    letter-spacing: 0.07em;
  }

  .organelle-page[data-organelle-page="nucleus"] .hero-lockup .organelle-page__mark {
    width: min(68vw, 252px);
    margin-bottom: clamp(-2.75rem, -8.5vw, -1.85rem);
  }

  .organelle-page[data-organelle-page="nucleus"] .hero-lockup .organelle-page__title {
    white-space: normal;
    font-size: clamp(1.02rem, 4.6vw, 1.32rem);
    line-height: 1.12;
  }

  .organelle-page[data-organelle-page="nucleus"] .organelle-page__lede {
    font-size: clamp(0.74rem, 2.7vw, 0.84rem);
    line-height: 1.4;
    margin: 0;
    max-width: 21rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .lattice {
    margin: 0;
    gap: 0.26rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .lattice__chip {
    font-size: clamp(0.56rem, 2.4vw, 0.62rem);
    padding: 0.2rem 0.4rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .organelle-page__meta {
    font-size: clamp(0.6rem, 2.5vw, 0.66rem);
    line-height: 1.32;
    max-width: 17.5rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .contact-orbs {
    margin: 0;
    gap: 0.22rem;
    flex-shrink: 0;
  }

  .organelle-page[data-organelle-page="nucleus"] .contact-orbs__row {
    gap: 0.22rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .contact-orbs a {
    font-size: clamp(0.58rem, 2.4vw, 0.64rem);
    padding: 0.22rem 0.44rem;
  }

  .hero-lockup .organelle-page__title {
    white-space: normal;
    font-size: clamp(1.2rem, 5.4vw, 1.65rem);
  }

  .organelle-page__lede {
    font-size: 0.92rem;
    max-width: 100%;
    margin-bottom: 0.6rem;
    line-height: 1.5;
  }

  .organelle-page__meta {
    font-size: 0.72rem;
    line-height: 1.45;
  }

  .lattice {
    margin-top: 0.55rem;
    gap: 0.35rem;
  }

  .lattice__chip {
    font-size: 0.67rem;
    padding: 0.28rem 0.52rem;
  }

  .contact-orbs a {
    font-size: 0.7rem;
    padding: 0.32rem 0.62rem;
  }

  .organelle-page__inner--split {
    overflow: visible;
    flex: 1 0 auto;
    gap: 1.15rem;
    padding: 0.35rem 0 1.5rem;
  }

  .founder-coin {
    width: min(66vw, 250px);
    margin-inline: auto;
  }

  [data-realism="hyper"] .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__visual {
    min-height: unset;
  }

  .organelle-page[data-organelle-page="nmaitochondria"] .organelle-page__title {
    font-size: clamp(1.35rem, 5.6vw, 1.85rem);
  }

  .organelle-page__inner--split .organelle-page__copy {
    padding: 0;
    gap: 0.28rem;
    justify-content: flex-start;
  }

  .organelle-page__prose p {
    font-size: 0.9rem;
    margin-bottom: 0.6rem;
    line-height: 1.55;
  }

  .organelle-page[data-organelle-page="chromosomes"] .organelle-page__inner {
    overflow: visible;
    flex: 1 0 auto;
    padding-bottom: 0.35rem;
  }

  .organelle-page[data-organelle-page="chromosomes"] .organelle-page__title {
    font-size: clamp(1.15rem, 4.8vw, 1.55rem);
    line-height: 1.22;
  }

  .organelle-page[data-organelle-page="chromosomes"] .organelle-page__lede {
    font-size: 0.88rem;
  }

  .organelle-page[data-organelle-page="chromosomes"] .catalog-panel {
    min-height: 260px;
    max-height: none;
  }

  .catalog-panel__table {
    -webkit-overflow-scrolling: touch;
  }

  .skills-catalog-table {
    min-width: 460px;
  }

  .skills-catalog-table th,
  .skills-catalog-table td {
    padding: 0.38rem 0.32rem;
    font-size: 0.72rem;
  }

  .skills-catalog-table code {
    font-size: 0.7rem;
  }

  .interior-foot {
    display: none;
  }

  .organelle-dock {
    bottom: calc(var(--mobile-dock-inset) + env(safe-area-inset-bottom));
    max-width: calc(100vw - 2rem);
    padding: var(--mobile-dock-pad);
    gap: 0.18rem;
    border-radius: 999px;
  }

  .organelle-dock__btn {
    min-height: var(--mobile-dock-size);
    min-width: var(--mobile-dock-size);
    width: var(--mobile-dock-size);
    height: var(--mobile-dock-size);
    padding: 0;
    justify-content: center;
    align-items: center;
    border-radius: 999px;
  }

  .organelle-dock__orb {
    width: 6px;
    height: 6px;
  }

  .organelle-dock__btn.is-active {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.11);
  }

  .organelle-dock__btn.is-active .organelle-dock__orb {
    width: 7px;
    height: 7px;
    box-shadow: 0 0 6px currentColor;
  }
}

@media (max-width: 768px) and (max-height: 700px) {
  .interior:not(.interior--hidden):not([hidden])[data-active-organelle="nucleus"] {
    padding-top: 0.25rem;
  }

  .organelle-page[data-organelle-page="nucleus"] .hero-lockup .organelle-page__mark {
    width: min(62vw, 220px);
    margin-bottom: clamp(-2.35rem, -7.5vw, -1.55rem);
  }

  .organelle-page[data-organelle-page="nucleus"] .organelle-page__meta {
    display: none;
  }

  .organelle-page[data-organelle-page="nucleus"] .contact-orbs a {
    padding: 0.18rem 0.38rem;
  }
}

@media (max-width: 390px) {
  .colony-ui__logo {
    width: min(90vw, 320px);
    margin-block: clamp(-3.75rem, -11vw, -2.15rem) clamp(-3.5rem, -10vw, -2rem);
  }

  .colony-ui__headline {
    font-size: clamp(0.98rem, 5.2vw, 1.28rem);
    max-width: 14.5rem;
  }

  .colony-ui__lead {
    font-size: 0.84rem;
  }

  .descend-btn {
    font-size: 0.72rem;
    padding: 0.5rem 0.95rem;
  }

  .founder-coin {
    width: min(72vw, 220px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .descend-btn {
    animation: none;
  }
  .organelle-page.is-active {
    animation: none;
  }
  .founder-coin__disc {
    animation: none;
  }
}
