* { box-sizing: border-box; margin: 0; -webkit-tap-highlight-color: transparent; }
:root {
  --bg:#14141c; --panel:#1f1f2b; --panel2:#2a2a3a; --ink:#f2eee2; --dim:#9a96a8;
  --gold:#f0c75e; --red:#c0392b; --blue:#6b74b8; --green:#2e7d4f; --purple:#8a5fc7;
}
html,body { height:100%; }
body { background:var(--bg); color:var(--ink); font:16px/1.4 system-ui,-apple-system,sans-serif; }
#app { max-width:520px; margin:0 auto; min-height:100%; display:flex; flex-direction:column; padding:env(safe-area-inset-top) 12px calc(env(safe-area-inset-bottom) + 12px); }
button { font:inherit; border:none; border-radius:12px; padding:13px 18px; background:var(--gold); color:#1a1408; font-weight:700; cursor:pointer; }
button:active { transform:scale(.97); }
button.secondary { background:var(--panel2); color:var(--ink); }
button.danger { background:var(--red); color:#fff; }
button.ghost { background:transparent; color:var(--dim); }
button:disabled { opacity:.4; }
input { font:inherit; border:none; border-radius:12px; padding:13px; background:var(--panel2); color:var(--ink); width:100%; }
input::placeholder { color:var(--dim); }
.stack { display:flex; flex-direction:column; gap:12px; }
.row { display:flex; gap:8px; align-items:center; }
.grow { flex:1; }

/* home */
.home { justify-content:center; flex:1; text-align:center; }
.logo { font-size:46px; font-weight:900; letter-spacing:1px; color:var(--gold); text-shadow:3px 3px 0 #000; }
.tagline { color:var(--dim); margin-bottom:18px; }
.hero { width:150px; margin:0 auto 8px; border-radius:10px; box-shadow:0 8px 30px rgba(0,0,0,.5); }

/* lobby */
.codebox { background:var(--panel); border-radius:16px; padding:18px; text-align:center; }
.codebox .code { font-size:42px; font-weight:900; letter-spacing:10px; color:var(--gold); }
.players { background:var(--panel); border-radius:16px; padding:8px; }
.prow { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:10px; }
.prow + .prow { border-top:1px solid #ffffff10; }
.dot { width:10px; height:10px; border-radius:50%; background:var(--green); }

/* game */
.hud { display:flex; gap:6px; overflow-x:auto; padding:8px 0; }
.chip { background:var(--panel); border-radius:12px; padding:6px 10px; font-size:12.5px; white-space:nowrap; flex-shrink:0; border:2px solid transparent; }
.chip.you { border-color:var(--gold); }
.chip.dead { opacity:.45; }
.chip .nm { font-weight:700; }
.chip .st { color:var(--dim); }
.banner { border-radius:12px; padding:10px 14px; font-weight:700; text-align:center; }
.banner.alert { background:var(--red); color:#fff; animation:pulse 1.2s infinite; }
.banner.info { background:var(--panel2); }
.banner.gold { background:var(--gold); color:#1a1408; }
@keyframes pulse { 50% { opacity:.75; } }
.log { background:var(--panel); border-radius:12px; padding:10px 14px; font-size:13.5px; color:var(--dim); flex:1; overflow-y:auto; min-height:56px; display:flex; flex-direction:column-reverse; }
.log b { color:var(--ink); }
.hand { display:flex; flex-wrap:wrap; gap:8px; overflow-y:auto; padding:10px 2px; max-height:312px; flex-shrink:0; }
.hand img { width:100px; border-radius:8px; flex-shrink:0; box-shadow:0 3px 10px rgba(0,0,0,.4); }
.hand img.unplayable { filter:grayscale(.8) brightness(.6); }
.actions { display:flex; gap:8px; }
.actions button { flex:1; padding:11px 6px; font-size:13.5px; }
.actions button.on { outline:3px solid var(--gold); }

/* overlay */
.overlay { position:fixed; inset:0; background:#000000cc; display:flex; align-items:center; justify-content:center; z-index:10; padding:20px; }
.sheet { background:var(--panel); border-radius:20px; padding:20px; width:100%; max-width:430px; max-height:86vh; overflow-y:auto; }
.sheet h2 { margin-bottom:10px; font-size:20px; }
.sheet .big { width:150px; margin:0 auto 12px; display:block; border-radius:10px; }
.grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.grid3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }
.grid3 img { width:100%; border-radius:8px; }
.tally { width:100%; border-collapse:collapse; }
.tally td, .tally th { padding:9px 6px; text-align:left; border-bottom:1px solid #ffffff12; }
.tally .pos { color:var(--gold); } .tally .neg { color:#e07a6f; }
.win { text-align:center; padding:30px 0; }
.win .trophy { font-size:60px; }
.muted { color:var(--dim); font-size:13px; }
.center { text-align:center; }

.cdoverlay { background:#00000088; backdrop-filter:blur(2px); }
.countdown { font-size:120px; font-weight:900; color:var(--gold); text-shadow:4px 4px 0 #000; animation:cdpulse 1s infinite; }
@keyframes cdpulse { 0% { transform:scale(1); } 50% { transform:scale(1.15); } 100% { transform:scale(1); } }

.countdown.word { font-size:54px; letter-spacing:3px; animation:cdpulse .5s infinite; }
.herowide { width:min(84vw, 360px); margin-bottom:14px; }

.waitroom { position:relative; border-radius:14px; overflow:hidden; box-shadow:0 6px 24px rgba(0,0,0,.45); }
.waitroom img { width:100%; display:block; }
.waitroom .boarding { position:absolute; left:0; right:0; bottom:0; padding:10px; text-align:center; font-weight:800; font-size:18px; color:var(--gold); background:linear-gradient(transparent, #04255Cee); text-shadow:1px 1px 0 #000; }

/* ============ fun layer + avatars ============ */

/* avatars: a circle that shows the emoji fallback, with art on top when it loads */
.av { position:relative; display:inline-flex; align-items:center; justify-content:center; vertical-align:middle;
  border-radius:50%; background:var(--panel2); overflow:hidden; flex-shrink:0; line-height:1; }
.av img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.av .avfb { position:relative; }

/* lobby player rows now lead with an avatar */
.prow .av { margin-right:2px; }

/* choose-your-skyjacker grid */
.avgrid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.avpick { background:var(--panel); border:2px solid transparent; border-radius:14px; padding:8px 4px;
  display:flex; flex-direction:column; align-items:center; gap:5px; color:var(--ink); }
.avpick .avname { font-size:10.5px; line-height:1.1; text-align:center; color:var(--dim); }
.avpick.mine { border-color:var(--gold); }
.avpick.mine .avname { color:var(--gold); }
.avpick.taken { opacity:.4; }

/* in-game chip avatar */
.chiptop { display:flex; align-items:center; gap:5px; }

/* emote bar */
.emotebar { display:flex; gap:6px; overflow-x:auto; padding:2px 0; }
.emotebar button { background:var(--panel2); border-radius:12px; padding:8px 10px; font-size:20px; line-height:1; flex-shrink:0; }
.emotebar button:active { background:var(--gold); }

/* gameOver stats */
.champ { display:flex; justify-content:center; margin:-6px 0 2px; }
.statboard th { color:var(--dim); font-weight:700; font-size:13px; }
.statboard .trow { display:flex; align-items:center; gap:7px; }
.statboard .merow td { background:#f0c75e14; }

/* sound toggle */
#sj-sound { position:fixed; top:calc(env(safe-area-inset-top) + 6px); left:8px; z-index:200;
  width:38px; height:38px; padding:0; border-radius:50%; background:#1f1f2bcc; color:var(--ink); font-size:16px; }

/* killfeed */
#sj-feed { position:fixed; top:56px; right:10px; left:10px; z-index:190; pointer-events:none; display:flex; flex-direction:column; max-width:520px; margin:0 auto; }
.sj-kf { margin-left:auto; max-width:92%; width:max-content; background:#12121ceb; border:1px solid #ffffff1a; border-left:4px solid var(--dim);
  border-radius:10px; padding:7px 11px; font-size:13.5px; margin-bottom:6px; box-shadow:0 6px 18px rgba(0,0,0,.45); color:var(--ink);
  animation:sjKfIn .35s cubic-bezier(.2,1.3,.5,1) both; }
.sj-kf.dim { animation:sjKfOut .5s forwards; }
.sj-kf b { font-weight:800; }
.sj-kf.kill { border-left-color:var(--red); }
.sj-kf.gold { border-left-color:var(--gold); }
.sj-kf.escape { border-left-color:var(--blue); }
.sj-kf.chaos { border-left-color:var(--purple); }
.sj-kf.emote { border-left-color:#ffffff44; }
@keyframes sjKfIn { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:none; } }
@keyframes sjKfOut { to { opacity:0; transform:translateX(20px); } }

/* screen shake + bomb whiteout */
@keyframes sjShake { 10%,90%{transform:translate(-1px,1px);} 20%,80%{transform:translate(2px,-2px);} 30%,50%,70%{transform:translate(-4px,2px);} 40%,60%{transform:translate(4px,-1px);} }
@keyframes sjShake2 { 10%,90%{transform:translate(-2px,2px);} 20%,80%{transform:translate(5px,-3px);} 30%,50%,70%{transform:translate(-7px,3px);} 40%,60%{transform:translate(7px,-2px);} }
.sj-shake { animation:sjShake .45s; }
.sj-shake2 { animation:sjShake2 .55s; }
#sj-flash { position:fixed; inset:0; background:#fff; opacity:0; pointer-events:none; z-index:195; }
#sj-flash.go { animation:sjWf .45s; }
@keyframes sjWf { 0%{opacity:.9;} 100%{opacity:0;} }

/* DANGER MODE — red pulse behind the response overlay when a shot targets YOU */
body.sj-danger::before { content:""; position:fixed; inset:0; z-index:9; pointer-events:none;
  background:radial-gradient(120% 120% at 50% 50%, rgba(192,57,43,0) 38%, rgba(192,57,43,.6) 100%);
  animation:sjDanger 1.05s infinite; }
@keyframes sjDanger { 0%,100%{opacity:.35;} 50%{opacity:.95;} }
body.sj-danger .sheet h2 { color:#ff6b5e; text-shadow:0 0 18px rgba(192,57,43,.6); }

/* end-of-game awards */
.awards { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:2px 0 4px; }
.award { background:var(--panel); border:1px solid #ffffff14; border-radius:14px; padding:9px 11px; text-align:center; min-width:88px; }
.award .awicon { font-size:22px; line-height:1; }
.award .awtitle { font-weight:800; font-size:11px; color:var(--gold); text-transform:uppercase; letter-spacing:.03em; margin-top:2px; }
.award .awwinner { font-size:12.5px; margin-top:3px; display:inline-flex; align-items:center; gap:5px; }
.award .awsub { font-size:10.5px; color:var(--dim); margin-top:1px; }

/* looping background videos */
.waitroom video { width:100%; display:block; }

/* ===== table view ===== */
.table { position:relative; flex:1; min-height:330px; margin:8px 0; border-radius:18px; overflow:hidden;
  background:radial-gradient(120% 95% at 50% 36%, #20304e 0%, #0e1626 72%); border:2px solid #2a3450;
  box-shadow:inset 0 0 70px rgba(0,0,0,.6); }
.tseat { position:absolute; transform:translate(-50%,-50%); width:88px; text-align:center; cursor:pointer; }
.tseat .av { box-shadow:0 2px 8px rgba(0,0,0,.55); }
.tseat .tname { font-size:11px; font-weight:700; margin-top:3px; line-height:1.15; max-width:88px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.tseat .tcards { font-size:10.5px; color:var(--dim); }
.tseat.you .tname { color:var(--gold); }
.tseat.you .av { outline:2px solid var(--gold); border-radius:50%; }
.tseat.dead { opacity:.4; filter:grayscale(.85); }
.tseat.targetable { pointer-events:auto; cursor:pointer; }
.tseat.targetable .av { outline:3px solid var(--red); border-radius:50%; animation:ttpulse 1s infinite; }
@keyframes ttpulse { 50% { outline-color:#ffd95e; } }
.pile { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.pile img { width:64px; border-radius:7px; box-shadow:0 4px 12px rgba(0,0,0,.55); margin:0 -18px; }
.pilemt { font-size:46px; opacity:.25; }
.targhint { position:absolute; left:50%; bottom:10px; transform:translateX(-50%); background:var(--red); color:#fff;
  font-weight:700; font-size:12.5px; padding:7px 14px; border-radius:20px; white-space:nowrap; box-shadow:0 4px 14px rgba(0,0,0,.4); }
.targhint span { text-decoration:underline; cursor:pointer; }

.chip { cursor:pointer; }

/* gold gain splash */
.sj-goldpop { position:fixed; left:50%; top:42%; transform:translate(-50%,-50%); z-index:210; pointer-events:none;
  font-weight:900; font-size:64px; color:var(--gold); text-shadow:0 3px 0 #7a5a12, 0 0 26px rgba(240,199,94,.75);
  animation:sjGold 1.6s cubic-bezier(.2,1,.3,1) forwards; }
.sj-goldpop span { font-size:46px; }
@keyframes sjGold {
  0% { opacity:0; transform:translate(-50%,-30%) scale(.4); }
  18% { opacity:1; transform:translate(-50%,-50%) scale(1.18); }
  34% { transform:translate(-50%,-50%) scale(1); }
  100% { opacity:0; transform:translate(-50%,-155%) scale(1); }
}
