:root {
  /* Gloom palette — the three ghost types drive the whole color system */
  --red:    #ff3b5c;
  --yellow: #ffc23b;
  --blue:   #3bb6ff;

  --bg:        #07090f;
  --bg-soft:   #0d111c;
  --panel:     #121829;
  --panel-2:   #1a2238;
  --line:      #283250;
  --text:      #e8edff;
  --text-dim:  #8d9bc4;
  --gloom:     #7CFFB2;     /* pickup currency green (studs) */
  --danger:    #ff3b5c;

  --rad: 14px;
  --shadow: 0 10px 40px rgba(0,0,0,.55);
  --mono: ui-monospace, "SF Mono", "Cascadia Code", Menlo, Consolas, monospace;
  --display: "Bahnschrift", "DIN Alternate", "Oswald", system-ui, sans-serif;
  --body: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: radial-gradient(120% 80% at 50% -10%, #11182c 0%, var(--bg) 60%);
  color: var(--text);
  font-family: var(--body);
  -webkit-font-smoothing: antialiased;
  overscroll-behavior: none;
}

h1, h2, h3, .display {
  font-family: var(--display);
  letter-spacing: .04em;
  text-transform: uppercase;
  font-weight: 700;
}

a { color: var(--blue); }

button {
  font-family: var(--display);
  letter-spacing: .06em;
  text-transform: uppercase;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  transition: transform .08s ease, border-color .15s, background .15s;
}
button:hover { border-color: var(--blue); }
button:active { transform: translateY(1px); }
button:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }
button.primary { background: var(--blue); color: #04121f; border-color: transparent; font-weight: 700; }
button.danger { border-color: var(--danger); color: var(--danger); background: transparent; }

input, select, textarea {
  font-family: var(--body);
  background: var(--bg-soft);
  border: 1px solid var(--line);
  color: var(--text);
  border-radius: 8px;
  padding: 9px 11px;
  width: 100%;
}
input:focus, select:focus, textarea:focus { outline: 2px solid var(--blue); outline-offset: 1px; }
label { font-size: 12px; color: var(--text-dim); display: block; margin-bottom: 4px; letter-spacing: .03em; }

.type-red    { color: var(--red); }
.type-yellow { color: var(--yellow); }
.type-blue   { color: var(--blue); }
.dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; vertical-align: middle; }
.dot.red    { background: var(--red); box-shadow: 0 0 8px var(--red); }
.dot.yellow { background: var(--yellow); box-shadow: 0 0 8px var(--yellow); }
.dot.blue   { background: var(--blue); box-shadow: 0 0 8px var(--blue); }

.stars { color: var(--yellow); letter-spacing: 2px; font-size: 13px; }

.disclaimer {
  font-size: 11px; color: var(--text-dim); line-height: 1.5;
  border-top: 1px solid var(--line); padding: 14px 18px; text-align: center;
}

.hidden { display: none !important; }
.muted { color: var(--text-dim); }
.mono { font-family: var(--mono); }
