@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&display=swap");

:root {
  --bg: #160f0c;
  --panel: #241c16;
  --panel-2: #2e241b;
  --red: #b5302a;
  --red-bright: #e74c3c;
  --gold: #e0ad2b;
  --gold-dim: #b88a1e;
  --text: #f6eedd;
  --muted: #a2937c;
  --line: #4a3a28;
  --display: "Oswald", "Segoe UI", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: "Segoe UI", system-ui, sans-serif;
  color: var(--text);
  height: 100vh;
  overflow: hidden;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(181,48,42,.28), transparent 55%),
    radial-gradient(100% 80% at 50% 120%, rgba(224,173,43,.10), transparent 60%),
    radial-gradient(circle at 50% 35%, #34281b, var(--bg));
}

.screen {
  display: none;
  position: absolute; inset: 0;
  align-items: center; justify-content: center; flex-direction: column;
}
.screen.active { display: flex; }

/* ---------- panels (home) ---------- */
.panel {
  position: relative;
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 34px 36px 32px;
  width: 370px; max-width: 92vw;
  text-align: center;
  box-shadow: 0 24px 70px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.04);
}
.panel::before {           /* gold accent bar at the top */
  content: ""; position: absolute; left: 22px; right: 22px; top: 0; height: 3px;
  border-radius: 0 0 3px 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}

.brand {
  font-family: var(--display); font-weight: 500;
  font-size: 22px; letter-spacing: 6px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 2px;
}
h1 {
  font-family: var(--display); font-weight: 700;
  font-size: 52px; line-height: 1; letter-spacing: 2px;
  text-transform: uppercase; margin-bottom: 10px;
  text-shadow: 0 2px 14px rgba(0,0,0,.5);
}
.controls-hint {
  margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.07);
  color: var(--muted); font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
}
h2 { font-family: var(--display); font-weight: 600; letter-spacing: 1px; margin-bottom: 10px; text-transform: uppercase; }
.red { color: var(--red-bright); text-shadow: 0 0 18px rgba(231,76,60,.45); }
.tag { color: var(--muted); font-size: 13px; margin: 8px 0 16px; line-height: 1.5; }

input {
  width: 100%; padding: 13px 14px; margin: 8px 0;
  border-radius: 10px; border: 1px solid var(--line);
  background: #18120e; color: var(--text); font-size: 16px; text-align: center;
  transition: border-color .15s, box-shadow .15s;
}
input::placeholder { color: #6f6354; }
input:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(224,173,43,.18); }
#codeInput { text-transform: uppercase; letter-spacing: 6px; font-weight: 700; }

button {
  cursor: pointer; border: none; border-radius: 10px;
  padding: 12px 18px; font-size: 15px; font-weight: 600;
  background: #574536; color: var(--text);
  transition: transform .08s ease, background .15s, box-shadow .15s, filter .15s;
}
button:hover { background: #6b5440; }
button:active { transform: translateY(1px) scale(.99); }
button:disabled { opacity: .4; cursor: not-allowed; filter: grayscale(.3); }

.big {
  width: 100%; margin-top: 12px;
  font-family: var(--display); font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.5px;
  font-size: 17px; padding: 14px;
  color: #fff;
  background: linear-gradient(180deg, var(--red-bright), var(--red));
  box-shadow: 0 6px 18px rgba(181,48,42,.4), inset 0 1px 0 rgba(255,255,255,.15);
}
.big:hover:not(:disabled) { filter: brightness(1.08); box-shadow: 0 8px 22px rgba(181,48,42,.55); }

.or { color: var(--muted); margin: 16px 0; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; }
.joinrow { display: flex; gap: 8px; }
.joinrow input { margin: 0; }
.joinrow button { white-space: nowrap; }
.error { color: var(--red-bright); font-size: 13px; min-height: 18px; margin-top: 10px; }

.code {
  font-family: var(--display);
  font-size: 48px; font-weight: 700; letter-spacing: 10px;
  color: var(--gold); background: #18120e; border-radius: 10px; padding: 12px; margin: 4px 0;
}

.players { list-style: none; margin: 14px 0; text-align: left; }
.players li {
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.06);
  border-left: 3px solid var(--gold-dim);
  border-radius: 8px; padding: 9px 13px; margin: 6px 0;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 14px;
}
.players .host {
  color: #1a130c; background: var(--gold); font-size: 10px; font-weight: 800;
  letter-spacing: 1px; padding: 2px 7px; border-radius: 20px;
}

/* ---------- wheel ---------- */
#wheelScreen { gap: 18px; }
#wheelTitle { font-family: var(--display); font-size: 30px; letter-spacing: 1px; text-transform: uppercase; }
#wheel { filter: drop-shadow(0 12px 34px rgba(0,0,0,.65)); }

/* ---------- game scene ---------- */
#scene { position: absolute; inset: 0; }
#scene canvas { display: block; }
#crosshair {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  color: rgba(255,255,255,.85); font-size: 22px; font-weight: 700;
  pointer-events: none; text-shadow: 0 0 6px rgba(0,0,0,.9);
}

/* glassy HUD chip shared look */
.chip, .role, .timer, .alive, #lobbyCode, #muteBtn {
  background: rgba(20,14,10,.55);
  border: 1px solid rgba(255,255,255,.08);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}

#hud {
  position: absolute; top: 0; left: 0; right: 0;
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 16px 20px; pointer-events: none;
}
.role { font-size: 16px; font-weight: 700; padding: 8px 16px; border-radius: 10px; }
.role.stalin { color: #fff; background: linear-gradient(180deg, var(--red-bright), var(--red)); border-color: rgba(231,76,60,.5); }
.role.runner { color: #1a130c; background: linear-gradient(180deg, #f0c14b, var(--gold)); border-color: rgba(224,173,43,.5); }
.timer {
  font-family: var(--display); font-weight: 700;
  font-size: 42px; line-height: 1; padding: 8px 20px; border-radius: 12px;
  font-variant-numeric: tabular-nums; color: var(--text);
}
.timer.low { color: var(--red-bright); animation: pulse .8s ease-in-out infinite; }
@keyframes pulse { 50% { opacity: .55; } }
.alive { font-size: 14px; text-align: right; padding: 8px 14px; border-radius: 10px; }

/* ---------- overlays ---------- */
.bigoverlay {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 16px; text-align: center;
  background: rgba(0,0,0,.5);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
}
.bigoverlay.hidden { display: none; }
#countdownOverlay {
  font-family: var(--display); font-size: 130px; font-weight: 700; color: var(--gold);
  background: rgba(0,0,0,.25); text-shadow: 0 0 40px rgba(224,173,43,.5);
}
#goText { font-family: var(--display); font-size: 50px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
#goText.stalin { color: var(--red-bright); text-shadow: 0 0 30px rgba(231,76,60,.5); }
#goText.runners { color: var(--gold); text-shadow: 0 0 30px rgba(224,173,43,.5); }
#againBtn { width: 240px; }
#againBtn.hidden { display: none; }

.lockbox {
  background: linear-gradient(180deg, rgba(46,36,27,.95), rgba(36,28,22,.95));
  border: 1px solid var(--line);
  padding: 30px 40px; border-radius: 16px; text-align: center;
  box-shadow: 0 24px 70px rgba(0,0,0,.6);
}

.mobilehint {
  position: absolute; bottom: 14px; left: 0; right: 0;
  text-align: center; color: var(--muted); font-size: 13px; pointer-events: none;
  text-shadow: 0 1px 4px rgba(0,0,0,.8);
}
.mobilehint b { color: var(--gold); }

/* ---------- lobby HUD ---------- */
#lobbyHud { position: absolute; inset: 0; pointer-events: none; }
#lobbyHud.hidden { display: none; }
#lobbyCode {
  position: absolute; top: 18px; left: 50%; transform: translateX(-50%);
  padding: 9px 24px; border-radius: 12px;
  font-family: var(--display); font-size: 20px; letter-spacing: 2px; text-transform: uppercase;
}
#lobbyCodeVal { color: var(--gold); font-weight: 700; letter-spacing: 7px; margin-left: 10px; }
#lobbyHud .players {
  position: absolute; top: 74px; right: 18px; width: 210px;
  background: rgba(20,14,10,.5); border: 1px solid rgba(255,255,255,.08);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border-radius: 12px; padding: 8px 10px; margin: 0;
}
#lobbyBottom {
  position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%);
  width: 320px; max-width: 90vw; text-align: center; pointer-events: auto;
}
#lobbyBottom .big { margin-top: 0; }
#lobbyHint { margin-top: 10px; }

#muteBtn {
  position: absolute; bottom: 16px; right: 16px;
  width: 44px; height: 44px; font-size: 20px; padding: 0;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  pointer-events: auto; z-index: 5;
}
#muteBtn:hover { background: rgba(40,28,20,.7); }

#radar {
  position: absolute; bottom: 16px; left: 16px;
  border-radius: 10px; border: 1px solid rgba(224,173,43,.45);
  background: rgba(10,8,6,.5);
  box-shadow: 0 6px 18px rgba(0,0,0,.45), 0 0 0 1px rgba(0,0,0,.3);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  pointer-events: none; z-index: 4;
}
#radar.hidden { display: none; }
#playHint.hidden { display: none; }
#specHint.hidden { display: none; }
#specHint b { color: var(--gold); }

#ghostHud {
  position: absolute; bottom: 56px; left: 50%; transform: translateX(-50%);
  width: 360px; max-width: 90vw; text-align: center; pointer-events: none;
}
#ghostHud.hidden { display: none; }
#ghostMsg { font-family: var(--display); font-size: 18px; letter-spacing: .5px; text-shadow: 0 1px 4px rgba(0,0,0,.9); }
#ghostMsg.guarded { color: var(--red-bright); }
#ghostMsg.holding { color: #6fe3ff; }
#reviveBarWrap {
  height: 12px; margin: 8px auto 6px; width: 280px; max-width: 80vw;
  background: rgba(0,0,0,.5); border: 1px solid rgba(255,255,255,.15); border-radius: 7px; overflow: hidden;
}
#reviveBar { height: 100%; width: 0%; background: linear-gradient(90deg, #4fd0ff, #6fffd0); transition: width .08s linear; }
#ghostSub { color: var(--muted); font-size: 12px; letter-spacing: 1px; text-transform: uppercase; }

/* ---------- pause ---------- */
#pauseTitle { font-family: var(--display); font-size: 46px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 6px; }
#pauseOverlay .lockbox { display: flex; flex-direction: column; align-items: center; gap: 4px; }
#pauseOverlay .big { width: 240px; margin-top: 16px; }
button.ghost { background: transparent; color: var(--muted); margin-top: 8px; box-shadow: none; -webkit-backdrop-filter: none; backdrop-filter: none; border: none; }
button.ghost:hover { background: rgba(255,255,255,.06); color: var(--text); }
