@import url('pally.css');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#4a90c4;--surface:#16213e;--accent:#e94560;--gold:#ffe44d;
  --green:#0f9b58;--text:#eaeaea;--muted:#8a8a9a;
  --radius:16px;--font:'Pally-Regular','Pally-Variable','Segoe UI',system-ui,-apple-system,sans-serif;
}
html,body{height:100%;overflow:hidden;font-family:var(--font);background:#000;color:var(--text);touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:pointer}
canvas{display:block;touch-action:none;background-image:url('../assets/backgrounds/bg_game.jpg')}

/* ---------- overlay screens ---------- */
.screen-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:100;background:url('../assets/backgrounds/bg_game.jpg') center/cover no-repeat;backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .3s}
.screen-overlay.active{opacity:1;pointer-events:all}
.screen-overlay.end-fadeout{animation:overlay-fadeout 2s ease forwards}
@keyframes overlay-fadeout{0%{background-color:rgba(255,255,255,.1)}100%{background-color:rgba(255,255,255,.3)}}
.back{background:#FFF;}
.panel{background:rgba(255,255,255,.9);border-radius:var(--radius);padding:32px 28px;max-width:480px;width:90%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.15);position:relative;z-index:1;border:2px solid #000}
.panel h1{font-size:clamp(24px,5vw,36px);margin-bottom:8px;color:#000}
.panel h2{font-size:clamp(18px,4vw,24px);margin-bottom:12px;color:#000}
.panel p{font-size:clamp(14px,2.5vw,16px);color:#000;line-height:1.6;margin-bottom:18px}
.panel .username{font-size:18px;color:#000;margin-bottom:14px;opacity:.8}
.btn{display:inline-block;padding:14px 36px;border:none;border-radius:30px;font-family:var(--font);font-size:16px;font-weight:700;cursor:pointer;transition:transform .15s,box-shadow .15s;letter-spacing:.5px;text-decoration:none;}
.btn:active{transform:scale(.95)}
#btnPlay{background:#32cd32;color:#fff;box-shadow:0 4px 20px rgba(50,205,50,.4)}
.btn-primary{background:linear-gradient(135deg,var(--accent),#c0392b);color:#fff;box-shadow:0 4px 20px rgba(233,69,96,.4)}
.btn-secondary{background:linear-gradient(135deg,var(--gold),#d4a017);color:#1a1a2e;box-shadow:0 4px 20px rgba(245,197,24,.3)}
.btn-green{background:linear-gradient(135deg,var(--green),#0d7a48);color:#fff;box-shadow:0 4px 20px rgba(15,155,88,.3)}
.btn-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- HUD ---------- */
#hud{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:10px 16px;z-index:50;pointer-events:none}
#hud>*{pointer-events:all}
.hud-left,.hud-right{display:flex;flex-direction:column;gap:6px}
.hud-left{color:#000}
.hud-right{align-items:flex-end}
.hud-box{background:rgba(255,255,255,.08);border-radius:12px;padding:8px 16px;font-size:clamp(13px,2.5vw,16px);font-weight:600;backdrop-filter:blur(6px);border:2px solid #000}
.hud-round{color:var(--gold)}
.hud-timer{color:var(--accent);font-size:clamp(26px,5vw,32px);min-width:60px;text-align:center;line-height:1}
.hud-timer.warning{animation:pulse-warn .5s ease infinite alternate}
@keyframes pulse-warn{0%{color:var(--accent);transform:scale(1)}100%{color:#ff0;transform:scale(1.1)}}
.hud-quit{background:rgba(255,255,255,.12);border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:6px 16px}
.hud-quit:hover{background:rgba(255,255,255,.2);color:#fff}

/* ---------- round result flash ---------- */
#roundResult{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:80;font-family:var(--font);font-size:clamp(56px,12vw,96px);font-weight:900;text-shadow:0 4px 20px rgba(0,0,0,.6);opacity:0;pointer-events:none}
#roundResult.win{color:var(--gold)}
#roundResult.lose{color:var(--accent)}

/* ---------- progress dots ---------- */
.progress-dots{display:flex;gap:8px;justify-content:center;margin:12px 0}
.dot{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.15);transition:background .3s}
.dot.done-win{background:var(--green)}
.dot.done-lose{background:var(--accent)}
.dot.current{background:var(--gold);box-shadow:0 0 8px var(--gold)}

/* ---------- top bar ---------- */
.topbar{position:fixed;top:0;left:0;width:100%;height:20px;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);pointer-events:none}
.topbar span{font-size:12px;color:rgba(255,255,255,.6);letter-spacing:.5px}
.topbar a { color: #FFF; }
