:root {
  --phi: 1.618;
  --u-xs: 5px;
  --u-sm: 8px;
  --u-md: 13px;
  --u-lg: 21px;
  --u-xl: 34px;
  --u-xxl: 55px;
  --u-xxxl: 89px;
  --radius-button: 21px;
  --radius-panel: 34px;
  --tap-target-min: 55px;
  --bg-0: #070417;
  --bg-1: #120a32;
  --panel: rgba(16, 13, 45, 0.78);
  --panel-strong: rgba(28, 22, 70, 0.92);
  --text: #fff8ff;
  --muted: #c5b8e8;
  --gold: #ffd86b;
  --accent: #81f7ff;
  --danger: #ff6a8a;
  --event-accent: var(--accent);
  --event-secondary: var(--gold);
  --event-glow: rgba(129, 247, 255, .22);
  --event-panel: rgba(129, 247, 255, .12);
  --event-text: #fff4c2;
  --app-height: 100dvh;
  --controls-clearance: clamp(13px, 2.4dvh, 34px);
  --mobile-controls-expanded-height: clamp(330px, 58dvh, 430px);
}

* {
  box-sizing: border-box;
  -webkit-tap-highlight-color: transparent;
}

html,
body {
  margin: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--bg-0);
  color: var(--text);
  font-family: ui-rounded, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

button,
input {
  font: inherit;
}

button {
  color: inherit;
}

.app {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  height: var(--app-height, 100dvh);
  min-height: 0;
  max-height: var(--app-height, 100dvh);
  overflow: hidden;
  background: radial-gradient(circle at 50% 25%, rgba(99, 70, 221, .34), transparent 34%), radial-gradient(circle at 12% 75%, rgba(255, 111, 170, .18), transparent 29%), linear-gradient(160deg, #09041a, #0f0631 42%, #02000b);
  touch-action: manipulation;
}

.app,
.status-card,
.progress-shell,
.progress-fill,
.console-button,
.upgrade-button,
.planet-wrap,
.planet-button {
  transition: box-shadow .24s ease, border-color .24s ease, background .24s ease, filter .24s ease, opacity .24s ease;
}

.app::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .34;
  background: radial-gradient(circle at 50% 18%, rgba(129, 247, 255, .10), transparent 32%), radial-gradient(circle at 20% 78%, rgba(255, 106, 169, .09), transparent 28%);
}

.app.event-active::before {
  opacity: .48;
  background:
    radial-gradient(circle at 50% 18%, var(--event-panel), transparent 32%),
    radial-gradient(circle at 20% 78%, var(--event-glow), transparent 28%),
    radial-gradient(circle at 75% 28%, color-mix(in srgb, var(--event-accent) 20%, transparent), transparent 26%);
}

#fxCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.top-bar {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--u-md);
  padding: max(var(--u-md), env(safe-area-inset-top)) var(--u-md) var(--u-sm);
}

.status-card {
  min-height: var(--tap-target-min);
  padding: var(--u-sm) var(--u-md);
  border-radius: var(--radius-button);
  background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .04)), var(--panel);
  box-shadow: 0 13px 34px rgba(0, 0, 0, .26), inset 0 0 0 1px rgba(255, 255, 255, .12);
  backdrop-filter: blur(12px);
  overflow: hidden;
}

.eyebrow {
  display: block;
  font-size: 12px;
  line-height: 1;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}

.status-card strong {
  display: block;
  margin-top: 4px;
  font-size: clamp(18px, 5vw, 27px);
  line-height: 1.04;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tap-area {
  position: relative;
  z-index: 4;
  min-height: 0;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  align-items: center;
  justify-items: center;
  padding: var(--u-sm) var(--u-md) var(--controls-clearance);
  overflow: visible;
  transition: transform .24s ease;
}

.tap-area.event-active::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: min(76vw, 440px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle, transparent 54%, var(--event-panel) 68%, transparent 76%);
  opacity: .7;
  animation: eventBreath 1.8s ease-in-out infinite;
}

.event-banner {
  min-height: 38px;
  max-width: min(92vw, 520px);
  padding: var(--u-sm) var(--u-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 999px;
  background: rgba(0, 0, 0, .18);
  color: #fff6c0;
  transform: translateY(-8px);
  opacity: 0;
  transition: opacity .22s ease, transform .22s ease;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .12);
}

.event-banner.show {
  opacity: 1;
  transform: translateY(0);
  background: linear-gradient(90deg, rgba(255, 216, 107, .18), rgba(129, 247, 255, .14)), rgba(0, 0, 0, .22);
}

.active-buffs {
  min-height: 34px;
  display: flex;
  gap: var(--u-sm);
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.buff-chip {
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 216, 107, .16);
  color: #fff4c2;
  border: 1px solid rgba(255, 216, 107, .35);
  font-size: 12px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .20);
}

.buff-chip.themed {
  background: var(--chip-bg, rgba(255, 216, 107, .16));
  color: var(--chip-color, #fff4c2);
  border-color: var(--chip-border, rgba(255, 216, 107, .35));
  box-shadow: 0 6px 18px rgba(0, 0, 0, .20), 0 0 18px var(--chip-glow, rgba(255, 216, 107, .18));
}

.planet-wrap {
  position: relative;
  display: grid;
  place-items: center;
  width: min(72vw, 360px);
  aspect-ratio: 1;
  transform: translateZ(0) scale(var(--warp-wrap-scale, 1));
  filter: blur(var(--warp-wrap-blur, 0px));
  transform-origin: center;
}

.planet-wrap.event-active::after {
  content: "";
  position: absolute;
  inset: -7%;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle, transparent 57%, var(--event-glow) 68%, transparent 76%);
  opacity: .92;
  animation: eventHalo 1.5s ease-in-out infinite;
}

.three-planet-layer {
  position: absolute;
  inset: 50% auto auto 50%;
  width: min(64vw, 300px);
  aspect-ratio: 1;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transition: opacity .25s ease;
  z-index: 0;
  opacity: var(--warp-planet-opacity, 1);
}

.three-planet-layer.enabled {
  opacity: 1;
}

.three-planet-layer canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
  border-radius: 50%;
}

.planet-button.three-enabled {
  background: radial-gradient(circle, rgba(255, 255, 255, .035), rgba(255, 255, 255, .012) 46%, rgba(0, 0, 0, .02) 68%, transparent 74%);
  box-shadow: 0 0 55px var(--planet-three-glow, rgba(129, 247, 255, .18)), 0 34px 89px rgba(0, 0, 0, .28);
}

.planet-button.three-enabled .planet-rim {
  opacity: var(--planet-rim-opacity);
}

.planet-button {
  --planet-three-glow: rgba(129, 247, 255, .18);
  --planet-rim-opacity: 0;
  --planet-rim-color: rgba(255, 255, 255, .18);
  position: relative;
  width: min(64vw, 300px);
  aspect-ratio: 1;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  touch-action: none;
  transform: perspective(700px) rotateX(var(--planet-rx, 0deg)) rotateY(var(--planet-ry, 0deg)) scale(var(--planet-zoom, 1));
  transform-style: preserve-3d;
  background: radial-gradient(circle at var(--planet-highlight-x, 35%) var(--planet-highlight-y, 24%), #ffaf82 0 10%, #c85a34 29%, #8f2d20 60%, #4b1516 100%);
  box-shadow: inset -28px -34px 55px rgba(0, 0, 0, .38), inset 18px 18px 34px rgba(255, 255, 255, .16), 0 0 34px rgba(255, 116, 69, .45), 0 34px 89px rgba(0, 0, 0, .45);
  transition: filter .18s ease;
  will-change: transform;
  opacity: var(--warp-planet-opacity, 1);
}

.planet-button.event-active {
  filter: saturate(1.16) brightness(1.06);
}

.planet-button.trait-atmosphere .planet-rim {
  filter: blur(1px);
}

.planet-button.trait-energy-halo.three-enabled {
  box-shadow: 0 0 56px var(--planet-three-glow, rgba(129, 247, 255, .1)), 0 34px 89px rgba(0, 0, 0, .28);
}

.planet-button.trait-energy-halo::after {
  opacity: max(.08, var(--planet-halo-opacity, .08));
}

.planet-button.trait-ring-system .planet-rim {
  inset: -10px;
}

.planet-button.family-real-rocky {
  --planet-halo-opacity: .08;
}

.planet-button.family-real-rocky::after {
  opacity: .08;
  mix-blend-mode: soft-light;
}

.planet-button.family-real-clouded {
  --planet-halo-opacity: .09;
}

.planet-button.family-real-clouded::after {
  opacity: .09;
  mix-blend-mode: screen;
}

.planet-button.family-real-gas {
  --planet-halo-opacity: .1;
}

.planet-button.family-real-gas::after {
  opacity: .1;
  mix-blend-mode: soft-light;
}

.planet-button.family-real-ice {
  --planet-halo-opacity: .09;
}

.planet-button.family-real-ice::after {
  opacity: .09;
  mix-blend-mode: screen;
}

.planet-button.family-exotic-atmosphere {
  --planet-halo-opacity: .11;
}

.planet-button.family-exotic-atmosphere::after {
  opacity: .11;
  mix-blend-mode: screen;
}

.planet-button.family-metallic-world {
  --planet-halo-opacity: .11;
}

.planet-button.family-metallic-world::after {
  opacity: .11;
  mix-blend-mode: screen;
}

.planet-button.family-crystal-world {
  --planet-halo-opacity: .12;
}

.planet-button.family-crystal-world::after {
  opacity: .12;
  mix-blend-mode: screen;
}

.planet-button.family-singularity-world {
  --planet-halo-opacity: .1;
}

.planet-button.family-singularity-world::after {
  opacity: .1;
  mix-blend-mode: hard-light;
}

.planet-button.family-stellar-world {
  --planet-halo-opacity: .14;
}

.planet-button.family-stellar-world::after {
  opacity: .14;
  mix-blend-mode: screen;
}

.planet-button.family-cosmic-world {
  --planet-halo-opacity: .11;
}

.planet-button.family-cosmic-world::after {
  opacity: .11;
  mix-blend-mode: screen;
}

.planet-button.mercury {
  background:
    radial-gradient(circle at 32% 24%, rgba(246, 244, 237, .92) 0 7%, transparent 22%),
    radial-gradient(circle at 63% 66%, rgba(69, 64, 66, .38) 0 10%, transparent 24%),
    radial-gradient(circle at 42% 54%, rgba(195, 171, 140, .32) 0 12%, transparent 25%),
    radial-gradient(circle at 36% 28%, #d9d7dc 0 12%, #b6b2bb 30%, #7f7c84 60%, #4e4c55 84%, #26272f 100%);
  box-shadow: inset -26px -30px 54px rgba(0, 0, 0, .4), inset 14px 14px 24px rgba(255, 255, 255, .1), 0 0 18px rgba(177, 179, 191, .18), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.venus {
  background:
    radial-gradient(circle at 34% 24%, rgba(255, 247, 223, .92) 0 8%, transparent 22%),
    repeating-linear-gradient(168deg, rgba(243, 206, 146, .28) 0 12px, rgba(184, 125, 71, .18) 12px 26px, rgba(255, 220, 172, .22) 26px 38px),
    radial-gradient(circle at 40% 32%, #f0c78b 0 16%, #d99958 39%, #aa6b3e 65%, #724528 84%, #422516 100%);
  box-shadow: inset -26px -30px 52px rgba(0, 0, 0, .34), inset 16px 16px 26px rgba(255, 238, 204, .1), 0 0 20px rgba(217, 160, 97, .2), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.earth {
  background:
    radial-gradient(circle at 34% 24%, rgba(242, 251, 255, .9) 0 8%, transparent 20%),
    radial-gradient(circle at 23% 48%, rgba(255, 255, 255, .46) 0 6%, transparent 14%),
    radial-gradient(circle at 63% 32%, rgba(255, 255, 255, .36) 0 7%, transparent 14%),
    radial-gradient(circle at 70% 62%, rgba(255, 255, 255, .28) 0 5%, transparent 12%),
    radial-gradient(circle at 58% 42%, rgba(116, 176, 101, .95) 0 10%, transparent 24%),
    radial-gradient(circle at 35% 60%, rgba(147, 196, 122, .88) 0 12%, transparent 24%),
    radial-gradient(circle at 68% 68%, rgba(212, 226, 181, .65) 0 8%, transparent 18%),
    linear-gradient(160deg, transparent 0 42%, rgba(255, 255, 255, .12) 42% 47%, transparent 47% 100%),
    radial-gradient(circle at 40% 36%, #77c7ff 0 12%, #3d8fd3 28%, #1e5f9f 58%, #0b264f 84%, #04101f 100%);
  box-shadow: inset -26px -30px 54px rgba(0, 0, 0, .34), inset 16px 16px 24px rgba(255, 255, 255, .12), 0 0 22px rgba(84, 160, 219, .24), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.mars {
  background:
    radial-gradient(circle at 34% 24%, rgba(255, 228, 193, .82) 0 8%, transparent 20%),
    radial-gradient(circle at 64% 34%, rgba(130, 54, 31, .34) 0 11%, transparent 23%),
    radial-gradient(circle at 38% 64%, rgba(220, 178, 119, .28) 0 13%, transparent 26%),
    radial-gradient(circle at 40% 32%, #d4925f 0 16%, #b46336 38%, #8f4425 62%, #5c2518 83%, #30110d 100%);
  box-shadow: inset -26px -30px 52px rgba(0, 0, 0, .36), inset 14px 14px 24px rgba(255, 223, 193, .08), 0 0 20px rgba(176, 104, 72, .22), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.jupiter {
  background:
    radial-gradient(circle at 34% 24%, rgba(255, 250, 243, .86) 0 7%, transparent 18%),
    radial-gradient(circle at 67% 55%, rgba(186, 107, 74, .72) 0 7%, transparent 15%),
    radial-gradient(circle at 70% 56%, rgba(255, 209, 182, .24) 0 12%, transparent 22%),
    radial-gradient(circle at 65% 58%, rgba(182, 112, 74, .55) 0 8%, transparent 16%),
    repeating-linear-gradient(176deg, #ece2d2 0 12px, #c79d72 12px 26px, #f1e8de 26px 38px, #aa7a55 38px 52px, #d6bea1 52px 68px, #8f5c3e 68px 78px);
  box-shadow: inset -26px -30px 54px rgba(0, 0, 0, .3), inset 14px 14px 22px rgba(255, 255, 255, .1), 0 0 22px rgba(196, 157, 117, .22), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.saturn {
  background:
    radial-gradient(circle at 35% 24%, rgba(250, 244, 226, .88) 0 8%, transparent 18%),
    linear-gradient(160deg, transparent 0 44%, rgba(255, 255, 255, .08) 44% 47%, transparent 47% 100%),
    repeating-linear-gradient(178deg, rgba(239, 229, 204, .95) 0 12px, rgba(191, 167, 135, .85) 12px 24px, rgba(221, 210, 190, .92) 24px 36px, rgba(165, 144, 121, .88) 36px 48px, rgba(226, 218, 200, .82) 48px 58px),
    radial-gradient(circle at 42% 32%, #d8c7ae 0 18%, #bca68d 42%, #8d7763 68%, #564539 87%, #2e241d 100%);
  box-shadow: inset -26px -30px 52px rgba(0, 0, 0, .34), inset 14px 14px 24px rgba(255, 255, 255, .08), 0 0 18px rgba(192, 174, 150, .16), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.saturn::before {
  content: "";
  position: absolute;
  left: -39%;
  top: 37%;
  width: 178%;
  height: 30%;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 50% 50%, transparent 45%, rgba(230, 224, 214, .9) 47%, rgba(155, 142, 142, .78) 53%, rgba(208, 202, 193, .72) 58%, transparent 61%),
    linear-gradient(90deg, transparent, rgba(213, 205, 196, .34), rgba(125, 117, 124, .26), transparent);
  transform: rotate(-15deg);
  box-shadow: 0 0 18px rgba(203, 194, 184, .22);
  pointer-events: none;
  z-index: 1;
}

.planet-button.saturn::after {
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse at 50% 43%, rgba(239, 233, 216, .54) 0 8%, rgba(185, 166, 138, .22) 28%, transparent 57%),
    repeating-linear-gradient(180deg, rgba(255, 255, 255, .06) 0 11px, rgba(90, 76, 61, .04) 11px 22px),
    radial-gradient(circle at var(--planet-highlight-x, 35%) var(--planet-highlight-y, 24%), rgba(255, 255, 255, .14), transparent 18%);
  mix-blend-mode: normal;
  opacity: .92;
}

.planet-button.uranus {
  background:
    radial-gradient(circle at 34% 24%, rgba(245, 253, 255, .88) 0 8%, transparent 19%),
    repeating-linear-gradient(180deg, rgba(224, 246, 249, .95) 0 16px, rgba(180, 218, 226, .88) 16px 30px, rgba(208, 238, 244, .92) 30px 44px),
    radial-gradient(circle at 42% 30%, #cdebf0 0 16%, #9fd0da 40%, #73aebd 66%, #456577 85%, #223241 100%);
  box-shadow: inset -24px -28px 48px rgba(0, 0, 0, .26), inset 12px 12px 20px rgba(255, 255, 255, .1), 0 0 16px rgba(189, 220, 228, .16), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.uranus::before {
  content: none;
}

.planet-button.uranus::after {
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(255, 255, 255, .22) 0 8%, transparent 20%),
    repeating-linear-gradient(180deg, rgba(255, 255, 255, .07) 0 10px, rgba(116, 150, 159, .05) 10px 22px),
    radial-gradient(circle at var(--planet-highlight-x, 35%) var(--planet-highlight-y, 24%), rgba(255, 255, 255, .14), transparent 18%);
  mix-blend-mode: normal;
  opacity: .84;
}

.planet-button.neptune {
  background:
    radial-gradient(circle at 34% 24%, rgba(242, 249, 255, .86) 0 8%, transparent 19%),
    radial-gradient(circle at 64% 54%, rgba(219, 245, 255, .38) 0 6%, transparent 14%),
    linear-gradient(160deg, transparent 0 45%, rgba(255, 255, 255, .08) 45% 48%, transparent 48% 100%),
    repeating-linear-gradient(180deg, rgba(142, 214, 234, .22) 0 14px, rgba(77, 149, 189, .18) 14px 28px, rgba(184, 235, 247, .16) 28px 40px, rgba(42, 94, 142, .12) 40px 54px),
    radial-gradient(circle at 42% 30%, #77c8e6 0 13%, #48a0cb 35%, #2f6fa4 60%, #193a69 82%, #0a1833 100%);
  box-shadow: inset -26px -30px 52px rgba(0, 0, 0, .34), inset 14px 14px 22px rgba(255, 255, 255, .08), 0 0 20px rgba(89, 151, 191, .2), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.pluto {
  background:
    radial-gradient(circle at 34% 24%, rgba(248, 235, 221, .82) 0 8%, transparent 18%),
    linear-gradient(170deg, transparent 0 46%, rgba(96, 74, 59, .28) 46% 54%, transparent 54% 100%),
    radial-gradient(circle at 60% 38%, rgba(205, 171, 147, .2) 0 13%, transparent 25%),
    radial-gradient(circle at 40% 30%, #ceb59a 0 16%, #a78b72 40%, #7c6557 64%, #56463c 84%, #2a201b 100%);
  box-shadow: inset -24px -28px 48px rgba(0, 0, 0, .34), inset 12px 12px 20px rgba(255, 255, 255, .08), 0 0 16px rgba(167, 144, 120, .16), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.exoplanet {
  background:
    radial-gradient(circle at 34% 24%, rgba(229, 255, 249, .78) 0 8%, transparent 18%),
    radial-gradient(circle at 64% 58%, rgba(95, 255, 226, .18) 0 12%, transparent 22%),
    repeating-linear-gradient(168deg, rgba(117, 86, 174, .22) 0 13px, rgba(44, 132, 126, .2) 13px 31px, rgba(146, 112, 206, .18) 31px 45px),
    radial-gradient(circle at 42% 30%, #7bc5b3 0 13%, #4e9f98 31%, #4d6e99 56%, #463f7f 77%, #231734 100%);
  box-shadow: inset -26px -30px 54px rgba(0, 0, 0, .38), inset 14px 14px 22px rgba(255, 255, 255, .08), 0 0 28px rgba(114, 142, 210, .28), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.golden-world {
  background:
    radial-gradient(circle at 33% 22%, rgba(255, 251, 221, .92) 0 8%, transparent 18%),
    linear-gradient(152deg, transparent 0 44%, rgba(255, 239, 188, .14) 44% 49%, transparent 49% 100%),
    repeating-linear-gradient(172deg, rgba(255, 227, 140, .28) 0 10px, rgba(184, 126, 33, .18) 10px 24px, rgba(255, 240, 191, .18) 24px 34px),
    radial-gradient(circle at 40% 30%, #f4dc91 0 15%, #d5ab46 35%, #aa7c24 62%, #6d4710 82%, #351d05 100%);
  box-shadow: inset -26px -30px 54px rgba(86, 53, 6, .34), inset 16px 16px 26px rgba(255, 245, 203, .18), 0 0 54px rgba(233, 188, 84, .54), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.crystal-planet {
  background:
    linear-gradient(140deg, rgba(255, 255, 255, .28) 0 20%, transparent 20% 100%),
    conic-gradient(from 28deg, #eefcff 0deg, #9cefff 58deg, #c8c0ff 116deg, #5a5bb4 174deg, #aaf4ff 238deg, #2b5d9f 302deg, #eefcff 360deg),
    radial-gradient(circle at 40% 28%, #e8fbff 0 11%, #9fe5ff 26%, #7bb8ff 48%, #4b4d9b 70%, #1f2444 100%);
  box-shadow: inset -24px -28px 46px rgba(0, 0, 0, .22), inset 18px 18px 26px rgba(255, 255, 255, .22), 0 0 58px rgba(146, 225, 255, .5), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.black-hole-forge {
  background:
    radial-gradient(circle at 50% 50%, #020205 0 20%, #05030b 22%, #14091f 34%, #523479 42%, #d08b3a 46%, #2b143c 52%, #040208 68%, #000 100%);
  box-shadow: inset 0 0 54px rgba(0, 0, 0, .92), 0 0 64px rgba(114, 73, 180, .5), 0 34px 89px rgba(0, 0, 0, .58);
}

.planet-button.black-hole-forge::before {
  content: "";
  position: absolute;
  inset: -12%;
  border-radius: 50%;
  background:
    radial-gradient(ellipse at 50% 50%, transparent 42%, rgba(236, 160, 75, .78) 46%, rgba(123, 82, 196, .55) 54%, transparent 63%),
    radial-gradient(ellipse at 50% 50%, transparent 56%, rgba(255, 224, 162, .16) 58%, transparent 67%);
  filter: blur(1px);
  opacity: .8;
  pointer-events: none;
  z-index: 1;
}

.planet-button.baby-star {
  background:
    radial-gradient(circle at 36% 28%, rgba(255, 255, 255, .96) 0 8%, rgba(255, 249, 196, .92) 10%, transparent 22%),
    radial-gradient(circle at 60% 58%, rgba(255, 126, 48, .3) 0 12%, transparent 24%),
    conic-gradient(from 12deg, rgba(255, 240, 150, .18), rgba(255, 169, 49, .2), rgba(255, 89, 58, .24), rgba(255, 227, 119, .18), rgba(255, 240, 150, .18)),
    radial-gradient(circle at 40% 32%, #fff6b3 0 14%, #ffd56a 30%, #ffab39 52%, #ff7146 76%, #661a05 100%);
  box-shadow: inset -18px -28px 46px rgba(255, 110, 23, .2), 0 0 92px rgba(255, 220, 117, .72), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.baby-star::before {
  content: "";
  position: absolute;
  inset: -8%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 236, 151, .42) 36%, rgba(255, 184, 72, .12) 58%, transparent 72%);
  filter: blur(5px);
  pointer-events: none;
  z-index: 1;
}

.planet-button.galaxy-core {
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, .9) 0 5%, rgba(255, 228, 148, .78) 6%, rgba(174, 226, 255, .56) 10%, rgba(108, 95, 195, .48) 16%, transparent 24%),
    conic-gradient(from 0deg, #2c2454 0deg, #5d4ea0 62deg, #3d7faa 136deg, #2a374f 198deg, #7a4b90 274deg, #2c2454 360deg),
    radial-gradient(circle at 40% 30%, #d8c8ff 0 12%, #8f89d3 30%, #4c4d86 58%, #23233d 82%, #090b16 100%);
  box-shadow: inset -24px -28px 56px rgba(0, 0, 0, .26), inset 18px 18px 28px rgba(255, 255, 255, .14), 0 0 82px rgba(126, 129, 212, .54), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button.galaxy-core::before {
  content: "";
  position: absolute;
  inset: -10%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, transparent 34%, rgba(152, 138, 228, .22) 49%, transparent 64%),
    conic-gradient(from 20deg, transparent 0 18%, rgba(117, 189, 255, .16) 18% 27%, transparent 27% 46%, rgba(255, 185, 134, .12) 46% 58%, transparent 58% 100%);
  filter: blur(2px);
  pointer-events: none;
  z-index: 1;
}

.planet-button.golden {
  filter: saturate(1.4) brightness(1.22);
  box-shadow: inset -28px -34px 55px rgba(93, 52, 0, .28), inset 18px 18px 34px rgba(255, 255, 255, .32), 0 0 89px rgba(255, 216, 107, .9), 0 34px 89px rgba(0, 0, 0, .45);
}

.planet-button::after {
  content: "";
  position: absolute;
  inset: 9%;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle at var(--planet-highlight-x, 35%) var(--planet-highlight-y, 24%), rgba(255, 255, 255, .12), transparent 18%), repeating-conic-gradient(from calc(var(--planet-ry, 0deg) * 1), rgba(255, 255, 255, .03) 0 5deg, transparent 5deg 24deg);
  mix-blend-mode: soft-light;
  opacity: .3;
}

@keyframes flash {
  from {
    opacity: .9;
    transform: scale(.92);
  }

  to {
    opacity: 0;
    transform: scale(1.14);
  }
}

.planet-rim {
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  background: radial-gradient(circle,
      transparent 60%,
      color-mix(in srgb, var(--planet-rim-color) 42%, transparent) 68%,
      color-mix(in srgb, var(--planet-rim-color) 14%, transparent) 76%,
      transparent 84%);
  opacity: var(--planet-rim-opacity);
  filter: blur(1.5px);
  pointer-events: none;
  z-index: 4;
}

.planet-rim::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  opacity: 0;
  pointer-events: none;
}

.planet-button.hit-flash .planet-rim::after {
  background: rgba(255, 255, 255, .28);
  animation: flash .18s ease-out;
}

.planet-label {
  position: relative;
  z-index: 5;
  padding: var(--u-sm) var(--u-md);
  border-radius: 999px;
  background: rgba(0, 0, 0, .18);
  color: rgba(255, 255, 255, .80);
  font-weight: 900;
  letter-spacing: .14em;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .45);
  transition: opacity .45s ease, transform .45s ease;
}

.floating-text-layer {
  position: absolute;
  inset: 0;
  z-index: 12;
  pointer-events: none;
  overflow: visible;
}

.float-text {
  position: absolute;
  left: 50%;
  top: 45%;
  z-index: 1;
  pointer-events: none;
  font-size: clamp(21px, 5vw, 34px);
  font-weight: 900;
  text-shadow: 0 3px 10px rgba(0, 0, 0, .5);
  color: #fff4c2;
  animation: floatUp .9s ease-out forwards;
  white-space: nowrap;
}

.event-reward-text {
  z-index: 13;
  color: #fff8c7;
  font-size: clamp(22px, 4.2vw, 38px);
  line-height: 1;
  text-shadow:
    0 2px 0 rgba(3, 8, 22, .95),
    0 -1px 0 rgba(3, 8, 22, .75),
    2px 0 0 rgba(3, 8, 22, .76),
    -2px 0 0 rgba(3, 8, 22, .76),
    0 5px 12px rgba(0, 0, 0, .72),
    0 0 22px rgba(255, 216, 107, .62),
    0 0 34px rgba(129, 247, 255, .24);
  animation: eventRewardFloat .76s cubic-bezier(.16, .92, .22, 1) forwards;
}

@keyframes floatUp {
  from {
    opacity: 0;
    transform: translate(-50%, 10px) scale(.78);
  }

  18% {
    opacity: 1;
  }

  to {
    opacity: 0;
    transform: translate(calc(-50% + var(--dx, 0px)), -82px) scale(1.08);
  }
}

@keyframes eventRewardFloat {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) scale(.72);
  }

  18% {
    opacity: 1;
    transform: translate(-50%, -58%) scale(1.18);
  }

  62% {
    opacity: 1;
    transform: translate(calc(-50% + var(--dx, 0px) * .42), -78%) scale(1.02);
  }

  100% {
    opacity: 0;
    transform: translate(calc(-50% + var(--dx, 0px)), -132%) scale(.94);
  }
}

.progress-shell {
  width: min(88vw, 520px);
  padding: var(--u-sm) var(--u-md);
  border-radius: var(--radius-button);
  background: rgba(0, 0, 0, .18);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .1);
}

.app.event-active .status-card,
.app.event-active .progress-shell {
  box-shadow: 0 13px 34px rgba(0, 0, 0, .26), inset 0 0 0 1px rgba(255, 255, 255, .12), 0 0 24px var(--event-glow);
}

.progress-info {
  display: flex;
  justify-content: space-between;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 6px;
}

.progress-track {
  height: 13px;
  background: rgba(255, 255, 255, .12);
  border-radius: 999px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: linear-gradient(90deg, #81f7ff, #ffd86b, #ff6aa9);
  box-shadow: 0 0 21px rgba(129, 247, 255, .55);
  transition: width .18s ease;
}

.app.event-active .progress-fill {
  background: linear-gradient(90deg, var(--event-accent), var(--event-secondary), #ffffff);
  box-shadow: 0 0 21px var(--event-glow);
}

.controls-panel {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--u-xs);
  min-height: 0;
  margin-top: max(var(--u-sm), calc(var(--controls-clearance) * .35));
  padding: 0 var(--u-md) max(var(--u-md), env(safe-area-inset-bottom));
}

.controls-toolbar {
  display: grid;
  grid-template-columns: 50px 1fr;
  align-items: center;
  gap: var(--u-sm);
  min-height: 50px;
}

.controls-toolbar-actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--u-sm);
}

.controls-toggle {
  width: 50px;
  height: 50px;
  min-width: 50px;
  min-height: 50px;
  justify-self: start;
  font-size: 24px;
  font-weight: 900;
}

.utility-button {
  position: relative;
  width: 50px;
  height: 50px;
  min-width: 50px;
  min-height: 50px;
  font-weight: 900;
}

.codex-button {
  clip-path: none;
  border-radius: 14px;
}

.codex-button small {
  position: absolute;
  right: 3px;
  bottom: 3px;
  min-width: 28px;
  padding: 2px 5px;
  border-radius: 999px;
  background: rgba(255, 216, 107, .95);
  color: #140d02;
  font-size: 9px;
  line-height: 1;
  text-align: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
}

.controls-panel.collapsed .controls-toolbar {
  grid-template-columns: 50px;
  justify-content: center;
}

.controls-panel.collapsed .controls-toggle {
  justify-self: center;
}

.controls-panel.collapsed .controls-toolbar-actions {
  display: none;
}

.controls-content {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: var(--u-sm);
  min-height: 0;
  overflow: hidden;
}

.controls-panel.collapsed .controls-content {
  display: none;
}

.priority-actions {
  display: grid;
  min-height: 0;
}

.action-button {
  min-height: 58px;
  width: 100%;
}

.priority-actions .prestige-button {
  min-height: 62px;
  font-weight: 900;
  letter-spacing: .02em;
}

.upgrade-tray {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--u-sm);
  min-height: 0;
  max-height: min(34dvh, 285px);
  overflow: auto;
  padding: 0 0 var(--u-xs);
}

.upgrade-button {
  min-height: 86px;
  padding: var(--u-sm);
  border: 0;
  border-radius: var(--radius-button);
  background: linear-gradient(180deg, rgba(255, 255, 255, .14), rgba(255, 255, 255, .05)), var(--panel-strong);
  box-shadow: 0 13px 34px rgba(0, 0, 0, .28), inset 0 0 0 1px rgba(255, 255, 255, .12);
  display: grid;
  gap: 3px;
  text-align: left;
  cursor: pointer;
}

.upgrade-button strong {
  font-size: 13px;
}

.upgrade-button span {
  font-size: 11px;
  color: var(--muted);
}

.upgrade-button .cost {
  color: var(--gold);
  font-weight: 800;
}

.upgrade-button:disabled {
  opacity: .52;
  filter: grayscale(.25);
}

.console-button,
.upgrade-button,
.pill-button,
.icon-button,
.settings-panel menu button {
  border: 1px solid rgba(129, 247, 255, .26);
  background:
    linear-gradient(135deg, rgba(129, 247, 255, .11), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .025)),
    rgba(7, 14, 31, .70);
  clip-path: polygon(13px 0, 100% 0, 100% calc(100% - 13px), calc(100% - 13px) 100%, 0 100%, 0 13px);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .06), 0 8px 21px rgba(0, 0, 0, .28), 0 0 20px rgba(129, 247, 255, .06);
}

.app.event-active .console-button,
.app.event-active .upgrade-button,
.app.event-active .pill-button,
.app.event-active .icon-button,
.app.event-active .settings-panel menu button {
  border-color: var(--event-glow);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .06), 0 8px 21px rgba(0, 0, 0, .28), 0 0 24px var(--event-glow);
}

.upgrade-button {
  position: relative;
  overflow: hidden;
  border-radius: 13px;
}

.upgrade-button.affordable {
  border-color: rgba(129, 247, 255, .44);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .06), 0 8px 21px rgba(0, 0, 0, .28), 0 0 24px rgba(129, 247, 255, .12);
}

.upgrade-button.unaffordable {
  opacity: .54;
  filter: saturate(.55);
}

.upgrade-button::before {
  content: "";
  position: absolute;
  left: -70%;
  top: 0;
  width: 45%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(129, 247, 255, .24), transparent);
  transform: skewX(-16deg);
  opacity: 0;
}

.upgrade-button:active::before {
  animation: consoleSweep .42s ease-out;
  opacity: 1;
}

@keyframes consoleSweep {
  from {
    left: -70%;
  }

  to {
    left: 125%;
  }
}

@keyframes eventHalo {

  0%,
  100% {
    opacity: .68;
    transform: scale(.97);
  }

  50% {
    opacity: 1;
    transform: scale(1.03);
  }
}

@keyframes eventBreath {

  0%,
  100% {
    opacity: .44;
    transform: translate(-50%, -50%) scale(.98);
  }

  50% {
    opacity: .78;
    transform: translate(-50%, -50%) scale(1.04);
  }
}

@keyframes eventTargetPulse {

  0%,
  100% {
    opacity: .24;
    transform: scale(.82);
  }

  50% {
    opacity: .72;
    transform: scale(1.08);
  }
}

@keyframes eventObjectPop {
  0% {
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
  }

  45% {
    transform: translate(-50%, -50%) scale(1.2) rotate(5deg);
  }

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

@keyframes eventObjectDragBoost {
  0% {
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
  }

  45% {
    transform: translate(-50%, -50%) scale(1.28) rotate(-7deg);
  }

  100% {
    transform: translate(-50%, -50%) scale(1.03) rotate(0deg);
  }
}

.pill-button,
.icon-button {
  border-radius: 13px;
}


.icon-button {
  min-width: 44px;
  min-height: 44px;
  border: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, .12);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .16);
  cursor: pointer;
}

.pill-button {
  min-height: 44px;
  border: 0;
  border-radius: 999px;
  padding: 0 var(--u-md);
  background: rgba(255, 255, 255, .12);
  color: var(--text);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .16), 0 10px 26px rgba(0, 0, 0, .24);
  cursor: pointer;
}

.prestige-button {
  background: linear-gradient(90deg, rgba(255, 216, 107, .2), rgba(129, 247, 255, .16));
}

.prestige-button:disabled {
  opacity: .5;
}

.app.prestige-arming::before {
  opacity: calc(.42 + var(--prestige-arm-progress, 0) * .34);
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 216, 107, calc(.08 + var(--prestige-arm-progress, 0) * .18)), transparent 30%),
    radial-gradient(circle at 22% 78%, rgba(129, 247, 255, calc(.08 + var(--prestige-arm-progress, 0) * .16)), transparent 28%),
    radial-gradient(circle at 78% 34%, rgba(255, 106, 169, calc(.05 + var(--prestige-arm-progress, 0) * .14)), transparent 24%);
}

.settings-dialog {
  border: 0;
  padding: 0;
  border-radius: var(--radius-panel);
  background: transparent;
  color: var(--text);
  width: min(92vw, 440px);
}

.settings-dialog::backdrop {
  background: rgba(0, 0, 0, .58);
  backdrop-filter: blur(8px);
}

.settings-panel {
  display: grid;
  gap: var(--u-md);
  padding: var(--u-lg);
  border-radius: var(--radius-panel);
  background: linear-gradient(180deg, rgba(42, 31, 98, .98), rgba(15, 10, 44, .98));
  box-shadow: 0 21px 89px rgba(0, 0, 0, .55);
}

.settings-panel header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.settings-panel h2 {
  margin: 0;
  font-size: 24px;
}

.settings-panel label {
  display: grid;
  gap: 7px;
  color: var(--muted);
}

.settings-panel .toggle {
  grid-template-columns: 1fr auto;
  align-items: center;
}

.settings-panel menu {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--u-sm);
  padding: 0;
  margin: 0;
}

.settings-panel menu button {
  min-height: var(--tap-target-min);
  border: 0;
  border-radius: var(--radius-button);
  background: rgba(255, 255, 255, .12);
}

.settings-panel menu .danger {
  background: rgba(255, 106, 138, .18);
  color: #ffd8e0;
}

.codex-list {
  display: grid;
  gap: var(--u-sm);
  max-height: min(58vh, 520px);
  overflow: auto;
}

.codex-entry {
  display: grid;
  gap: 4px;
  padding: var(--u-sm) var(--u-md);
  border-radius: var(--radius-button);
  background: rgba(255, 255, 255, .08);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .10);
}

.codex-entry strong {
  font-size: 16px;
}

.codex-entry span {
  color: var(--gold);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.codex-entry p,
.empty-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}

.prestige-dialog {
  width: min(34vw, 420px);
  min-width: 340px;
  margin: 0;
  background: transparent;
}

.prestige-dialog.arming {
  position: fixed;
  top: 50%;
  right: max(16px, env(safe-area-inset-right));
  left: auto;
  transform: translateY(-50%);
}

.prestige-dialog.arming::backdrop {
  background: transparent;
  backdrop-filter: none;
}

.prestige-panel {
  gap: var(--u-md);
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(39, 27, 90, .82), rgba(10, 7, 34, .78)),
    radial-gradient(circle at 50% 0%, rgba(255, 216, 107, .08), transparent 32%);
  box-shadow: 0 21px 64px rgba(0, 0, 0, .44), 0 0 34px rgba(129, 247, 255, .10);
  backdrop-filter: blur(14px);
}

.prestige-warning {
  margin: 0;
  color: #f4ecff;
  line-height: 1.45;
}

.prestige-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--u-sm);
}

.prestige-stat {
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .03));
  border: 1px solid rgba(255, 255, 255, .12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08), 0 10px 22px rgba(0, 0, 0, .18);
}

.prestige-stat span {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.prestige-stat strong {
  font-size: clamp(20px, 3.2vw, 28px);
}

.prestige-stat.accent {
  background: linear-gradient(180deg, rgba(255, 216, 107, .16), rgba(129, 247, 255, .08));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .12), 0 0 30px rgba(255, 216, 107, .14);
}

.prestige-console {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: var(--u-lg);
  align-items: center;
}

.prestige-slider-shell {
  display: grid;
  justify-items: center;
  gap: var(--u-sm);
  touch-action: none;
}

.prestige-slider-cap {
  min-width: 120px;
  padding: 7px 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .04));
  border: 1px solid rgba(255, 255, 255, .12);
  color: #fff0c6;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .16em;
  text-align: center;
}

.prestige-slider-cap.top {
  box-shadow: 0 0 18px rgba(255, 216, 107, .22);
}

.prestige-slider-cap.bottom {
  color: #bfb4df;
}

.prestige-warp-track {
  position: relative;
  width: 120px;
  height: min(48vh, 330px);
  min-height: 250px;
  padding: 12px;
  border-radius: 24px;
  outline: none;
  cursor: ns-resize;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02)),
    linear-gradient(145deg, rgba(13, 17, 42, .98), rgba(32, 22, 76, .96));
  border: 1px solid rgba(129, 247, 255, .22);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, .12),
    inset 0 -12px 28px rgba(0, 0, 0, .44),
    0 18px 30px rgba(0, 0, 0, .28),
    0 0 calc(22px + var(--prestige-arm-progress, 0) * 38px) rgba(129, 247, 255, calc(.08 + var(--prestige-arm-progress, 0) * .18));
  transform: perspective(900px) rotateX(12deg);
}

.prestige-warp-track:focus-visible {
  border-color: rgba(255, 216, 107, .48);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, .12),
    inset 0 -12px 28px rgba(0, 0, 0, .44),
    0 24px 40px rgba(0, 0, 0, .34),
    0 0 0 2px rgba(255, 216, 107, .24),
    0 0 28px rgba(255, 216, 107, .18);
}

.prestige-warp-rail,
.prestige-warp-fill {
  position: absolute;
  left: 50%;
  bottom: 14px;
  width: 24px;
  transform: translateX(-50%);
  border-radius: 999px;
}

.prestige-warp-rail {
  top: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .06), inset 0 0 22px rgba(0, 0, 0, .42);
}

.prestige-warp-fill {
  height: 0%;
  background: linear-gradient(180deg, #ffffff, #ffd86b 28%, #81f7ff 74%, #2f6bff 100%);
  box-shadow: 0 0 18px rgba(255, 216, 107, .28), 0 0 28px rgba(129, 247, 255, .18);
  transition: height .12s linear;
}

.prestige-warp-thumb {
  position: absolute;
  left: 50%;
  bottom: 0%;
  width: 76px;
  height: 46px;
  transform: translate(-50%, 50%);
  border: 0;
  border-radius: 20px;
  padding: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .26), rgba(255, 255, 255, .08)),
    linear-gradient(145deg, rgba(22, 31, 84, .98), rgba(54, 34, 122, .98));
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, .22),
    inset 0 -10px 18px rgba(0, 0, 0, .38),
    0 10px 20px rgba(0, 0, 0, .28),
    0 0 calc(16px + var(--prestige-arm-progress, 0) * 28px) rgba(255, 216, 107, calc(.12 + var(--prestige-arm-progress, 0) * .32));
  transition: bottom .12s linear, box-shadow .12s linear;
  touch-action: none;
}

.prestige-warp-thumb::before,
.prestige-warp-thumb::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 8px;
  height: 18px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .22);
  transform: translateY(-50%);
}

.prestige-warp-thumb::before {
  left: 11px;
}

.prestige-warp-thumb::after {
  right: 11px;
}

.prestige-warp-thumb-core {
  position: absolute;
  inset: 8px 22px;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff7cc, #ffd86b 42%, #81f7ff 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .6), 0 0 18px rgba(255, 216, 107, .24);
}

.prestige-warp-markers {
  position: absolute;
  inset: 16px 14px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-end;
  color: rgba(255, 255, 255, .52);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  pointer-events: none;
}

.prestige-readout {
  display: grid;
  gap: var(--u-sm);
  align-content: center;
}

.prestige-readout strong {
  font-size: clamp(36px, 7vw, 62px);
  line-height: .92;
  color: #fff5d2;
  text-shadow: 0 0 24px rgba(255, 216, 107, .18);
}

.prestige-warp-hint {
  margin: 0;
  color: #d6caef;
  line-height: 1.5;
}

.prestige-menu {
  display: flex;
  justify-content: stretch;
}

.prestige-menu button {
  min-height: 42px;
  width: 100%;
  padding: 0 18px;
}

.screen-shake {
  animation: shake .24s linear;
}

@keyframes shake {

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

  25% {
    transform: translate3d(4px, -2px, 0);
  }

  50% {
    transform: translate3d(-3px, 3px, 0);
  }

  75% {
    transform: translate3d(2px, 2px, 0);
  }
}

@media (max-width: 960px) {
  .prestige-dialog {
    width: min(42vw, 400px);
    min-width: 300px;
  }

  .prestige-console {
    grid-template-columns: 120px 1fr;
  }
}

@media (max-width: 720px) {
  .prestige-dialog.arming {
    top: auto;
    right: max(8px, env(safe-area-inset-right));
    left: max(8px, env(safe-area-inset-left));
    bottom: max(8px, env(safe-area-inset-bottom));
    transform: none;
    width: auto;
    min-width: 0;
    max-height: min(28dvh, 220px);
  }

  .prestige-dialog.arming .prestige-panel {
    grid-template-columns: 1fr;
    gap: 6px 10px;
    padding: 9px 10px;
    border-radius: 18px;
    max-height: min(28dvh, 220px);
    overflow: hidden;
  }

  .prestige-dialog.arming .prestige-panel header,
  .prestige-dialog.arming .prestige-menu {
    grid-column: 1 / -1;
  }

  .prestige-dialog.arming .prestige-panel header {
    min-height: 32px;
  }

  .prestige-dialog.arming .prestige-panel h2 {
    font-size: 17px;
  }

  .prestige-dialog.arming .prestige-warning,
  .prestige-dialog.arming .prestige-summary,
  .prestige-dialog.arming .prestige-warp-hint,
  .prestige-dialog.arming .prestige-slider-cap,
  .prestige-dialog.arming .prestige-menu {
    display: none;
  }

  .prestige-dialog.arming .prestige-console {
    grid-column: 1 / -1;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
  }

  .prestige-dialog.arming .prestige-slider-shell {
    gap: 0;
  }

  .prestige-dialog.arming .prestige-warp-track {
    width: 86px;
    min-height: 0;
    height: clamp(96px, 15dvh, 120px);
    padding: 8px;
    border-radius: 18px;
    transform: none;
  }

  .prestige-dialog.arming .prestige-warp-rail,
  .prestige-dialog.arming .prestige-warp-fill {
    bottom: 10px;
    width: 18px;
  }

  .prestige-dialog.arming .prestige-warp-rail {
    top: 10px;
  }

  .prestige-dialog.arming .prestige-warp-markers {
    inset: 11px 9px;
    font-size: 8px;
  }

  .prestige-dialog.arming .prestige-warp-thumb {
    width: 58px;
    height: 34px;
    border-radius: 14px;
  }

  .prestige-dialog.arming .prestige-warp-thumb-core {
    inset: 7px 18px;
    border-radius: 8px;
  }

  .prestige-dialog.arming .prestige-readout {
    gap: 4px;
    text-align: left;
  }

  .prestige-dialog.arming .prestige-readout strong {
    font-size: 32px;
  }

}

@media (orientation: landscape) and (max-height: 560px) {
  .top-bar {
    grid-template-columns: 200px 200px;
    justify-content: center;
    padding-top: var(--u-sm);
  }

  .planet-button {
    width: min(42vh, 250px);
  }

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

@media (max-width: 720px),
(max-height: 760px) {
  .app.controls-expanded {
    grid-template-rows: auto minmax(0, 1fr) var(--mobile-controls-expanded-height);
  }

  .top-bar {
    gap: var(--u-sm);
    padding-bottom: 0;
  }

  .status-card {
    min-height: 48px;
    padding: var(--u-xs) var(--u-sm);
  }

  .status-card strong {
    font-size: clamp(16px, 4vw, 22px);
  }

  .tap-area {
    gap: var(--u-xs);
    padding-top: 0;
  }

  .app.controls-expanded .tap-area {
    transform: none;
  }

  .planet-wrap {
    width: min(54vw, 280px);
  }

  .planet-button {
    width: min(52vw, 260px);
  }

  .controls-panel,
  .controls-content {
    gap: var(--u-xs);
  }

  .app.controls-expanded .controls-panel {
    height: var(--mobile-controls-expanded-height);
    max-height: calc(var(--app-height, 100dvh) - 104px);
  }

  .app.controls-expanded .controls-content {
    min-height: 0;
  }

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

  .app.controls-expanded .upgrade-tray {
    max-height: none;
    height: 100%;
  }

  .upgrade-button {
    min-height: 76px;
  }
}

@media (max-height: 620px) {
  .planet-wrap {
    width: min(48vw, 230px);
  }

  .planet-button {
    width: min(46vw, 220px);
  }

  .upgrade-tray {
    max-height: min(32dvh, 205px);
  }

  .app.controls-expanded .tap-area {
    transform: none;
  }

  .app.controls-expanded {
    grid-template-rows: auto minmax(0, 1fr) clamp(318px, 60dvh, 430px);
  }

  .app.controls-expanded .controls-panel {
    height: clamp(318px, 60dvh, 430px);
    max-height: calc(var(--app-height, 100dvh) - 92px);
  }

  .upgrade-button {
    min-height: 72px;
  }
}

@media (max-width: 420px) {
  .upgrade-tray {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .upgrade-button {
    min-height: 78px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .app::before {
    animation: none;
  }

  .float-text {
    animation-duration: .45s;
  }
}

.planet-info-panel {
  position: absolute;
  left: 50%;
  top: 12%;
  width: min(84vw, 340px);
  transform: translate(-50%, -10px) scale(.98);
  opacity: 0;
  pointer-events: none;
  z-index: 7;
  padding: 13px 21px;
  color: #e9fbff;
  text-align: left;
  transition: opacity 180ms ease, transform 180ms ease;
}

.planet-info-panel.show {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.planet-info-panel strong {
  display: block;
  color: #fff;
  font-size: 16px;
  margin-bottom: 4px;
}

.planet-info-panel span,
.planet-info-panel p {
  display: block;
  margin: 3px 0;
  color: rgba(226, 247, 255, .76);
  font-size: 12px;
}

.planet-button.inspect-pulse::after {
  animation: inspectPulse 900ms ease-out infinite;
}

@keyframes inspectPulse {
  0% {
    opacity: .35;
    transform: scale(1);
  }

  60% {
    opacity: .85;
    transform: scale(1.08);
  }

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

@media (prefers-reduced-motion: reduce) {
  .planet-info-panel {
    transition: none;
  }

  .planet-button.inspect-pulse::after {
    animation: none;
  }
}

/* Phase 12: unique rare-event objects and epic exploration feedback */
.rare-event-object {
  position: absolute;
  left: var(--event-x, 50%);
  top: var(--event-y, 38%);
  z-index: 7;
  width: 118px;
  height: 118px;
  transform: translate(-50%, -50%) scale(.62) rotate(-8deg);
  opacity: 0;
  pointer-events: auto;
  touch-action: none;
  display: grid;
  place-items: center;
  cursor: pointer;
  user-select: none;
  filter: drop-shadow(0 0 18px rgba(129, 247, 255, .42));
  transition: opacity 180ms ease, transform 420ms cubic-bezier(.2, 1.3, .25, 1);
}

.rare-event-object.show {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1) rotate(0deg);
}

.rare-event-object .event-symbol {
  display: grid;
  place-items: center;
  width: 76px;
  height: 76px;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: 50%;
  background: radial-gradient(circle at 34% 26%, rgba(255, 255, 255, .48), rgba(129, 247, 255, .18) 35%, rgba(2, 5, 18, .52) 70%);
  color: #fff;
  font-size: 36px;
  line-height: 1;
  box-shadow: inset 0 0 21px rgba(255, 255, 255, .12), 0 0 34px rgba(129, 247, 255, .34);
}

.rare-event-object::before {
  content: "";
  position: absolute;
  inset: 10px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .26);
  opacity: .42;
  animation: eventTargetPulse 1.2s ease-in-out infinite;
  pointer-events: none;
}

.rare-event-object:focus-visible {
  outline: 2px solid var(--event-accent);
  outline-offset: 4px;
}

.rare-event-object.holding .event-symbol {
  filter: brightness(1.22) saturate(1.2);
  box-shadow: inset 0 0 26px rgba(255, 255, 255, .20), 0 0 48px var(--event-glow);
}

.rare-event-object.activated {
  animation: eventObjectPop 260ms ease-out;
}

.rare-event-object.drag-boost {
  animation: eventObjectDragBoost 220ms ease-out;
}

.rare-event-object .event-name {
  margin-top: 6px;
  padding: 3px 9px;
  border: 1px solid rgba(129, 247, 255, .22);
  border-radius: 999px;
  background: rgba(3, 8, 22, .58);
  color: rgba(226, 247, 255, .92);
  font-size: 10px;
  letter-spacing: .13em;
  text-transform: uppercase;
  white-space: nowrap;
}

.event-shooting_star {
  animation: objectShoot 2.2s ease-out both;
}

.event-shooting_star.shooting-star-anchored {
  animation: none;
  opacity: 1;
  transition: none;
}

.event-shooting_star .event-symbol {
  clip-path: polygon(50% 0, 61% 35%, 100% 35%, 68% 56%, 80% 100%, 50% 72%, 20% 100%, 32% 56%, 0 35%, 39% 35%);
  background: radial-gradient(circle, #fff 0, #fff6b8 42%, rgba(255, 216, 107, .3) 70%);
  color: #130d03;
}

.planet-warp-name {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 8;
  pointer-events: none;
  padding: 7px 13px;
  border-radius: 999px;
  background: rgba(3, 8, 22, .46);
  color: #fff4c2;
  font-weight: 900;
  font-size: clamp(20px, 5vw, 38px);
  line-height: 1;
  text-shadow: 0 0 18px rgba(255, 216, 107, .38), 0 0 32px rgba(129, 247, 255, .24);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .18), 0 0 28px rgba(129, 247, 255, .18);
  transform-origin: center;
  animation: planetNameWarp 3.05s cubic-bezier(.16, .92, .18, 1) forwards;
}

.planet-warp-name.reduced {
  animation-duration: 1.1s;
}

@keyframes planetNameWarp {
  0% {
    opacity: 0;
    transform: translate(calc(var(--start-x) - 50%), calc(var(--start-y) - 50%)) scale(.16);
  }

  12% {
    opacity: 1;
    transform: translate(calc(var(--start-x) - 50%), calc(var(--start-y) - 50%)) scale(1.08);
  }

  44% {
    opacity: 1;
    transform: translate(calc(var(--start-x) - 50%), calc(var(--start-y) - 50%)) scale(1);
  }

  76% {
    opacity: 1;
    transform: translate(calc(var(--mid-x) - 50%), calc(var(--mid-y) - 50%)) scale(.72);
  }

  100% {
    opacity: 0;
    transform: translate(calc(var(--target-x) - 50%), calc(var(--target-y) - 50%)) scale(.34);
  }
}

.event-meteor_shower .event-symbol {
  border-radius: 32% 68% 55% 45%;
  background: linear-gradient(135deg, #ff6a3d, #ffd39a 48%, #4b1808);
  color: #210800;
  animation: objectTumble 1.1s linear infinite;
}

.event-golden_planet .event-symbol {
  background: radial-gradient(circle at 30% 20%, #fff8c7, #ffd86b 42%, #a45b00 78%);
  color: #2c1700;
  box-shadow: 0 0 44px rgba(255, 216, 107, .72);
}

.event-satellite_flyby {
  animation: satelliteSweep 2.6s ease-in-out both;
}

.event-satellite_flyby .event-symbol {
  border-radius: 14px;
  background: linear-gradient(135deg, #dffcff, #81f7ff 40%, #1c5a73);
  color: #002331;
}

.event-alien_scout_ship {
  animation: scoutBob 2.5s ease-in-out infinite;
}

.event-alien_scout_ship .event-symbol {
  width: 96px;
  height: 52px;
  border-radius: 50% 50% 42% 42%;
  background: radial-gradient(ellipse at 50% 20%, #d8fff1, #7cffb2 40%, #293042 75%);
  color: #0c2418;
}

.event-green_alien_visitor .event-symbol {
  background: radial-gradient(circle at 40% 25%, #eafff5, #7cffb2 45%, #09351f 78%);
  color: #103b22;
  animation: alienPulse 900ms ease-in-out infinite;
}

.event-wormhole_burst .event-symbol {
  background: conic-gradient(from 0deg, #81f7ff, #b18cff, #10022b, #81f7ff);
  color: #fff;
  animation: wormholeSpin 680ms linear infinite;
}

.event-cosmic_coin_comet {
  animation: cometArc 2.4s cubic-bezier(.16, .82, .24, 1) both;
}

.event-cosmic_coin_comet .event-symbol {
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  background: linear-gradient(135deg, #fff8c7, #ffd86b, #ff6a3d);
  color: #3f1800;
}

.event-black_hole_tax_refund .event-symbol {
  background: radial-gradient(circle, #000 0 34%, #6e48ff 38%, #10022b 58%, #ffd86b 62%, #090411 76%);
  color: #ffd86b;
  animation: wormholeSpin 1.4s linear infinite reverse;
}

.event-supernova_click .event-symbol {
  background: radial-gradient(circle, #fff, #ffe878 30%, #ff7a4d 55%, #ff2c7d 78%);
  color: #3c020f;
  animation: supernovaThrob 620ms ease-in-out infinite;
}

.event-star_whale {
  width: 170px;
  animation: whaleDrift 3.4s ease-in-out both;
}

.event-star_whale .event-symbol {
  width: 142px;
  height: 62px;
  border-radius: 65% 45% 58% 42%;
  background: linear-gradient(130deg, #101a4f, #b9b2ff 52%, #81f7ff);
  color: #ffffff;
}

.event-galactic_alignment .event-symbol {
  width: 104px;
  height: 104px;
  background: conic-gradient(#ff6a8a, #ffd86b, #81f7ff, #b18cff, #7cffb2, #ff6a8a);
  color: #090411;
  animation: wormholeSpin 2.8s linear infinite;
}

.event-space_jellyfish .event-symbol {
  border-radius: 55% 55% 38% 38%;
  background: radial-gradient(ellipse at 50% 25%, #fff, #ff9dff 48%, #81f7ff 80%);
  color: #49105b;
  animation: jellyFloat 1.4s ease-in-out infinite;
}

.event-quantum_duplicate_planet .event-symbol {
  background: radial-gradient(circle at 32% 45%, #81f7ff 0 18%, transparent 19%), radial-gradient(circle at 67% 45%, #ff6a8a 0 20%, transparent 21%), radial-gradient(circle, rgba(255, 255, 255, .3), rgba(8, 14, 36, .65));
  color: #fff;
}

.event-crystal_asteroid .event-symbol {
  clip-path: polygon(50% 0, 88% 25%, 74% 100%, 22% 88%, 0 32%);
  background: linear-gradient(135deg, #d7fcff, #75f7ff 42%, #b18cff);
  color: #082335;
}

.event-time_dilation_field .event-symbol {
  background: repeating-conic-gradient(from 0deg, rgba(129, 247, 255, .95) 0 14deg, rgba(255, 255, 255, .2) 14deg 32deg);
  color: #021016;
  animation: wormholeSpin 1.8s steps(16) infinite;
}

@keyframes objectShoot {
  from {
    transform: translate(-180%, -110%) scale(.4) rotate(-28deg);
  }

  to {
    transform: translate(150%, 60%) scale(1.05) rotate(8deg);
    opacity: 0;
  }
}

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

@keyframes satelliteSweep {
  0% {
    transform: translate(-170%, -50%) scale(.75);
  }

  50% {
    transform: translate(-50%, -78%) scale(1.05);
  }

  100% {
    transform: translate(120%, -45%) scale(.72);
    opacity: 0;
  }
}

@keyframes scoutBob {
  50% {
    transform: translate(-50%, -58%) scale(1.03) rotate(3deg);
  }
}

@keyframes alienPulse {
  50% {
    box-shadow: 0 0 55px rgba(124, 255, 178, .82);
    transform: scale(1.06);
  }
}

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

@keyframes cometArc {
  0% {
    transform: translate(-180%, -120%) scale(.5) rotate(-20deg);
  }

  70% {
    transform: translate(-40%, -35%) scale(1.15) rotate(8deg);
  }

  100% {
    transform: translate(80%, 30%) scale(.9) rotate(20deg);
    opacity: 0;
  }
}

@keyframes supernovaThrob {
  50% {
    transform: scale(1.14);
    filter: brightness(1.35);
  }
}

@keyframes whaleDrift {
  0% {
    transform: translate(-160%, -50%) scale(.8);
  }

  70% {
    opacity: 1;
  }

  100% {
    transform: translate(80%, -45%) scale(1.05);
    opacity: 0;
  }
}

@keyframes jellyFloat {
  50% {
    transform: translateY(-10px) scale(1.04);
  }
}

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

  .rare-event-object,
  .rare-event-object * {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition: none !important;
  }
}