:root {
  --ink: #24180f;
  --ft-parchment: #f2d99c;
  --ft-parchment-lt: #fdf7c0;
  --ft-parchment-dk: #e0ca6a;
  --ft-brown: #5c3a1e;
  --ft-brown-dk: #3d2010;
  --ft-brown-lt: #8b6020;
  --ft-green: #4a7c3f;
  --ft-green-dk: #2a4a24;
  --ft-green-lt: #72b864;
  --ft-gold: #c8870a;
  --ft-gold-dk: #7d5200;
  --ft-gold-lt: #f5c842;
  --ft-sky: #6ab4f5;
  --ft-sky-dk: #3a8acc;
  --basalt: #31583a;
  --basalt-2: #4f7546;
  --regolith: #d6c08a;
  --regolith-light: #f5e5ad;
  --sand-shadow: #9a7743;
  --hazard: #f0b637;
  --hazard-dark: #7f4d13;
  --oxide: #b64d33;
  --oxide-dark: #5e2418;
  --mint: #7bc982;
  --ice: #87c6c4;
  --violet: #8f6ab8;
  --panel: #f2d99c;
  --panel-deep: #3c2817;
  --outline: #2b1a0d;
  --lunar-floor: #747987;
  --lunar-floor-dk: #4c505d;
  --lunar-floor-lt: #aeb1ab;
  --lunar-shadow: rgba(35, 32, 28, 0.24);
  --tile-size: min(10.6vw, 76px);
  color-scheme: light;
  font-family: Inter, "Avenir Next", sans-serif;
  background: var(--ft-green-dk);
}

* {
  box-sizing: border-box;
}

html,
body,
#app {
  min-width: 320px;
  min-height: 100%;
  margin: 0;
}

body {
  color: var(--ink);
  background:
    radial-gradient(circle at 12% 8%, rgba(245, 200, 66, 0.18) 0 5px, transparent 6px),
    linear-gradient(180deg, var(--ft-sky) 0 118px, var(--ft-green) 119px 152px, var(--ft-green-dk) 153px 100%);
  overflow-x: hidden;
}

button {
  font: inherit;
}

.app-shell {
  min-height: 100vh;
  padding: 14px;
  position: relative;
}

.app-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    repeating-linear-gradient(0deg, rgba(253, 247, 192, 0.08) 0 1px, transparent 1px 18px),
    repeating-linear-gradient(90deg, rgba(253, 247, 192, 0.06) 0 1px, transparent 1px 18px);
  opacity: 0.75;
}

.topbar,
.side-panel,
.board-wrap,
.toast,
.mode-pill,
.hotbar-button,
.tab,
.store-card,
.contract-card,
.job-card,
.plot {
  image-rendering: pixelated;
}

.topbar {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(420px, auto);
  gap: 14px;
  align-items: center;
  background: var(--panel);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 var(--ft-parchment-lt),
    5px 5px 0 var(--ft-brown-dk);
  padding: 10px 14px;
}

.brand-lockup {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.brand-mark {
  width: 70px;
  height: 70px;
  flex: 0 0 auto;
  image-rendering: pixelated;
  filter: drop-shadow(4px 4px 0 var(--ft-brown-dk));
  object-fit: contain;
}

.eyebrow {
  color: var(--oxide-dark);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0;
}

h1 {
  color: var(--ft-green);
  font-family: "Press Start 2P", monospace;
  font-size: clamp(1.15rem, 2vw, 2rem);
  line-height: 1.18;
  margin: 6px 0 0;
  text-shadow:
    2px 2px 0 var(--ft-gold-lt),
    4px 4px 0 var(--ft-brown-dk);
}

.resource-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(74px, 1fr)) auto auto;
  gap: 8px;
  align-items: stretch;
}

.resource {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow: inset -2px -2px 0 var(--ft-parchment-dk), inset 2px 2px 0 #fffde0;
  min-height: 50px;
  padding: 7px 9px;
}

.resource span {
  color: #6f4b25;
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  font-weight: 700;
  line-height: 1;
}

.resource strong {
  color: #2e1a0d;
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 1rem;
  line-height: 1.1;
  margin-top: 6px;
}

.track {
  background: var(--ft-brown-dk);
  border: 2px solid var(--ft-brown);
  height: 8px;
  margin-top: 5px;
  overflow: hidden;
}

.track i {
  background: repeating-linear-gradient(90deg, var(--ft-green-lt) 0 9px, var(--ft-green) 9px 18px);
  display: block;
  height: 100%;
  width: 0%;
}

.reset-button,
.site-link-button {
  background: var(--oxide);
  border: 3px solid var(--oxide-dark);
  color: #fff2c4;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Press Start 2P", monospace;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 0 14px;
  text-decoration: none;
  box-shadow:
    inset -2px -2px 0 var(--oxide-dark),
    inset 2px 2px 0 #df7b5b,
    3px 3px 0 #0b0f0a;
}

.site-link-button {
  background: var(--ft-green);
  border-color: var(--ft-green-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-green-dk),
    inset 2px 2px 0 var(--ft-green-lt),
    3px 3px 0 #0b0f0a;
}

.reset-button:active,
.site-link-button:active,
.hotbar-button:active,
.mode-pill:active,
.tab:active,
.store-card button:active,
.contract-card button:active,
.job-card button:active {
  transform: translate(2px, 2px);
}

.game-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 280px minmax(430px, 1fr) 340px;
  gap: 16px;
  align-items: start;
  margin-top: 16px;
}

.side-panel,
.board-wrap {
  background: var(--panel);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 var(--ft-parchment-lt),
    5px 5px 0 var(--ft-brown-dk);
}

.side-panel {
  padding: 14px;
}

.panel-head {
  align-items: center;
  border-bottom: 3px solid var(--ft-brown);
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding-bottom: 10px;
}

.panel-head span,
.tabs button,
.mode-pill,
.hotbar-button strong,
.store-card h3,
.contract-card h3,
.job-card h3 {
  font-family: "Press Start 2P", monospace;
  font-weight: 700;
}

.panel-head span {
  color: var(--panel-deep);
  font-size: 0.78rem;
  line-height: 1.5;
}

.panel-head strong {
  background: #2b1a0d;
  color: var(--hazard);
  font-family: "Press Start 2P", monospace;
  font-size: 0.68rem;
  padding: 3px 8px;
}

.operator-line {
  color: #5d3d1c;
  font-size: 0.98rem;
  line-height: 1.45;
  margin: 14px 0;
}

.selected-rig {
  align-items: center;
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 10px;
  padding: 8px;
}

.rig-chip,
.crop-badge {
  align-items: center;
  background: var(--ft-parchment-lt);
  background: color-mix(in srgb, var(--badge-color, var(--ice)) 45%, var(--ft-parchment-lt));
  border: 3px solid var(--ft-brown);
  color: #1b211d;
  display: inline-flex;
  font-family: "Press Start 2P", monospace;
  font-size: 0.72rem;
  font-weight: 700;
  height: 50px;
  justify-content: center;
  line-height: 1;
  width: 50px;
  box-shadow: inset -3px -3px 0 rgba(61, 32, 16, 0.24), inset 2px 2px 0 #fffde0;
}

.rig-chip img,
.crop-badge img {
  display: block;
  height: 48px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 48px;
}

.selected-rig small {
  color: #6f4b25;
  display: block;
  font-size: 0.72rem;
}

.selected-rig strong {
  display: block;
  font-size: 0.86rem;
  overflow-wrap: anywhere;
}

.board-wrap {
  overflow: hidden;
  padding: 0 14px 14px;
}

.skyline {
  background: var(--ft-sky);
  border-bottom: 4px solid var(--ft-brown);
  height: 128px;
  margin: 0 -14px 12px;
  position: relative;
  overflow: hidden;
}

.skyline::before {
  content: "";
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.18) 0 5px, transparent 5px 16px),
    repeating-linear-gradient(0deg, rgba(58, 138, 204, 0.16) 0 3px, transparent 3px 12px);
  position: absolute;
  inset: 0;
  z-index: 1;
}

.skyline-bg {
  height: 100%;
  image-rendering: pixelated;
  inset: 0;
  object-fit: cover;
  object-position: center bottom;
  position: absolute;
  width: 100%;
  z-index: 0;
}

.module-sprite {
  bottom: 4px;
  filter: drop-shadow(3px 3px 0 var(--ft-brown-dk));
  image-rendering: pixelated;
  object-fit: contain;
  position: absolute;
  width: 92px;
  z-index: 2;
}

.module-left {
  left: 16px;
}

.module-right {
  right: 18px;
  width: 86px;
}

.rover-sprite {
  bottom: 0;
  left: 118px;
  width: 76px;
}

.board-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 12px;
}

.mode-pill,
.tab {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  color: #4f3319;
  cursor: pointer;
  font-size: 0.62rem;
  line-height: 1.6;
  min-height: 36px;
  padding: 6px 12px;
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    2px 2px 0 var(--ft-brown-dk);
}

.mode-pill.active,
.tab.active {
  background: var(--ft-gold);
  color: #2a1909;
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    2px 2px 0 var(--ft-brown-dk);
}

.moon-board {
  --board-gap: 5px;
  display: grid;
  gap: var(--board-gap);
  grid-template-columns: repeat(7, minmax(42px, var(--tile-size)));
  justify-content: center;
  margin: 0 auto;
  padding: 10px;
  width: fit-content;
  background: var(--ft-brown);
  border: 4px solid var(--ft-brown-dk);
  box-shadow: inset 4px 4px 0 var(--ft-brown-lt), inset -4px -4px 0 #1f140c;
}

.plot {
  aspect-ratio: 1;
  background: #6b5f47;
  border: 3px solid var(--ft-brown-dk);
  color: #24180f;
  cursor: pointer;
  min-width: 0;
  overflow: hidden;
  position: relative;
  transition: transform 80ms steps(2, end), filter 120ms;
}

.plot:hover {
  filter: brightness(1.08);
}

.plot:focus-visible,
button:focus-visible,
.mini-map-field:focus-visible {
  outline: 3px solid #fff0bd;
  outline-offset: 3px;
}

.plot.owned {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12) 0 12%, transparent 13%),
    repeating-linear-gradient(0deg, rgba(92, 58, 30, 0.1) 0 3px, transparent 3px 16px),
    #d3b66c;
}

.plot.locked {
  background:
    repeating-linear-gradient(45deg, rgba(0, 0, 0, 0.16) 0 8px, transparent 8px 16px),
    #4a6e37;
  filter: saturate(0.6);
}

.plot.drilled {
  background:
    radial-gradient(circle at 50% 55%, #5b321f 0 30%, transparent 31%),
    #d3b66c;
}

.plot.mining {
  background:
    repeating-linear-gradient(45deg, rgba(36, 24, 15, 0.18) 0 7px, transparent 7px 14px),
    #c5ad6a;
}

.plot.ready {
  animation: ready-pulse 1s steps(2, end) infinite;
  background:
    radial-gradient(circle at 50% 48%, rgba(255, 240, 189, 0.95) 0 18%, transparent 19%),
    var(--ft-gold-lt);
}

.plot.overheated {
  background: #7c3f2b;
}

.plot.expandable::after {
  content: "";
  position: absolute;
  inset: 4px;
  border: 3px dashed var(--hazard);
}

.plot .tile-label {
  bottom: 4px;
  color: rgba(36, 24, 15, 0.82);
  font-family: "Press Start 2P", monospace;
  font-size: 0.52rem;
  font-weight: 700;
  left: 4px;
  position: absolute;
  text-shadow: 1px 1px 0 rgba(245, 229, 173, 0.45);
  display: none;
  z-index: 2;
}

.plot .tile-icon {
  align-items: center;
  display: flex;
  font-family: "Press Start 2P", monospace;
  font-size: 0.72rem;
  font-weight: 700;
  inset: 2px;
  justify-content: center;
  line-height: 1.4;
  position: absolute;
  text-align: center;
}

.tile-text {
  color: rgba(36, 24, 15, 0.72);
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.tile-sprite {
  display: block;
  filter: drop-shadow(2px 2px 0 rgba(61, 32, 16, 0.55));
  height: 82%;
  image-rendering: pixelated;
  object-fit: contain;
  width: 82%;
}

.plot .timer {
  background: #24180fcc;
  color: #fff0bd;
  font-family: "Press Start 2P", monospace;
  font-size: 0.48rem;
  left: 4px;
  padding: 2px 4px;
  position: absolute;
  right: 4px;
  text-align: center;
  top: 4px;
  z-index: 3;
}

.plot.ready .timer {
  background: var(--ft-gold-lt);
  border: 3px solid var(--ft-brown-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 #fff0bd,
    3px 3px 0 rgba(36, 24, 15, 0.65);
  color: var(--ft-green-dk);
  font-size: 0.64rem;
  left: 50%;
  line-height: 1.35;
  padding: 5px 6px;
  right: auto;
  text-shadow: 1px 1px 0 #fff0bd;
  top: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.plot.ready .tile-icon {
  opacity: 0.35;
}

.hotbar {
  display: grid;
  grid-template-columns: repeat(4, minmax(74px, 104px));
  gap: 10px;
  justify-content: center;
  margin-top: 14px;
}

.hotbar-button {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    3px 3px 0 var(--ft-brown-dk);
  color: #3c2817;
  cursor: pointer;
  min-height: 66px;
  padding: 7px 5px;
}

.hotbar-button.selected {
  background: var(--ft-green-lt);
  box-shadow:
    inset -2px -2px 0 var(--ft-green-dk),
    inset 2px 2px 0 #bff1b8,
    3px 3px 0 var(--ft-brown-dk);
}

.hotbar-icon {
  display: block;
  height: 36px;
  line-height: 1;
}

.hotbar-icon-img {
  display: block;
  height: 38px;
  image-rendering: pixelated;
  margin: 0 auto;
  object-fit: contain;
  width: 46px;
}

.hotbar-button strong {
  display: block;
  font-size: 0.58rem;
  line-height: 1;
  margin-top: 5px;
  overflow-wrap: anywhere;
  white-space: normal;
}

.tabs {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: 12px;
}

.tab {
  font-size: 0.56rem;
  padding: 6px 4px;
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: grid;
  gap: 10px;
}

.store-card,
.contract-card,
.job-card {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow: inset -2px -2px 0 var(--ft-parchment-dk), inset 2px 2px 0 #fffde0;
  display: grid;
  gap: 9px;
  padding: 10px;
}

.store-card {
  grid-template-columns: 56px minmax(0, 1fr) auto;
  align-items: center;
}

.core-upgrade-card {
  background:
    linear-gradient(135deg, rgba(245, 200, 66, 0.2) 0 20%, transparent 21%),
    var(--ft-parchment-lt);
  border-color: var(--ft-gold-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    0 0 0 3px rgba(245, 200, 66, 0.18);
}

.store-card h3,
.contract-card h3,
.job-card h3 {
  color: #2f451f;
  font-size: 0.72rem;
  line-height: 1.55;
  margin: 0;
}

.store-card p,
.contract-card p,
.job-card p {
  color: #5d3d1c;
  font-size: 0.9rem;
  line-height: 1.32;
  margin: 2px 0 0;
}

.store-card small,
.contract-card small,
.job-card small {
  color: #77552a;
  display: block;
  font-size: 0.78rem;
  line-height: 1.25;
  margin-top: 3px;
}

.store-card button,
.contract-card button,
.job-card button {
  background: var(--ft-gold);
  border: 3px solid var(--ft-gold-dk);
  box-shadow: inset -2px -2px 0 var(--ft-gold-dk), inset 2px 2px 0 var(--ft-gold-lt), 2px 2px 0 var(--ft-brown-dk);
  color: #2b1a0d;
  cursor: pointer;
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  font-weight: 700;
  min-height: 36px;
  padding: 5px 9px;
  white-space: normal;
}

.store-card button:disabled,
.contract-card button:disabled,
.job-card button:disabled {
  cursor: not-allowed;
  filter: grayscale(0.8);
  opacity: 0.65;
}

.contract-reqs {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}

.req-pill {
  background: #2b1a0d;
  color: #fff0bd;
  font-family: "Press Start 2P", monospace;
  font-size: 0.52rem;
  line-height: 1.5;
  padding: 3px 6px;
}

.req-pill.ready {
  background: #315c30;
}

.job-progress {
  background: var(--ft-brown-dk);
  border: 2px solid var(--ft-brown);
  height: 10px;
  margin-top: 8px;
}

.job-progress i {
  background: repeating-linear-gradient(90deg, var(--ft-green-lt) 0 9px, var(--ft-green) 9px 18px);
  display: block;
  height: 100%;
}

.toast-stack {
  bottom: 16px;
  display: grid;
  gap: 8px;
  pointer-events: none;
  position: fixed;
  right: 16px;
  width: min(330px, calc(100vw - 32px));
  z-index: 20;
}

.toast {
  animation: toast-in 180ms steps(2, end);
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow: 4px 4px 0 var(--ft-brown-dk);
  color: #3c2817;
  font-weight: 700;
  font-size: 0.78rem;
  line-height: 1.5;
  padding: 10px 12px;
}

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

@keyframes ready-pulse {
  0%,
  100% {
    box-shadow: inset 0 0 0 0 #fff0bd, 0 0 0 0 rgba(240, 182, 55, 0.55);
  }
  50% {
    box-shadow: inset 0 0 0 5px #fff0bd, 0 0 0 5px rgba(240, 182, 55, 0.15);
  }
}

.site-page {
  min-height: 100vh;
  background: var(--ft-green-dk);
}

.pixel-img {
  image-rendering: pixelated;
}

.site-nav {
  align-items: center;
  background: var(--ft-brown-dk);
  border-bottom: 4px solid var(--ft-brown);
  box-shadow: 0 4px 0 #1d1008;
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1fr) auto auto auto;
  min-height: 72px;
  padding: 8px clamp(14px, 3vw, 34px);
  position: sticky;
  top: 0;
  z-index: 10;
}

.site-brand {
  align-items: center;
  color: var(--ft-parchment-lt);
  display: inline-flex;
  font-family: "Press Start 2P", monospace;
  font-size: clamp(0.72rem, 1.4vw, 1.05rem);
  gap: 10px;
  line-height: 1.4;
  min-width: 0;
  text-decoration: none;
  text-shadow: 2px 2px 0 #121006;
}

.site-brand img {
  filter: drop-shadow(3px 3px 0 #121006);
  height: 50px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 50px;
}

.site-links {
  align-items: center;
  display: flex;
  gap: 8px;
}

.site-links a,
.site-footer a {
  color: var(--ft-parchment);
  font-family: "Press Start 2P", monospace;
  font-size: 0.55rem;
  line-height: 1.5;
  padding: 8px;
  text-decoration: none;
}

.site-links a:hover,
.site-footer a:hover {
  color: var(--ft-gold-lt);
}

.pixel-action {
  align-items: center;
  background: var(--ft-gold);
  border: 3px solid var(--ft-gold-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    4px 4px 0 var(--ft-brown-dk);
  color: #2b1a0d;
  cursor: pointer;
  display: inline-flex;
  font-family: "Press Start 2P", monospace;
  font-size: 0.65rem;
  justify-content: center;
  line-height: 1.6;
  min-height: 46px;
  padding: 10px 18px;
  text-decoration: none;
  transition: transform 80ms steps(2, end), box-shadow 80ms steps(2, end);
  white-space: nowrap;
}

.pixel-action:hover {
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    6px 6px 0 var(--ft-brown-dk);
  transform: translateY(-2px);
}

.pixel-action:active {
  box-shadow:
    inset -1px -1px 0 var(--ft-gold-dk),
    inset 1px 1px 0 var(--ft-gold-lt),
    2px 2px 0 var(--ft-brown-dk);
  transform: translate(2px, 2px);
}

.pixel-action-light {
  background: var(--ft-parchment-lt);
  border-color: var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
}

.pixel-action-green {
  background: var(--ft-green);
  border-color: var(--ft-green-dk);
  color: var(--ft-parchment-lt);
  text-shadow: 1px 1px 0 var(--ft-green-dk);
}

.wallet-chip {
  align-items: center;
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  cursor: pointer;
  display: inline-flex;
  font-family: "Press Start 2P", monospace;
  font-size: 0.52rem;
  justify-content: center;
  line-height: 1.45;
  min-height: 42px;
  max-width: 230px;
  overflow: hidden;
  padding: 8px 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.wallet-chip.connected {
  background: linear-gradient(180deg, #eaffb8 0%, var(--ft-parchment-lt) 100%);
  border-color: var(--ft-green-dk);
  color: var(--ft-green-dk);
}

.wallet-gate {
  align-items: center;
  background:
    radial-gradient(circle at var(--player-x, 50%) var(--player-y, 48%), rgba(245, 200, 66, 0.18), transparent 32%),
    rgba(18, 30, 18, 0.82);
  display: none;
  inset: 0;
  justify-content: center;
  padding: 20px;
  position: fixed;
  z-index: 80;
}

.wallet-gate.open {
  display: flex;
}

.wallet-modal {
  background: var(--ft-parchment);
  border: 5px solid var(--ft-brown);
  box-shadow:
    inset -4px -4px 0 var(--ft-brown-lt),
    inset 4px 4px 0 var(--ft-parchment-lt),
    7px 7px 0 var(--ft-brown-dk);
  max-width: min(520px, calc(100vw - 34px));
  padding: 22px;
  text-align: center;
}

.wallet-modal-sprite {
  filter: drop-shadow(5px 5px 0 var(--ft-brown-dk));
  height: 74px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 74px;
}

.wallet-kicker {
  color: var(--oxide-dark);
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  line-height: 1.7;
  margin: 12px 0 4px;
}

.wallet-modal h2 {
  color: var(--ft-green);
  font-family: "Press Start 2P", monospace;
  font-size: clamp(1rem, 4vw, 1.5rem);
  line-height: 1.5;
  margin: 0;
  text-shadow: 2px 2px 0 var(--ft-gold-lt);
}

.wallet-copy {
  color: #5d3d1c;
  font-weight: 800;
  line-height: 1.45;
  margin: 12px auto 18px;
  max-width: 430px;
}

.wallet-options {
  display: grid;
  gap: 10px;
}

.wallet-primary {
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  cursor: pointer;
  font-family: "Press Start 2P", monospace;
  font-size: 0.62rem;
  line-height: 1.55;
  min-height: 46px;
  padding: 9px 12px;
}

.wallet-primary {
  background: var(--ft-gold);
}

.wallet-primary:disabled {
  cursor: wait;
  filter: grayscale(0.45);
  opacity: 0.75;
}

.wallet-help,
.wallet-home-link {
  color: #68431c;
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.5rem;
  line-height: 1.7;
  margin-top: 12px;
}

.wallet-home-link {
  color: var(--ft-green-dk);
  text-decoration: none;
}

.token-ca-panel {
  align-items: center;
  background: rgba(253, 247, 192, 0.94);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  display: none;
  gap: 6px 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  image-rendering: pixelated;
  padding: 9px 10px;
}

body.has-token-ca .token-ca-panel {
  display: grid;
}

.token-ca-panel span,
.token-ca-panel code,
.token-ca-panel small,
.token-ca-panel button {
  font-family: "Press Start 2P", monospace;
  line-height: 1.55;
}

.token-ca-panel span {
  color: var(--oxide-dark);
  font-size: 0.52rem;
}

.token-ca-panel code {
  background: rgba(135, 198, 196, 0.2);
  border: 2px solid rgba(49, 88, 58, 0.28);
  color: var(--ft-green-dk);
  font-size: 0.5rem;
  grid-column: 1 / -1;
  min-height: 30px;
  overflow: hidden;
  padding: 5px 7px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.token-ca-panel small {
  color: #6f4b25;
  font-size: 0.45rem;
}

.token-ca-panel button {
  background: var(--ft-green);
  border: 3px solid var(--ft-green-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-green-dk),
    inset 2px 2px 0 var(--ft-green-lt),
    2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-parchment-lt);
  cursor: pointer;
  font-size: 0.48rem;
  min-height: 34px;
  padding: 5px 8px;
}

.token-ca-panel button:disabled {
  background: var(--ft-parchment-dk);
  border-color: var(--ft-brown-lt);
  box-shadow:
    inset -2px -2px 0 rgba(92, 58, 30, 0.28),
    inset 2px 2px 0 #fffde0,
    2px 2px 0 var(--ft-brown-dk);
  color: #77532a;
  cursor: not-allowed;
}

.hero-token-ca {
  margin-top: 16px;
  max-width: 560px;
}

.game-token-ca {
  margin-top: 8px;
}

.site-hero {
  align-items: end;
  background: var(--ft-sky);
  display: grid;
  min-height: min(760px, calc(100svh - 104px));
  overflow: hidden;
  padding: clamp(84px, 14vh, 148px) clamp(18px, 5vw, 72px) 28px;
  position: relative;
}

.hero-bg {
  animation: hero-bg-drift 18s steps(12, end) infinite;
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: center bottom;
  position: absolute;
  transform: scale(1.04);
  transform-origin: center bottom;
  width: 100%;
  z-index: 0;
}

.hero-live-scene {
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.hero-live-scene::before {
  animation: hero-scan 9s steps(10, end) infinite;
  background:
    repeating-linear-gradient(0deg, rgba(253, 247, 192, 0.08) 0 2px, transparent 2px 18px),
    repeating-linear-gradient(90deg, rgba(42, 74, 36, 0.09) 0 3px, transparent 3px 26px);
  content: "";
  inset: 0;
  opacity: 0.68;
  position: absolute;
}

.hero-live-scene::after {
  animation: lunar-haze 6s steps(5, end) infinite;
  background:
    radial-gradient(circle at 62% 58%, rgba(245, 200, 66, 0.18) 0 90px, transparent 92px),
    linear-gradient(180deg, transparent 0 58%, rgba(42, 74, 36, 0.18) 72%, rgba(61, 32, 16, 0.1) 100%);
  content: "";
  inset: 0;
  position: absolute;
}

.hero-orbit-layer {
  border: 3px dotted rgba(253, 247, 192, 0.55);
  height: 240px;
  image-rendering: pixelated;
  opacity: 0.54;
  position: absolute;
  transform: rotate(-18deg);
  width: 520px;
}

.orbit-a {
  animation: orbit-slide-a 16s steps(12, end) infinite;
  right: 8%;
  top: 12%;
}

.orbit-b {
  animation: orbit-slide-b 21s steps(12, end) infinite reverse;
  left: -6%;
  top: 23%;
}

.hero-cloud {
  background:
    linear-gradient(#fdf7c0 0 0) 0 18px / 74px 34px no-repeat,
    linear-gradient(#fdf7c0 0 0) 42px 0 / 88px 54px no-repeat,
    linear-gradient(#fdf7c0 0 0) 118px 24px / 72px 28px no-repeat;
  filter: drop-shadow(6px 6px 0 rgba(42, 74, 36, 0.18));
  height: 68px;
  opacity: 0.82;
  position: absolute;
  width: 198px;
}

.cloud-a {
  animation: cloud-drift-a 24s steps(20, end) infinite;
  left: -12%;
  top: 15%;
}

.cloud-b {
  animation: cloud-drift-b 31s steps(22, end) infinite;
  right: -18%;
  top: 31%;
  transform: scale(0.72);
}

.cloud-c {
  animation: cloud-drift-c 38s steps(24, end) infinite;
  left: 52%;
  top: 8%;
  transform: scale(0.58);
}

.hero-scene-sprite {
  filter: drop-shadow(8px 11px 0 rgba(61, 32, 16, 0.28));
  image-rendering: pixelated;
  object-fit: contain;
  position: absolute;
}

.scene-module {
  animation: hero-machine-idle 2.8s steps(3, end) infinite;
  bottom: 12%;
  right: 16%;
  width: clamp(86px, 12vw, 148px);
}

.scene-antenna {
  animation: hero-machine-idle 3.2s steps(3, end) infinite reverse;
  bottom: 20%;
  right: 7%;
  width: clamp(58px, 8vw, 96px);
}

.scene-drill {
  animation: drill-pulse 920ms steps(2, end) infinite;
  bottom: 11%;
  left: 53%;
  width: clamp(54px, 7vw, 82px);
}

.scene-rover {
  animation: hero-rover-route 14s steps(18, end) infinite;
  bottom: 8%;
  left: 8%;
  width: clamp(54px, 8vw, 92px);
}

.scene-ice {
  animation: mineral-twinkle 1.8s steps(3, end) infinite;
  bottom: 25%;
  left: 36%;
  width: clamp(42px, 5vw, 66px);
}

.scene-quartz {
  animation: mineral-twinkle 2.2s steps(3, end) infinite reverse;
  bottom: 15%;
  right: 35%;
  width: clamp(38px, 5vw, 62px);
}

.hero-signal {
  border: 4px solid rgba(245, 200, 66, 0.7);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  height: 84px;
  opacity: 0;
  position: absolute;
  width: 108px;
}

.signal-a {
  animation: signal-pulse 2.4s steps(4, end) infinite;
  bottom: 22%;
  right: 11%;
}

.signal-b {
  animation: signal-pulse 3s steps(4, end) infinite 900ms;
  bottom: 30%;
  left: 45%;
}

.hero-dust {
  background: var(--ft-gold-lt);
  box-shadow: 0 0 0 2px rgba(61, 32, 16, 0.12);
  height: 6px;
  position: absolute;
  transform: rotate(-20deg);
  width: 12px;
}

.dust-a {
  animation: hero-dust-run 3.8s steps(8, end) infinite;
  bottom: 11%;
  left: 20%;
}

.dust-b {
  animation: hero-dust-run 5.1s steps(8, end) infinite reverse;
  bottom: 18%;
  left: 61%;
}

.dust-c {
  animation: hero-dust-run 4.4s steps(8, end) infinite 700ms;
  bottom: 24%;
  right: 18%;
}

.hero-cloud-mask {
  background:
    repeating-linear-gradient(90deg, rgba(253, 247, 192, 0.16) 0 4px, transparent 4px 16px),
    linear-gradient(180deg, rgba(106, 180, 245, 0.18), rgba(42, 74, 36, 0.18));
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 2;
}

.hero-content {
  max-width: 780px;
  min-width: 0;
  position: relative;
  width: min(100%, 780px);
  z-index: 3;
}

.hero-logo-sprite {
  filter: drop-shadow(5px 5px 0 var(--ft-brown-dk));
  height: clamp(74px, 12vw, 126px);
  object-fit: contain;
  width: clamp(74px, 12vw, 126px);
}

.hero-kicker,
.section-heading span {
  color: var(--ft-brown-dk);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: clamp(0.5rem, 1vw, 0.72rem);
  line-height: 1.9;
  margin-top: 14px;
}

.site-hero h1 {
  color: var(--ft-green);
  font-size: clamp(2.45rem, 8.5vw, 6.6rem);
  line-height: 1.04;
  margin: 12px 0 18px;
  max-width: 900px;
  text-shadow:
    4px 4px 0 var(--ft-gold-lt),
    8px 8px 0 var(--ft-brown-dk),
    -3px -3px 0 var(--ft-parchment-lt),
    3px -3px 0 var(--ft-parchment-lt),
    -3px 3px 0 var(--ft-parchment-lt);
}

.hero-copy {
  color: var(--ft-brown-dk);
  font-size: clamp(1rem, 1.7vw, 1.38rem);
  font-weight: 800;
  line-height: 1.45;
  max-width: 620px;
  text-shadow: 1px 1px 0 var(--ft-parchment-lt);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.hero-stats {
  align-self: end;
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  justify-self: end;
  max-width: 520px;
  position: relative;
  width: min(100%, 520px);
  z-index: 3;
}

.hero-stats div {
  background: var(--ft-parchment-lt);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
  padding: 12px;
}

.hero-stats strong {
  color: var(--ft-green);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: clamp(0.8rem, 1.5vw, 1.2rem);
  line-height: 1.4;
}

.hero-stats span {
  color: var(--ft-text-lt, #6b4020);
  display: block;
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1.3;
  margin-top: 4px;
}

.site-band {
  padding: clamp(48px, 8vw, 86px) clamp(18px, 5vw, 72px);
}

.site-loop {
  background: var(--ft-parchment);
  border-top: 4px solid var(--ft-brown);
}

.section-heading {
  margin: 0 auto clamp(24px, 4vw, 42px);
  max-width: 980px;
}

.section-heading h2 {
  color: var(--ft-brown-dk);
  font-family: "Press Start 2P", monospace;
  font-size: clamp(1.3rem, 3vw, 2.35rem);
  line-height: 1.55;
  margin: 6px 0 0;
  text-shadow: 3px 3px 0 rgba(200, 135, 10, 0.34);
}

.loop-track {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1180px;
}

.loop-step,
.rig-grid article,
.roadmap-lanes article {
  background: var(--ft-parchment-lt);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-parchment-dk),
    inset 3px 3px 0 #fffde0,
    5px 5px 0 var(--ft-brown-dk);
  min-width: 0;
  padding: 18px;
}

.loop-step img {
  height: 86px;
  object-fit: contain;
  width: 86px;
}

.loop-step h3,
.roadmap-lanes h3 {
  color: var(--ft-green-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.82rem;
  line-height: 1.6;
  margin: 14px 0 6px;
}

.loop-step p,
.roadmap-lanes p,
.rig-showcase p {
  color: var(--ft-brown-dk);
  font-size: 0.96rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 0;
}

.site-rigs {
  align-items: center;
  background:
    repeating-linear-gradient(0deg, rgba(253, 247, 192, 0.05) 0 1px, transparent 1px 22px),
    var(--ft-green);
  display: grid;
  gap: clamp(24px, 5vw, 60px);
  grid-template-columns: minmax(260px, 0.85fr) minmax(320px, 1.15fr);
}

.rig-showcase {
  color: var(--ft-parchment-lt);
}

.rig-showcase .section-heading {
  margin-left: 0;
}

.rig-showcase .section-heading span,
.section-heading-light span {
  color: var(--ft-gold-lt);
}

.rig-showcase .section-heading h2,
.section-heading-light h2 {
  color: var(--ft-parchment-lt);
  text-shadow: 3px 3px 0 var(--ft-brown-dk);
}

.rig-showcase p {
  color: var(--ft-parchment-lt);
  max-width: 520px;
}

.rig-showcase .pixel-action {
  margin-top: 22px;
}

.rig-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rig-grid article {
  min-height: 230px;
  text-align: center;
}

.rig-grid img {
  height: 110px;
  margin: 0 auto 14px;
  object-fit: contain;
  width: 110px;
}

.rig-grid strong {
  color: var(--ft-green-dk);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.72rem;
  line-height: 1.7;
}

.rig-grid span {
  color: var(--ft-brown-lt);
  display: block;
  font-weight: 800;
  margin-top: 8px;
}

.site-roadmap {
  background: var(--ft-brown-dk);
}

.roadmap-lanes {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1100px;
}

.roadmap-lanes article {
  background: var(--ft-green-dk);
  border-color: var(--ft-green-lt);
  box-shadow:
    inset -3px -3px 0 #1a2e16,
    inset 3px 3px 0 var(--ft-green-lt),
    5px 5px 0 #0d1a0a;
}

.roadmap-lanes img {
  height: 88px;
  object-fit: contain;
  width: 88px;
}

.roadmap-lanes h3 {
  color: var(--ft-gold-lt);
}

.roadmap-lanes p {
  color: var(--ft-parchment-lt);
}

.site-footer {
  align-items: center;
  background: #1a2e16;
  border-top: 4px solid var(--ft-brown);
  color: var(--ft-parchment);
  display: flex;
  font-family: "Press Start 2P", monospace;
  font-size: 0.62rem;
  gap: 18px;
  justify-content: space-between;
  line-height: 1.7;
  padding: 22px clamp(18px, 5vw, 72px);
}

.game-page {
  background:
    radial-gradient(circle at 18% 28%, rgba(222, 226, 226, 0.16) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 72%, rgba(36, 39, 48, 0.16) 0 4px, transparent 5px),
    url("./assets/sprites/regolith-tile.svg") 0 0 / 128px 128px repeat,
    var(--lunar-floor);
  height: 100vh;
  height: 100svh;
  inset: 0;
  overflow: hidden;
  overscroll-behavior: none;
  position: fixed;
  width: 100%;
}

.world-shell {
  height: 100vh;
  height: 100svh;
  min-height: 640px;
  min-width: 320px;
  overflow: clip;
}

.world-stage {
  --player-x: 47%;
  --player-y: 49%;
  --player-world-x: 1500px;
  --player-world-y: 1080px;
  --npc-x: 66%;
  --npc-y: 42%;
  --npc-world-x: 2110px;
  --npc-world-y: 920px;
  --camera-x: 0px;
  --camera-y: 0px;
  --camera-scale: 1;
  --surface-w: 3400px;
  --surface-h: 2400px;
  background:
    radial-gradient(circle at 18% 28%, rgba(222, 226, 226, 0.16) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 72%, rgba(36, 39, 48, 0.16) 0 4px, transparent 5px),
    radial-gradient(circle at 49% 46%, rgba(245, 200, 66, 0.09) 0 110px, transparent 112px),
    url("./assets/sprites/regolith-tile.svg") 0 0 / 128px 128px repeat,
    var(--lunar-floor);
  height: 100%;
  cursor: crosshair;
  overflow: clip;
  overscroll-behavior: none;
  position: relative;
  touch-action: none;
}

.wallet-locked .world-stage *,
.wallet-locked .site-hero * {
  animation-play-state: paused !important;
}

.world-stage.is-panning {
  cursor: grabbing;
}

.world-stage::before {
  content: "";
  inset: -80px;
  pointer-events: none;
  position: absolute;
  background:
    radial-gradient(circle at 12% 76%, rgba(58, 54, 47, 0.32) 0 122px, transparent 124px),
    radial-gradient(circle at 84% 24%, rgba(97, 90, 75, 0.26) 0 118px, transparent 120px),
    radial-gradient(circle at 54% 106%, rgba(47, 44, 38, 0.28) 0 140px, transparent 142px),
    linear-gradient(120deg, rgba(255, 240, 189, 0.08), transparent 38%, rgba(35, 32, 28, 0.12));
  mix-blend-mode: multiply;
  opacity: 0.34;
  z-index: 0;
}

.world-noise {
  inset: 0;
  pointer-events: none;
  position: absolute;
  background:
    repeating-linear-gradient(0deg, rgba(43, 40, 34, 0.12) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(90deg, rgba(218, 207, 172, 0.08) 0 1px, transparent 1px 16px);
  z-index: 1;
}

.night-spotlight {
  inset: 0;
  pointer-events: none;
  position: absolute;
  background:
    radial-gradient(circle at var(--player-x) var(--player-y), rgba(245, 200, 66, 0.18) 0 78px, rgba(245, 200, 66, 0.08) 79px 158px, transparent 159px),
    rgba(28, 28, 24, 0.28);
  mix-blend-mode: multiply;
  z-index: 3;
}

.world-profile,
.world-resource-bar,
.world-actions,
.world-tip,
.canvas-status,
.mini-map,
.camera-controls,
.world-menu,
.mission-popover,
.world-hotbar,
.rotate-control,
.toast-stack {
  position: absolute;
  z-index: 8;
}

.world-profile {
  left: 12px;
  top: 12px;
}

.profile-button {
  align-items: center;
  background: var(--ft-parchment-lt);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
  display: inline-flex;
  height: 54px;
  justify-content: center;
  width: 54px;
}

.profile-button img {
  height: 42px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 42px;
}

.world-resource-bar {
  display: flex;
  gap: 0;
  left: 50%;
  min-width: 430px;
  top: 18px;
  transform: translateX(-50%);
}

.world-resource-bar .resource {
  border-width: 3px;
  min-height: 38px;
  min-width: 92px;
  padding: 5px 8px;
}

.world-resource-bar .resource span {
  font-size: 0.48rem;
}

.world-resource-bar .resource strong {
  font-size: 0.8rem;
  margin-top: 4px;
}

.world-actions {
  align-items: flex-start;
  display: flex;
  gap: 8px;
  right: 12px;
  top: 12px;
}

.world-wallet-chip {
  max-width: 190px;
  min-width: 150px;
}

.world-actions .site-link-button,
.world-actions .reset-button {
  min-height: 44px;
  min-width: 68px;
}

.world-actions .wallet-disconnect {
  background: var(--ft-parchment-lt);
  border-color: var(--ft-brown);
  color: var(--ft-brown-dk);
  font-size: 0.48rem;
  min-width: 112px;
}

.world-tip {
  background: var(--ft-parchment-lt);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  display: grid;
  gap: 4px;
  left: 50%;
  padding: 9px 14px;
  top: 74px;
  transform: translateX(-50%);
  width: min(430px, calc(100vw - 520px));
}

.world-tip strong {
  color: var(--ft-green);
  font-family: "Press Start 2P", monospace;
  font-size: 0.56rem;
  line-height: 1.4;
}

.world-tip span {
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.35;
}

.world-tip button {
  background: var(--ft-gold);
  border: 3px solid var(--ft-gold-dk);
  box-shadow: inset -2px -2px 0 var(--ft-gold-dk), inset 2px 2px 0 var(--ft-gold-lt), 2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.52rem;
  justify-self: end;
  margin-top: 2px;
  padding: 7px 10px;
}

.world-stage.expand-mode .world-tip {
  display: none;
}

.world-stage.expand-mode .plot.expandable::after {
  animation: ready-pulse 1s steps(2, end) infinite;
}

.canvas-status {
  background: rgba(253, 247, 192, 0.94);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    4px 4px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  display: grid;
  gap: 3px;
  font-family: "Press Start 2P", monospace;
  left: 84px;
  padding: 8px 10px;
  top: 82px;
  width: 190px;
}

.canvas-status strong,
.canvas-status span {
  display: block;
  font-size: 0.5rem;
  line-height: 1.5;
}

.canvas-status span {
  color: #6d4a24;
}

.mini-map {
  background: var(--ft-parchment);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 var(--ft-parchment-lt),
    4px 4px 0 var(--ft-brown-dk);
  left: 12px;
  padding: 8px;
  top: 436px;
  width: 170px;
}

.mini-map-head {
  align-items: center;
  border-bottom: 3px solid var(--ft-brown);
  display: flex;
  font-family: "Press Start 2P", monospace;
  justify-content: space-between;
  margin-bottom: 7px;
  padding-bottom: 5px;
}

.mini-map-head strong,
.mini-map-head span {
  color: var(--ft-green-dk);
  font-size: 0.48rem;
}

.mini-map-field {
  background:
    radial-gradient(circle at 48% 46%, rgba(245, 200, 66, 0.35) 0 8px, transparent 9px),
    radial-gradient(circle at 23% 24%, rgba(43, 40, 34, 0.45) 0 11px, transparent 12px),
    radial-gradient(circle at 78% 62%, rgba(43, 40, 34, 0.38) 0 14px, transparent 15px),
    repeating-linear-gradient(0deg, rgba(218, 207, 172, 0.14) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(90deg, rgba(218, 207, 172, 0.12) 0 1px, transparent 1px 12px),
    #696251;
  border: 3px solid var(--ft-brown-dk);
  cursor: pointer;
  height: 106px;
  overflow: hidden;
  position: relative;
}

.mini-blip,
.mini-node-layer,
.mini-player,
.mini-viewport {
  position: absolute;
}

.mini-blip {
  background: var(--ft-gold-lt);
  border: 2px solid var(--ft-brown-dk);
  height: 8px;
  width: 8px;
}

.mini-core {
  left: 47%;
  top: 45%;
}

.mini-node-layer {
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.mini-node {
  background: #87c6c4;
  border: 2px solid var(--ft-brown-dk);
  box-shadow: 0 0 0 1px rgba(245, 200, 66, 0.38);
  height: 8px;
  position: absolute;
  transform: translate(-50%, -50%);
  width: 8px;
}

.mini-node.field-mini-node {
  border-width: 1px;
  height: 5px;
  opacity: 0.72;
  width: 5px;
}

.mini-node[data-kind="debris"] {
  background: #ff6a3d;
}

.mini-node[data-kind="relay"] {
  background: var(--ft-gold-lt);
}

.mini-node.cooling {
  filter: grayscale(0.85);
  opacity: 0.38;
}

.mini-player {
  background: #f6f0da;
  border: 2px solid var(--oxide-dark);
  box-shadow: 0 0 0 2px rgba(245, 200, 66, 0.5);
  height: 10px;
  transform: translate(-50%, -50%);
  width: 10px;
  z-index: 3;
}

.mini-viewport {
  border: 2px solid var(--ft-parchment-lt);
  box-shadow: 0 0 0 1px rgba(36, 24, 15, 0.55);
  min-height: 14px;
  min-width: 18px;
  z-index: 2;
}

.camera-controls {
  display: grid;
  gap: 6px;
  left: 12px;
  top: 576px;
}

.camera-controls button {
  background: var(--ft-gold);
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  cursor: pointer;
  font-family: "Press Start 2P", monospace;
  font-size: 0.95rem;
  height: 42px;
  width: 42px;
}

.world-camera {
  height: var(--surface-h);
  left: 50%;
  pointer-events: none;
  position: absolute;
  top: 50%;
  transform:
    translate(-50%, -50%)
    translate3d(var(--camera-x), var(--camera-y), 0)
    scale(var(--camera-scale));
  transform-origin: center center;
  width: var(--surface-w);
  will-change: transform;
  z-index: 2;
}

.infinite-surface {
  background:
    radial-gradient(circle at 49% 46%, rgba(245, 200, 66, 0.12) 0 110px, transparent 112px),
    radial-gradient(circle at 16% 22%, rgba(42, 45, 54, 0.5) 0 170px, transparent 172px),
    radial-gradient(circle at 82% 66%, rgba(35, 38, 47, 0.28) 0 180px, transparent 182px),
    radial-gradient(circle at 64% 18%, rgba(146, 150, 160, 0.32) 0 120px, transparent 122px),
    url("./assets/sprites/regolith-tile.svg") 0 0 / 128px 128px repeat,
    var(--lunar-floor);
  box-shadow: inset 0 0 140px rgba(35, 32, 28, 0.12);
  height: 100%;
  overflow: hidden;
  pointer-events: auto;
  position: relative;
  width: 100%;
}

.infinite-surface::before,
.infinite-surface::after {
  content: "";
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.infinite-surface::before {
  background:
    radial-gradient(circle at 49% 47%, rgba(43, 40, 34, 0.38) 0 70px, rgba(194, 181, 139, 0.24) 71px 112px, transparent 114px),
    radial-gradient(circle at 22% 24%, rgba(43, 40, 34, 0.32) 0 92px, rgba(194, 181, 139, 0.18) 93px 140px, transparent 142px),
    radial-gradient(circle at 74% 62%, rgba(43, 40, 34, 0.34) 0 110px, rgba(194, 181, 139, 0.2) 111px 166px, transparent 168px),
    radial-gradient(circle at 68% 21%, rgba(43, 40, 34, 0.28) 0 62px, rgba(194, 181, 139, 0.17) 63px 98px, transparent 100px);
  inset: 0;
}

.infinite-surface::after {
  background:
    repeating-linear-gradient(96deg, transparent 0 32px, rgba(43, 40, 34, 0.22) 32px 40px, rgba(218, 207, 172, 0.13) 40px 45px, transparent 45px 86px),
    repeating-linear-gradient(17deg, transparent 0 52px, rgba(43, 40, 34, 0.14) 52px 58px, transparent 58px 120px);
  height: 1050px;
  left: 720px;
  opacity: 0.42;
  top: 620px;
  transform: rotate(-9deg);
  width: 1800px;
}

.surface-grid,
.surface-glow,
.ore-field {
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.world-node-layer {
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 4;
}

.surface-grid {
  background:
    linear-gradient(rgba(227, 232, 230, 0.16) 1px, transparent 1px),
    linear-gradient(90deg, rgba(28, 31, 40, 0.18) 1px, transparent 1px);
  background-size: 128px 128px;
  opacity: 0.08;
  z-index: 0;
}

.surface-glow {
  background:
    radial-gradient(circle at 45% 47%, rgba(245, 200, 66, 0.16) 0 170px, transparent 174px),
    radial-gradient(circle at 63% 33%, rgba(135, 198, 196, 0.16) 0 98px, transparent 100px),
    radial-gradient(circle at 29% 67%, rgba(181, 106, 201, 0.16) 0 84px, transparent 86px),
    linear-gradient(120deg, rgba(43, 40, 34, 0.18), transparent 42%, rgba(218, 207, 172, 0.12));
  mix-blend-mode: soft-light;
  z-index: 1;
}

.canvas-object {
  filter:
    drop-shadow(0 10px 0 rgba(35, 32, 28, 0.2))
    drop-shadow(2px 3px 0 rgba(253, 247, 192, 0.08));
  image-rendering: pixelated;
  object-fit: contain;
  position: absolute;
  z-index: 2;
}

.lunar-decal {
  image-rendering: pixelated;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.lunar-crater {
  background:
    radial-gradient(circle at 42% 38%, rgba(45, 42, 37, 0.56) 0 28%, transparent 29%),
    radial-gradient(circle at 50% 50%, rgba(45, 42, 37, 0.7) 0 42%, rgba(194, 181, 139, 0.34) 43% 56%, transparent 57%);
  border: 5px solid rgba(52, 48, 42, 0.48);
  box-shadow:
    inset 8px 8px 0 rgba(43, 40, 34, 0.38),
    inset -8px -8px 0 rgba(218, 207, 172, 0.22),
    10px 12px 0 rgba(43, 40, 34, 0.14);
  clip-path: polygon(16% 8%, 55% 0, 91% 17%, 100% 55%, 78% 90%, 36% 100%, 6% 78%, 0 34%);
  height: var(--decal-size, 120px);
  opacity: var(--decal-opacity, 0.82);
  width: var(--decal-size, 120px);
}

.lunar-dimple {
  background:
    radial-gradient(circle at 48% 45%, rgba(43, 40, 34, 0.58) 0 42%, rgba(194, 181, 139, 0.22) 43% 62%, transparent 63%);
  height: var(--decal-size, 34px);
  opacity: var(--decal-opacity, 0.64);
  width: var(--decal-size, 34px);
}

.lunar-ridge {
  background:
    repeating-linear-gradient(90deg, rgba(43, 40, 34, 0.46) 0 18px, rgba(194, 181, 139, 0.34) 18px 28px, transparent 28px 54px);
  height: 18px;
  opacity: var(--decal-opacity, 0.62);
  transform: rotate(var(--decal-rotate, -16deg));
  width: var(--decal-size, 260px);
}

.lunar-track {
  background:
    repeating-linear-gradient(90deg, rgba(51, 47, 41, 0.28) 0 10px, transparent 10px 22px),
    linear-gradient(0deg, transparent 0 35%, rgba(51, 47, 41, 0.3) 36% 48%, transparent 49% 58%, rgba(218, 207, 172, 0.16) 59% 70%, transparent 71%);
  height: 28px;
  opacity: var(--decal-opacity, 0.72);
  transform: rotate(var(--decal-rotate, 8deg));
  width: var(--decal-size, 320px);
}

.lunar-pad {
  background:
    linear-gradient(45deg, rgba(245, 200, 66, 0.2) 0 12%, transparent 13% 38%, rgba(43, 40, 34, 0.18) 39% 62%, transparent 63%),
    repeating-linear-gradient(0deg, rgba(253, 247, 192, 0.14) 0 3px, transparent 3px 22px),
    rgba(102, 96, 80, 0.68);
  border: 5px solid rgba(52, 48, 42, 0.62);
  box-shadow:
    inset -6px -6px 0 rgba(43, 40, 34, 0.28),
    inset 6px 6px 0 rgba(218, 207, 172, 0.18),
    9px 11px 0 rgba(43, 40, 34, 0.18);
  height: calc(var(--decal-size, 170px) * 0.62);
  opacity: var(--decal-opacity, 0.82);
  transform: rotate(var(--decal-rotate, 0deg)) skewX(-8deg);
  width: var(--decal-size, 170px);
}

.lunar-ore-speck {
  background: var(--ore-color, #87c6c4);
  box-shadow:
    8px 0 0 rgba(43, 40, 34, 0.18),
    0 8px 0 rgba(253, 247, 192, 0.28),
    10px 10px 0 color-mix(in srgb, var(--ore-color, #87c6c4) 65%, #2b2822);
  height: 8px;
  opacity: var(--decal-opacity, 0.9);
  width: 8px;
}

.canvas-object.tiny {
  width: 42px;
}

.canvas-object.small {
  width: 64px;
}

.canvas-object.large {
  width: 96px;
}

.canvas-label {
  background: rgba(253, 247, 192, 0.9);
  border: 3px solid var(--ft-brown);
  box-shadow: 3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-green-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  line-height: 1.5;
  padding: 5px 8px;
  position: absolute;
  white-space: nowrap;
  z-index: 3;
}

.label-core {
  left: 1320px;
  top: 730px;
}

.label-ridge {
  left: 550px;
  top: 420px;
}

.label-ice {
  left: 2360px;
  top: 1480px;
}

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

.prop {
  filter:
    drop-shadow(0 12px 0 rgba(35, 32, 28, 0.22))
    drop-shadow(2px 3px 0 rgba(253, 247, 192, 0.08));
  image-rendering: pixelated;
  object-fit: contain;
  position: absolute;
  animation: prop-bob 3.8s steps(4, end) infinite;
}

.prop-module {
  width: 128px;
}

.prop-antenna,
.prop-ice,
.prop-quartz,
.prop-storage {
  width: 82px;
}

.prop-crater,
.prop-meteor {
  width: 70px;
}

.p1 {
  left: 13%;
  top: 14%;
}

.p2 {
  right: 16%;
  top: 14%;
}

.p3 {
  left: 6%;
  bottom: 13%;
}

.p4 {
  right: 11%;
  bottom: 18%;
}

.p5 {
  left: 30%;
  top: 33%;
}

.p6 {
  right: 33%;
  top: 55%;
}

.p7 {
  left: 46%;
  bottom: 15%;
}

.p8 {
  left: 21%;
  bottom: 35%;
}

.p9 {
  right: 8%;
  top: 44%;
}

.dust {
  background: var(--ft-gold-lt);
  box-shadow: 0 0 0 2px rgba(61, 32, 16, 0.12);
  height: 5px;
  image-rendering: pixelated;
  position: absolute;
  transform: rotate(-28deg);
  width: 10px;
}

.d1 {
  left: 42%;
  top: 58%;
  animation: dust-drift 5.2s steps(8, end) infinite;
}

.d2 {
  left: 58%;
  top: 32%;
  animation: dust-drift 6.4s steps(8, end) infinite reverse;
}

.d3 {
  right: 21%;
  bottom: 22%;
  animation: dust-drift 5.8s steps(8, end) infinite;
}

.d4 {
  left: 27%;
  bottom: 18%;
  animation: dust-drift 7s steps(8, end) infinite reverse;
}

.world-character {
  background: transparent;
  border: 0;
  cursor: pointer;
  image-rendering: pixelated;
  padding: 0;
  position: absolute;
  transform: translate(-50%, -50%);
  pointer-events: auto;
  z-index: 4;
}

.world-character img {
  filter: drop-shadow(5px 8px 0 rgba(61, 32, 16, 0.28));
  height: 58px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 58px;
}

.world-character[data-moving="true"] img {
  animation: rover-walk 320ms steps(2, end) infinite;
}

.player-character {
  left: var(--player-world-x);
  top: var(--player-world-y);
}

.npc-character {
  left: var(--npc-world-x);
  top: var(--npc-world-y);
}

.npc-character img {
  animation: npc-idle 1.8s steps(3, end) infinite;
  height: 68px;
  width: 68px;
}

.selection-diamond {
  border: 5px solid var(--ft-gold-lt);
  box-shadow:
    0 0 0 2px rgba(92, 58, 30, 0.08),
    0 0 34px rgba(245, 200, 66, 0.34);
  height: 124px;
  left: var(--player-world-x);
  pointer-events: none;
  position: absolute;
  top: calc(var(--player-world-y) + 30px);
  transform: translate(-50%, -50%) rotate(30deg) skewX(-18deg);
  width: 142px;
  z-index: 3;
}

.nameplate {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow: 3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.58rem;
  left: 50%;
  line-height: 1.4;
  padding: 4px 7px;
  position: absolute;
  top: -30px;
  transform: translateX(-50%);
  white-space: nowrap;
}

.quest-mark {
  color: #ff4a24;
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 2.3rem;
  left: 50%;
  line-height: 1;
  position: absolute;
  text-shadow:
    2px 2px 0 var(--ft-gold-lt),
    4px 4px 0 var(--ft-brown-dk);
  top: -76px;
  transform: translateX(-50%);
}

.world-board {
  --tile-size: 58px;
  background: transparent;
  border: 0;
  box-shadow: none;
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(7, var(--tile-size));
  isolation: isolate;
  left: 1600px;
  padding: 0;
  position: absolute;
  top: 1120px;
  transform: translate(-50%, -50%);
  width: max-content;
  z-index: 3;
}

.world-board::before {
  background:
    radial-gradient(ellipse at 48% 48%, rgba(245, 200, 66, 0.16) 0 34%, transparent 35%),
    repeating-linear-gradient(90deg, rgba(35, 32, 28, 0.16) 0 8px, transparent 8px 28px),
    rgba(91, 91, 86, 0.28);
  border: 4px solid rgba(45, 42, 37, 0.36);
  box-shadow:
    inset 8px 8px 0 rgba(253, 247, 192, 0.06),
    inset -8px -8px 0 rgba(35, 32, 28, 0.2),
    14px 18px 0 rgba(35, 32, 28, 0.16);
  clip-path: polygon(9% 0, 92% 3%, 100% 45%, 91% 96%, 8% 100%, 0 55%);
  content: "";
  inset: -28px;
  pointer-events: none;
  position: absolute;
  z-index: 0;
}

.world-board[data-core-level="2"]::before,
.world-board[data-core-level="3"]::before,
.world-board[data-core-level="4"]::before,
.world-board[data-core-level="5"]::before {
  box-shadow:
    inset 8px 8px 0 rgba(253, 247, 192, 0.08),
    inset -8px -8px 0 rgba(35, 32, 28, 0.2),
    0 0 34px rgba(245, 200, 66, 0.2),
    14px 18px 0 rgba(35, 32, 28, 0.16);
}

.world-board[data-core-level="4"]::before,
.world-board[data-core-level="5"]::before {
  background:
    radial-gradient(ellipse at 48% 48%, rgba(245, 200, 66, 0.28) 0 34%, transparent 35%),
    repeating-linear-gradient(90deg, rgba(35, 32, 28, 0.16) 0 8px, transparent 8px 28px),
    rgba(91, 91, 86, 0.32);
}

.world-board .plot {
  background: transparent;
  border: 0;
  cursor: pointer;
  overflow: visible;
  pointer-events: auto;
  z-index: 1;
}

.world-board .plot.owned.raw,
.world-board .plot.owned.drilled,
.world-board .plot.owned.mining,
.world-board .plot.owned.ready,
.world-board .plot.owned.overheated {
  background:
    radial-gradient(circle at 62% 36%, rgba(245, 200, 66, 0.16) 0 3px, transparent 4px),
    radial-gradient(circle at 24% 72%, rgba(35, 32, 28, 0.18) 0 5px, transparent 6px),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
  border: 3px solid rgba(64, 61, 55, 0.94);
  box-shadow:
    inset 3px 3px 0 rgba(227, 232, 230, 0.2),
    inset -4px -4px 0 rgba(35, 32, 28, 0.36),
    5px 7px 0 rgba(35, 32, 28, 0.24);
}

.world-board .plot.owned::before {
  border: 2px solid rgba(218, 207, 172, 0.18);
  box-shadow: inset 2px 2px 0 rgba(253, 247, 192, 0.06);
  content: "";
  inset: 5px;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.world-board .plot.owned.mining {
  background:
    repeating-linear-gradient(45deg, rgba(240, 182, 55, 0.2) 0 7px, transparent 7px 14px),
    radial-gradient(circle at 50% 58%, rgba(245, 200, 66, 0.16) 0 30%, transparent 31%),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
  border-color: rgba(240, 182, 55, 0.82);
}

.world-board .plot.owned.ready {
  background:
    radial-gradient(circle at 50% 50%, rgba(245, 200, 66, 0.56) 0 31%, transparent 32%),
    radial-gradient(circle at 50% 50%, rgba(135, 198, 196, 0.18) 0 52%, transparent 53%),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
  border-color: var(--ft-gold-lt);
  box-shadow:
    0 0 0 4px rgba(245, 200, 66, 0.22),
    0 0 18px rgba(245, 200, 66, 0.55),
    6px 8px 0 rgba(35, 32, 28, 0.24);
}

.world-board .plot.owned.raw {
  background:
    linear-gradient(135deg, rgba(245, 200, 66, 0.14) 0 16%, transparent 17%),
    radial-gradient(circle at 28% 35%, rgba(227, 232, 230, 0.18) 0 4px, transparent 5px),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
}

.world-board .plot.owned.drilled {
  background:
    radial-gradient(circle at 50% 56%, rgba(35, 32, 28, 0.58) 0 24%, rgba(218, 207, 172, 0.16) 25% 35%, transparent 36%),
    repeating-linear-gradient(116deg, transparent 0 12px, rgba(35, 32, 28, 0.16) 12px 15px, transparent 15px 30px),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
  border-color: rgba(245, 200, 66, 0.72);
}

.world-board .plot.owned.overheated {
  background:
    radial-gradient(circle at 50% 54%, rgba(182, 77, 51, 0.48) 0 31%, transparent 32%),
    repeating-linear-gradient(45deg, rgba(126, 63, 43, 0.24) 0 7px, transparent 7px 14px),
    url("./assets/sprites/regolith-tile.svg") center / 94px 94px repeat,
    var(--lunar-floor);
  border-color: rgba(182, 77, 51, 0.84);
}

.world-board .plot.owned.raw,
.world-board .plot.owned.drilled,
.world-board .plot.owned.mining,
.world-board .plot.owned.ready,
.world-board .plot.owned.overheated,
.world-node::before {
  background-blend-mode: screen, normal, normal, normal;
}

.world-board .plot.owned.raw .tile-label {
  color: rgba(255, 244, 196, 0.88);
  display: block;
  font-size: 0.42rem;
  text-shadow: 2px 2px 0 rgba(41, 36, 28, 0.8);
}

.world-board .plot.owned.drilled .tile-label,
.world-board .plot.owned.mining .tile-label,
.world-board .plot.owned.ready .tile-label,
.world-board .plot.owned.overheated .tile-label {
  background: rgba(36, 24, 15, 0.82);
  border: 2px solid rgba(255, 240, 189, 0.64);
  color: #fff0bd;
  display: block;
  font-size: 0.38rem;
  left: 50%;
  max-width: 86px;
  padding: 2px 4px;
  text-align: center;
  text-shadow: 1px 1px 0 rgba(41, 36, 28, 0.8);
  transform: translateX(-50%);
  white-space: nowrap;
}

.world-board .plot.locked:not(.owned) {
  opacity: 0;
}

.world-board .plot.expandable {
  opacity: 1;
}

.world-board .plot.expandable::after {
  border: 4px solid var(--ft-gold-lt);
  box-shadow: 0 0 0 2px rgba(92, 58, 30, 0.12);
  clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  inset: -6px;
  transform: rotate(0deg);
}

.world-board .plot .tile-icon {
  inset: -8px;
  z-index: 2;
}

.world-board .tile-sprite {
  background: radial-gradient(ellipse at 50% 78%, rgba(245, 200, 66, 0.13) 0 38%, transparent 39%);
  filter:
    drop-shadow(0 8px 0 rgba(35, 32, 28, 0.26))
    drop-shadow(2px 3px 0 rgba(253, 247, 192, 0.08));
  height: 94%;
  width: 94%;
}

.world-board .plot.mining .timer {
  left: 50%;
  min-width: 78px;
  right: auto;
  top: -18px;
  transform: translateX(-50%);
}

.world-board .plot.ready .timer {
  min-width: 82px;
}

.mission-popover {
  background: var(--ft-parchment);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 var(--ft-parchment-lt),
    5px 5px 0 var(--ft-brown-dk);
  bottom: auto;
  left: 14px;
  max-width: min(330px, calc(100vw - 28px));
  max-height: 270px;
  overflow: hidden;
  padding: 12px;
  top: 150px;
  width: 300px;
  display: block;
}

.world-node {
  align-items: center;
  background: transparent;
  border: 0;
  color: var(--ft-parchment-lt);
  cursor: pointer;
  display: grid;
  font-family: "Press Start 2P", monospace;
  isolation: isolate;
  justify-items: center;
  padding: 0;
  pointer-events: auto;
  position: absolute;
  transform: translate(-50%, -50%);
  min-height: 100px;
  width: 104px;
  z-index: 4;
}

.world-node.anchor-node {
  min-height: 116px;
  width: 124px;
  z-index: 5;
}

.world-node.field-node {
  min-height: 92px;
  width: 86px;
  z-index: 3;
}

.world-node.field-node.tiny {
  min-height: 74px;
  width: 70px;
}

.world-node.field-node.large {
  min-height: 120px;
  width: 118px;
}

.world-node::before {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(245, 200, 66, 0.16) 0 28%, transparent 29%),
    repeating-linear-gradient(90deg, rgba(35, 32, 28, 0.18) 0 6px, transparent 6px 18px),
    rgba(88, 88, 82, 0.38);
  border: 3px solid rgba(218, 207, 172, 0.2);
  box-shadow:
    inset 3px 3px 0 rgba(253, 247, 192, 0.06),
    inset -4px -4px 0 rgba(35, 32, 28, 0.18),
    6px 8px 0 rgba(35, 32, 28, 0.16);
  content: "";
  height: 34px;
  left: 50%;
  pointer-events: none;
  position: absolute;
  top: 42px;
  transform: translate(-50%, -50%) rotate(30deg) skewX(-18deg);
  width: 76px;
  z-index: 0;
}

.world-node.field-node::before {
  height: 28px;
  top: 34px;
  width: 64px;
}

.world-node.field-node.tiny::before {
  height: 22px;
  top: 27px;
  width: 52px;
}

.world-node.field-node.large::before {
  height: 38px;
  top: 48px;
  width: 88px;
}

.world-node[data-kind="debris"]::before {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(182, 77, 51, 0.18) 0 29%, transparent 30%),
    repeating-linear-gradient(90deg, rgba(35, 32, 28, 0.18) 0 6px, transparent 6px 18px),
    rgba(76, 72, 67, 0.38);
}

.world-node[data-kind="relay"]::before {
  background:
    radial-gradient(ellipse at 50% 50%, rgba(135, 198, 196, 0.18) 0 31%, transparent 32%),
    repeating-linear-gradient(90deg, rgba(35, 32, 28, 0.16) 0 6px, transparent 6px 18px),
    rgba(91, 91, 86, 0.4);
}

.world-node img {
  animation: node-bob 1.9s steps(3, end) infinite;
  background: radial-gradient(ellipse at 50% 78%, rgba(245, 200, 66, 0.13) 0 38%, transparent 39%);
  filter:
    drop-shadow(0 8px 0 rgba(35, 32, 28, 0.24))
    drop-shadow(0 0 10px rgba(245, 200, 66, 0.28));
  height: 58px;
  image-rendering: pixelated;
  object-fit: contain;
  position: relative;
  width: 58px;
  z-index: 2;
}

.world-node.field-node img {
  height: 54px;
  width: 54px;
}

.world-node.field-node.tiny img {
  height: 42px;
  width: 42px;
}

.world-node.field-node.large img {
  height: 74px;
  width: 74px;
}

.world-node-label {
  background: rgba(36, 24, 15, 0.9);
  border: 2px solid var(--ft-gold-lt);
  box-shadow: 3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-parchment-lt);
  font-size: 0.46rem;
  line-height: 1.4;
  margin-top: 3px;
  max-width: 132px;
  padding: 3px 5px;
  position: relative;
  text-align: center;
  text-shadow: 1px 1px 0 #1d130c;
  white-space: nowrap;
  z-index: 3;
}

.world-node.field-node .world-node-label {
  opacity: 0;
  position: absolute;
  top: 52px;
  transform: translateY(-4px);
  transition: opacity 120ms steps(2, end), transform 120ms steps(2, end);
}

.world-node.field-node.tiny .world-node-label {
  top: 42px;
}

.world-node.field-node.large .world-node-label {
  top: 68px;
}

.world-node.field-node:hover .world-node-label,
.world-node.field-node:focus-visible .world-node-label {
  opacity: 1;
  transform: translateY(0);
}

.world-node-range {
  border: 3px solid rgba(245, 200, 66, 0.5);
  height: 74px;
  left: 50%;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 30px;
  transform: translate(-50%, -50%) rotate(30deg) skewX(-18deg);
  transition: opacity 120ms steps(2, end);
  width: 92px;
  z-index: 1;
}

.world-node.field-node .world-node-range {
  height: 58px;
  top: 31px;
  width: 72px;
}

.world-node.field-node.tiny .world-node-range {
  height: 46px;
  top: 25px;
  width: 58px;
}

.world-node.field-node.large .world-node-range {
  height: 82px;
  top: 42px;
  width: 102px;
}

.world-node:hover .world-node-range,
.world-node:focus-visible .world-node-range {
  opacity: 1;
}

.world-node[data-kind="debris"] img {
  filter:
    drop-shadow(0 8px 0 rgba(35, 32, 28, 0.28))
    drop-shadow(0 0 10px rgba(255, 86, 54, 0.3));
}

.world-node[data-kind="relay"] img {
  filter:
    drop-shadow(0 8px 0 rgba(35, 32, 28, 0.24))
    drop-shadow(0 0 14px rgba(135, 198, 196, 0.38));
}

.world-node.recharging,
.world-node.collected {
  filter: grayscale(0.58);
  opacity: 0.66;
}

.world-node.recharging img {
  animation-duration: 2.8s;
  filter:
    drop-shadow(5px 8px 0 rgba(35, 32, 28, 0.22))
    drop-shadow(0 0 7px rgba(218, 207, 172, 0.2));
}

.world-node-cooldown {
  background: var(--ft-parchment);
  border: 2px solid var(--ft-brown);
  box-shadow: 2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.43rem;
  margin-top: 3px;
  padding: 2px 4px;
  position: relative;
  text-align: center;
  z-index: 3;
}

.world-menu {
  background: var(--ft-parchment);
  border: 4px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 var(--ft-parchment-lt),
    5px 5px 0 var(--ft-brown-dk);
  max-height: calc(100vh - 156px);
  overflow: auto;
  padding: 10px;
  right: 12px;
  top: 58px;
  width: 318px;
}

.menu-title-row {
  align-items: center;
  background: var(--ft-parchment);
  border-bottom: 3px solid var(--ft-brown);
  display: flex;
  justify-content: space-between;
  margin-bottom: 10px;
  padding-bottom: 8px;
  position: sticky;
  top: -10px;
  z-index: 4;
}

.menu-title-row strong {
  color: var(--ft-green-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.72rem;
  line-height: 1.5;
}

.menu-controls {
  display: flex;
  gap: 5px;
}

.menu-square {
  background: var(--ft-gold);
  border: 3px solid var(--ft-gold-dk);
  box-shadow: inset -2px -2px 0 var(--ft-gold-dk), inset 2px 2px 0 var(--ft-gold-lt), 2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.76rem;
  height: 44px;
  width: 44px;
}

.farm-menu-grid {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(3, 1fr);
}

.farm-menu-card {
  align-items: center;
  aspect-ratio: 1;
  background: linear-gradient(180deg, var(--ft-parchment-lt) 0%, #edbe67 100%);
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -3px -3px 0 var(--ft-brown-lt),
    inset 3px 3px 0 #fffde0,
    3px 3px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  cursor: pointer;
  display: grid;
  font-family: "Press Start 2P", monospace;
  font-size: 0.48rem;
  gap: 4px;
  justify-items: center;
  line-height: 1.35;
  padding: 8px 5px;
  position: relative;
  text-align: center;
}

.farm-menu-card img {
  height: 34px;
  image-rendering: pixelated;
  object-fit: contain;
  width: 34px;
}

.farm-menu-card em {
  background: var(--ft-gold-lt);
  color: var(--ft-parchment-lt);
  font-size: 0.45rem;
  font-style: normal;
  padding: 1px 5px;
  position: absolute;
  right: -2px;
  top: -2px;
}

.farm-menu-card.disabled {
  filter: grayscale(0.7);
  opacity: 0.62;
}

.farm-menu-card:active {
  transform: translate(2px, 2px);
}

.farm-overview {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 8px;
}

.farm-overview div {
  background: var(--ft-parchment-lt);
  border: 2px solid var(--ft-parchment-dk);
  box-shadow: inset -2px -2px 0 rgba(92, 58, 30, 0.16), inset 2px 2px 0 #fffde0;
  color: var(--ft-brown-dk);
  padding: 5px 7px;
}

.farm-overview span,
.farm-overview strong {
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.46rem;
  line-height: 1.45;
}

.farm-overview strong {
  color: var(--ft-green);
  margin-top: 1px;
}

.station-drawer {
  background: rgba(253, 247, 192, 0.95);
  border-top: 3px solid var(--ft-brown);
  display: none;
  margin-top: 9px;
  padding-top: 9px;
}

.station-drawer.open {
  display: block;
}

.world-menu .board-toolbar {
  margin-bottom: 10px;
}

.world-menu .store-card {
  grid-template-columns: 48px minmax(0, 1fr);
}

.world-menu .store-card button {
  grid-column: 1 / -1;
  white-space: normal;
  width: 100%;
}

.world-menu .contract-card,
.world-menu .job-card,
.world-menu .store-card {
  padding: 8px;
}

.world-menu .store-card p,
.world-menu .contract-card p,
.world-menu .job-card p,
.world-menu .store-card small,
.world-menu .contract-card small,
.world-menu .job-card small {
  font-size: 0.72rem;
}

.chain-card {
  background: var(--ft-parchment-lt);
  border: 3px solid var(--ft-brown);
  box-shadow:
    inset -2px -2px 0 var(--ft-parchment-dk),
    inset 2px 2px 0 #fffde0,
    3px 3px 0 rgba(43, 26, 13, 0.88);
  color: var(--ft-brown-dk);
  display: grid;
  gap: 8px;
  margin-bottom: 9px;
  padding: 9px;
}

.chain-card-head {
  align-items: start;
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.chain-card-head span,
.chain-mini-grid span,
.chain-card small,
.chain-card a {
  font-family: "Press Start 2P", monospace;
  font-size: 0.43rem;
  line-height: 1.55;
}

.chain-card-head span {
  color: var(--oxide-dark);
}

.chain-card-head strong {
  color: var(--ft-green);
  font-family: "Press Start 2P", monospace;
  font-size: 0.52rem;
  line-height: 1.5;
  text-align: right;
}

.chain-card p {
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.35;
  margin: 0;
}

.chain-address {
  background: rgba(135, 198, 196, 0.23);
  border: 2px solid rgba(49, 88, 58, 0.35);
  color: var(--ft-green-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 0.48rem;
  line-height: 1.6;
  overflow-wrap: anywhere;
  padding: 5px 7px;
}

.chain-mini-grid {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chain-mini-grid div {
  background: rgba(224, 202, 106, 0.28);
  border: 2px solid rgba(92, 58, 30, 0.22);
  min-width: 0;
  padding: 5px 6px;
}

.chain-mini-grid strong {
  color: var(--ft-green-dk);
  display: block;
  font-family: "Press Start 2P", monospace;
  font-size: 0.48rem;
  line-height: 1.55;
  margin-top: 2px;
  overflow-wrap: anywhere;
}

.chain-mini-grid a {
  color: var(--oxide-dark);
  display: inline-block;
  margin-top: 3px;
  text-decoration: none;
}

.chain-actions {
  display: grid;
  gap: 6px;
  grid-template-columns: 1fr;
}

.chain-card button,
.chain-actions button {
  background: var(--ft-gold);
  border: 3px solid var(--ft-gold-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  cursor: pointer;
  font-family: "Press Start 2P", monospace;
  font-size: 0.5rem;
  line-height: 1.45;
  min-height: 36px;
  padding: 7px 8px;
}

.chain-actions button:nth-child(2) {
  background: var(--ft-green);
  border-color: var(--ft-green-dk);
  box-shadow:
    inset -2px -2px 0 var(--ft-green-dk),
    inset 2px 2px 0 var(--ft-green-lt),
    2px 2px 0 var(--ft-brown-dk);
  color: var(--ft-parchment-lt);
}

.chain-actions button:nth-child(3) {
  background: var(--oxide);
  border-color: var(--oxide-dark);
  box-shadow:
    inset -2px -2px 0 var(--oxide-dark),
    inset 2px 2px 0 #df7b5b,
    2px 2px 0 var(--ft-brown-dk);
  color: #fff2c4;
}

.chain-error,
.chain-last {
  background: rgba(182, 77, 51, 0.12);
  border: 2px solid rgba(182, 77, 51, 0.3);
  color: var(--oxide-dark);
  padding: 5px 6px;
}

.chain-last {
  background: rgba(123, 201, 130, 0.16);
  border-color: rgba(42, 74, 36, 0.3);
  color: var(--ft-green-dk);
}

.world-hotbar {
  bottom: 16px;
  display: grid;
  gap: 6px;
  grid-template-columns: repeat(4, 72px);
  left: 50%;
  margin: 0;
  transform: translateX(-50%);
}

.world-hotbar .hotbar-button {
  min-height: 66px;
}

.rotate-control {
  background: var(--ft-gold);
  border: 4px solid var(--ft-brown);
  bottom: 28px;
  box-shadow:
    inset -2px -2px 0 var(--ft-gold-dk),
    inset 2px 2px 0 var(--ft-gold-lt),
    4px 4px 0 var(--ft-brown-dk);
  color: var(--ft-brown-dk);
  font-family: "Press Start 2P", monospace;
  font-size: 1.7rem;
  height: 54px;
  width: 54px;
}

.rotate-left {
  left: calc(50% - 218px);
}

.rotate-right {
  left: calc(50% + 166px);
}

.world-menu.collapsed {
  max-height: 52px;
  overflow: hidden;
  width: 64px;
}

.world-menu.collapsed .menu-title-row {
  border-bottom: 0;
  margin: 0;
  padding: 0;
}

.world-menu.collapsed .menu-title-row strong,
.world-menu.collapsed .farm-menu-grid,
.world-menu.collapsed .farm-overview,
.world-menu.collapsed .game-token-ca,
.world-menu.collapsed .station-drawer,
.world-menu.collapsed .board-toolbar,
.world-menu.collapsed .tabs,
.world-menu.collapsed .tab-panel {
  display: none;
}

@media (max-width: 1180px) {
  .topbar,
  .game-layout {
    grid-template-columns: 1fr;
  }

  .resource-bar {
    grid-template-columns: repeat(4, minmax(70px, 1fr)) auto auto;
  }

  .side-panel {
    order: 2;
  }

  .board-wrap {
    order: 1;
  }

  .economy-panel {
    order: 3;
  }

  .site-rigs {
    grid-template-columns: 1fr;
  }

  .loop-track,
  .rig-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .app-shell {
    padding: 8px;
  }

  .topbar {
    padding: 8px;
  }

  h1 {
    font-size: 1.45rem;
    line-height: 1;
  }

  .brand-mark {
    height: 44px;
    width: 44px;
  }

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

  .reset-button,
  .site-link-button {
    min-height: 38px;
  }

  .site-link-button {
    grid-column: 1 / 2;
  }

  .reset-button {
    grid-column: 2 / -1;
  }

  .game-layout {
    gap: 10px;
    margin-top: 10px;
  }

  .side-panel,
  .board-wrap {
    border-width: 3px;
  }

  .board-wrap {
    padding: 0 8px 10px;
  }

  .skyline {
    height: 64px;
    margin: 0 -8px 10px;
  }

  .module-sprite {
    width: 56px;
  }

  .module-right {
    width: 50px;
  }

  .moon-board {
    --board-gap: 3px;
    border-width: 3px;
    gap: var(--board-gap);
    padding: 5px;
    width: 100%;
  }

  .plot {
    border-width: 2px;
  }

  .plot .tile-label,
  .plot .timer {
    font-size: 0.62rem;
  }

  .hotbar {
    gap: 6px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .hotbar-button {
    min-height: 54px;
  }

  .hotbar-icon {
    font-size: 1.15rem;
  }

  .hotbar-button strong {
    font-size: 0.78rem;
  }

  .store-card {
    grid-template-columns: 40px minmax(0, 1fr);
  }

  .store-card button {
    grid-column: 1 / -1;
    width: 100%;
  }

  .site-nav {
    gap: 8px;
    grid-template-columns: 1fr auto;
    min-height: 64px;
    padding: 7px 10px;
  }

  .site-brand img {
    height: 42px;
    width: 42px;
  }

  .site-brand span {
    font-size: 0.68rem;
  }

  .nav-wallet {
    display: none;
  }

  .site-links {
    display: none;
  }

  .nav-action {
    font-size: 0.52rem;
    min-height: 40px;
    padding: 8px 10px;
  }

  .site-hero {
    align-content: end;
    min-height: min(680px, calc(100svh - 70px));
    padding: 58px 14px 20px;
  }

  .site-hero h1 {
    font-size: clamp(1.58rem, 10.5vw, 2.4rem);
    text-shadow:
      3px 3px 0 var(--ft-gold-lt),
      6px 6px 0 var(--ft-brown-dk),
      -2px -2px 0 var(--ft-parchment-lt),
      2px -2px 0 var(--ft-parchment-lt),
      -2px 2px 0 var(--ft-parchment-lt);
    overflow-wrap: anywhere;
  }

  .hero-copy {
    font-size: 0.98rem;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hero-actions .pixel-action {
    max-width: 100%;
    white-space: normal;
    width: 100%;
  }

  .token-ca-panel {
    grid-template-columns: 1fr;
  }

  .token-ca-panel button {
    width: 100%;
  }

  .token-ca-panel code {
    font-size: 0.43rem;
    white-space: normal;
    word-break: break-all;
  }

  .hero-stats {
    grid-template-columns: 1fr;
    justify-self: stretch;
    margin-top: 22px;
  }

  .hero-orbit-layer,
  .cloud-b,
  .cloud-c,
  .signal-b,
  .scene-ice,
  .scene-quartz {
    display: none;
  }

  .scene-module {
    bottom: 23%;
    right: 3%;
    width: 82px;
  }

  .scene-antenna {
    bottom: 33%;
    right: 13%;
    width: 56px;
  }

  .scene-drill {
    bottom: 24%;
    left: 58%;
    width: 54px;
  }

  .scene-rover {
    bottom: 20%;
    width: 58px;
  }

  .cloud-a {
    opacity: 0.54;
    top: 12%;
    transform: scale(0.68);
  }

  .site-band {
    padding: 44px 12px;
  }

  .section-heading h2 {
    font-size: 1.15rem;
  }

  .loop-track,
  .rig-grid,
  .roadmap-lanes {
    grid-template-columns: 1fr;
  }

  .loop-step,
  .rig-grid article,
  .roadmap-lanes article {
    padding: 14px;
  }

  .loop-step {
    display: grid;
    grid-template-columns: 78px minmax(0, 1fr);
    column-gap: 12px;
    align-items: center;
  }

  .loop-step img {
    grid-row: span 2;
    height: 72px;
    width: 72px;
  }

  .loop-step h3 {
    margin-top: 0;
  }

  .site-footer {
    align-items: flex-start;
    flex-direction: column;
    padding: 20px 14px;
  }
}

@media (max-width: 900px) {
  .world-shell {
    min-height: 100svh;
  }

  .world-resource-bar {
    left: 74px;
    min-width: 0;
    right: 88px;
    top: 10px;
    transform: none;
  }

  .world-resource-bar .resource {
    min-width: 0;
    padding: 5px 6px;
  }

  .world-resource-bar .resource span {
    font-size: 0.42rem;
  }

  .world-resource-bar .resource strong {
    font-size: 0.66rem;
  }

  .world-actions {
    right: 10px;
    top: 10px;
  }

  .world-wallet-chip,
  .wallet-disconnect {
    display: none;
  }

  .world-tip {
    display: none;
  }

  .world-actions .site-link-button,
  .world-actions .reset-button {
    font-size: 0.48rem;
    min-height: 44px;
    min-width: 58px;
    padding: 0 8px;
  }

  .world-menu {
    max-height: 38svh;
    padding: 8px;
    right: 8px;
    top: 86px;
    width: min(286px, calc(100vw - 16px));
  }

  .farm-menu-grid {
    gap: 4px;
  }

  .farm-menu-card {
    font-size: 0.42rem;
  }

	  .station-drawer {
	    max-height: 30svh;
	    overflow: auto;
	  }

	  .world-menu[data-active-tab="chain"] {
	    max-height: 58svh;
	  }

	  .world-menu[data-active-tab="chain"] .station-drawer {
	    max-height: 46svh;
	  }

	  .world-menu[data-active-tab="chain"] .board-toolbar {
	    display: none;
	  }

  .menu-title-row {
    top: -8px;
  }

  .chain-mini-grid {
    grid-template-columns: 1fr;
  }

  .chain-card-head {
    display: grid;
    justify-content: stretch;
  }

  .chain-card-head strong {
    text-align: left;
  }

  .mission-popover {
    bottom: 96px;
    display: none;
  }

  .world-board {
    --tile-size: clamp(38px, 10vw, 52px);
    border-width: 0;
    gap: 4px;
    left: 1600px;
    padding: 0;
    top: 1120px;
    width: max-content;
  }

  .player-character {
    left: var(--player-world-x);
    top: var(--player-world-y);
  }

  .npc-character {
    left: var(--npc-world-x);
    top: var(--npc-world-y);
  }

  .world-hotbar {
    bottom: 14px;
    grid-template-columns: repeat(4, minmax(58px, 1fr));
    width: min(300px, calc(100vw - 128px));
  }

  .world-hotbar .hotbar-button {
    min-height: 58px;
  }

  .world-hotbar .hotbar-button strong {
    font-size: 0.55rem;
  }

  .rotate-control {
    bottom: 20px;
    height: 50px;
    width: 50px;
  }

  .rotate-left {
    left: 8px;
  }

  .rotate-right {
    left: auto;
    right: 8px;
  }

  .toast-stack {
    bottom: 100px;
    left: 12px;
    right: 12px;
    width: auto;
  }

  .canvas-status {
    display: none;
  }

  .mini-map {
    left: 8px;
    top: 76px;
    width: 128px;
  }

  .mini-map-field {
    height: 76px;
  }

  .camera-controls {
    grid-template-columns: repeat(3, 44px);
    left: 8px;
    top: 178px;
  }

  .camera-controls button {
    height: 44px;
    width: 44px;
  }

  .prop-module {
    width: 96px;
  }

  .prop-antenna,
  .prop-ice,
  .prop-quartz,
  .prop-storage {
    width: 64px;
  }
}

@media (max-width: 520px) {
  .profile-button {
    height: 48px;
    width: 48px;
  }

  .profile-button img {
    height: 38px;
    width: 38px;
  }

  .world-resource-bar {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    left: 66px;
    right: 76px;
  }

  .world-menu {
    top: 142px;
    width: min(270px, calc(100vw - 118px));
  }

  .world-menu.collapsed {
    top: 82px;
  }

  .mini-map {
    top: 146px;
  }

  .camera-controls {
    top: 280px;
  }

  .world-board {
    left: 1600px;
    top: 1120px;
  }

  .world-character img {
    height: 48px;
    width: 48px;
  }

  .nameplate {
    font-size: 0.45rem;
    top: -26px;
  }

  .quest-mark {
    font-size: 1.7rem;
    top: -58px;
  }
}

@keyframes prop-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}

@keyframes node-bob {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

@keyframes dust-drift {
  0% {
    transform: translate(0, 0) rotate(-28deg);
    opacity: 0.45;
  }
  50% {
    transform: translate(16px, -10px) rotate(-28deg);
    opacity: 0.95;
  }
  100% {
    transform: translate(28px, -20px) rotate(-28deg);
    opacity: 0.2;
  }
}

@keyframes rover-walk {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-3px);
  }
}

@keyframes npc-idle {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

@keyframes hero-bg-drift {
  0%,
  100% {
    transform: scale(1.04) translate3d(0, 0, 0);
  }
  50% {
    transform: scale(1.04) translate3d(-14px, 8px, 0);
  }
}

@keyframes hero-scan {
  0%,
  100% {
    opacity: 0.54;
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0.82;
    transform: translate3d(0, 12px, 0);
  }
}

@keyframes lunar-haze {
  0%,
  100% {
    opacity: 0.72;
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0.92;
    transform: translate3d(0, -8px, 0);
  }
}

@keyframes orbit-slide-a {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(-18deg);
  }
  50% {
    transform: translate3d(-34px, 16px, 0) rotate(-18deg);
  }
}

@keyframes orbit-slide-b {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(16deg);
  }
  50% {
    transform: translate3d(42px, -12px, 0) rotate(16deg);
  }
}

@keyframes cloud-drift-a {
  0% {
    transform: translate3d(-20px, 0, 0);
  }
  100% {
    transform: translate3d(calc(100vw + 260px), 0, 0);
  }
}

@keyframes cloud-drift-b {
  0% {
    transform: translate3d(120px, 0, 0) scale(0.72);
  }
  100% {
    transform: translate3d(calc(-100vw - 320px), 0, 0) scale(0.72);
  }
}

@keyframes cloud-drift-c {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(0.58);
  }
  50% {
    transform: translate3d(-120px, 12px, 0) scale(0.58);
  }
}

@keyframes hero-machine-idle {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -5px, 0);
  }
}

@keyframes drill-pulse {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(-2deg);
    filter: drop-shadow(8px 11px 0 rgba(61, 32, 16, 0.28));
  }
  50% {
    transform: translate3d(0, 5px, 0) rotate(2deg);
    filter: drop-shadow(8px 8px 0 rgba(61, 32, 16, 0.22)) brightness(1.08);
  }
}

@keyframes hero-rover-route {
  0% {
    transform: translate3d(-12vw, 0, 0) scaleX(-1);
  }
  42% {
    transform: translate3d(34vw, -12px, 0) scaleX(-1);
  }
  50% {
    transform: translate3d(34vw, -12px, 0) scaleX(1);
  }
  92% {
    transform: translate3d(-8vw, 5px, 0) scaleX(1);
  }
  100% {
    transform: translate3d(-12vw, 0, 0) scaleX(-1);
  }
}

@keyframes mineral-twinkle {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.82;
  }
  50% {
    transform: translate3d(0, -7px, 0) scale(1.08);
    opacity: 1;
  }
}

@keyframes signal-pulse {
  0% {
    opacity: 0;
    transform: scale(0.52);
  }
  35% {
    opacity: 0.95;
  }
  100% {
    opacity: 0;
    transform: scale(1.18);
  }
}

@keyframes hero-dust-run {
  0% {
    opacity: 0;
    transform: translate3d(0, 0, 0) rotate(-20deg);
  }
  35% {
    opacity: 0.9;
  }
  100% {
    opacity: 0;
    transform: translate3d(52px, -22px, 0) rotate(-20deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }
}
