@import url('https://fonts.googleapis.com/css2?family=Permanent+Marker&family=Patrick+Hand&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
body{background:#111;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;font-family:'Patrick Hand',cursive;overflow:hidden}
#wrapper{display:flex;flex-direction:column;align-items:center}
#topbar{width:960px;height:44px;background:#0a0a14;border:2px solid #222;border-bottom:none;
  display:flex;align-items:center;justify-content:space-between;padding:0 14px}
#game-title{font-family:'Permanent Marker',cursive;font-size:20px;color:#ff4d6d;letter-spacing:2px}
.tstat{text-align:center;min-width:70px}
.tstat .tl{font-size:9px;color:#555;text-transform:uppercase;letter-spacing:1px}
.tstat .tv{font-size:16px;color:#e0e0ff;font-weight:bold;font-family:'Permanent Marker',cursive}
.tstat .tv.danger{color:#ff4d6d;animation:blink .4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
#lvltag{font-size:11px;color:#555;letter-spacing:1px;text-transform:uppercase}
#canvas{display:block;border:2px solid #222;border-top:none;border-bottom:none;cursor:crosshair;touch-action:none}
#hud{width:960px;background:#0a0a14;border:2px solid #222;border-top:1px solid #1a1a2a;
  display:flex;align-items:center;padding:6px 10px;gap:6px;flex-wrap:wrap;touch-action:manipulation}
.sbtn{width:88px;height:72px;border:1.5px solid #2a2a3a;background:#080814;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;border-radius:4px;position:relative;user-select:none;transition:.1s}
.sbtn:hover{border-color:#444;background:#111128}
.sbtn.active{border-color:#7b5ea7;background:#1a0a2e;box-shadow:0 0 10px rgba(123,94,167,.5)}
.sbtn.empty{opacity:.3;cursor:not-allowed}
.sbtn .sico{font-size:20px;line-height:1}
.sbtn .sname{font-size:8px;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;text-align:center}
.sbtn.active .sname{color:#aaa}
.sbtn .scnt{position:absolute;top:3px;right:5px;font-size:11px;color:#7b5ea7;font-weight:bold}
.sbtn.active .scnt{color:#c9b1ff}
.sbtn .shot{position:absolute;bottom:3px;left:4px;font-size:8px;color:#333}
.sbtn .skey{position:absolute;top:3px;left:5px;font-size:13px;font-weight:bold;color:#555;font-family:'Permanent Marker',cursive;line-height:1}
.sbtn.active .skey{color:#c9b1ff}
.sbtn.empty .skey{color:#2a2a3a}
.sbtn .stip{font-size:7px;color:#444;text-align:center;margin-top:1px;line-height:1.2;max-width:80px}
.sbtn.active .stip{color:#7b5ea7}
.hdiv{width:1px;height:60px;background:#1a1a2a;margin:0 4px;flex-shrink:0}
.ctrl-col{display:flex;flex-direction:column;gap:5px;padding:0 8px}
.ctrl-row{display:flex;align-items:center;gap:6px}
.ctrl-row label{font-size:9px;color:#555;text-transform:uppercase;letter-spacing:.5px;width:58px}
.ctrl-row input[type=range]{width:90px;accent-color:#7b5ea7;cursor:pointer}
.ctrl-row span{font-size:10px;color:#7b5ea7;min-width:32px}
.hbtn{background:#1a0a2e;border:1px solid #333;color:#888;padding:4px 10px;
  cursor:pointer;font-size:10px;border-radius:3px;font-family:inherit;letter-spacing:.5px}
.hbtn:hover{background:#2a1a3e;color:#bbb}
.hbtn.red{border-color:#5a1a1a;color:#f44;background:#1a0808}
.hbtn.red:hover{background:#2a1010}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.9);display:flex;flex-direction:column;
  align-items:center;justify-content:center;z-index:100}
.overlay.hidden{display:none}
#lobby{background:radial-gradient(ellipse at center,#1a1a3e 0%,#08080f 100%)}
.lobby-title{font-family:'Permanent Marker',cursive;font-size:64px;color:#ff4d6d;
  text-shadow:4px 4px 0 #000;margin-bottom:6px;animation:wobble 3s ease-in-out infinite}
@keyframes wobble{0%,100%{transform:rotate(-1deg)}50%{transform:rotate(1deg)}}
.lobby-sub{font-family:'Permanent Marker',cursive;font-size:16px;color:#555;
  margin-bottom:32px;letter-spacing:3px}
.lobby-card{width:420px;border:1.5px solid #2a2a4a;border-radius:8px;background:#0d0d1a;padding:20px}
.lc-num{font-family:'Permanent Marker',cursive;font-size:36px;color:#ff4d6d;margin-bottom:4px}
.lc-name{font-size:18px;color:#e0e0ff;font-weight:bold;margin-bottom:8px}
.lc-desc{font-size:12px;color:#666;line-height:1.6;margin-bottom:16px}
.lc-meta{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.lc-m{font-size:11px;color:#555}
.lc-m span{color:#7b5ea7;font-weight:bold}
.big-btn{background:#7b5ea7;color:#fff;border:none;padding:12px 36px;
  font-family:'Permanent Marker',cursive;font-size:20px;cursor:pointer;border-radius:5px;
  letter-spacing:2px;box-shadow:0 4px 0 #4a3a6a;transition:.1s}
.big-btn:hover{background:#9a7dc9;transform:translateY(-2px);box-shadow:0 6px 0 #4a3a6a}
.big-btn:active{transform:translateY(2px);box-shadow:0 2px 0 #4a3a6a}
.lobby-hint{margin-top:14px;font-size:11px;color:#333}
.lobby-best{margin-top:8px;font-size:13px;color:#ff9800;font-family:'Permanent Marker',cursive;letter-spacing:1px}
#result{background:rgba(0,0,0,.95)}
.res-title{font-family:'Permanent Marker',cursive;font-size:52px;margin-bottom:12px}
.res-title.win{color:#4caf50;text-shadow:0 0 20px rgba(76,175,80,.5)}
.res-title.lose{color:#ff4d6d;text-shadow:0 0 20px rgba(255,77,109,.5)}
.res-detail{font-size:18px;color:#aaa;margin-bottom:6px}
.res-score{font-family:'Permanent Marker',cursive;font-size:28px;color:#ff9800;margin:8px 0}
.res-best{font-family:'Permanent Marker',cursive;font-size:18px;margin:4px 0}
.res-best.newbest{color:#ffd700;animation:pulse 0.6s ease-in-out infinite alternate}
@keyframes pulse{from{transform:scale(1);opacity:0.8}to{transform:scale(1.15);opacity:1}}
.res-stars{font-size:44px;margin:14px 0}
.res-btns{display:flex;gap:14px;margin-top:18px}
#sniper-stamp{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  pointer-events:none;z-index:50;opacity:0;transition:opacity .2s}
#sniper-stamp.show{opacity:1}
.stamp-text{font-family:'Permanent Marker',cursive;font-size:72px;color:#ff2222;
  border:8px solid #ff2222;padding:10px 28px;border-radius:8px;transform:rotate(-8deg);
  text-shadow:3px 3px 0 #000;letter-spacing:4px;background:rgba(0,0,0,.4)}
#disguise{background:#fff;color:#000;font-family:Arial,sans-serif;
  align-items:flex-start;justify-content:flex-start;padding:0}
.d-nav{width:100%;height:56px;background:#1a73e8;display:flex;align-items:center;
  padding:0 20px;gap:14px;color:white;font-size:14px;flex-shrink:0}
.d-logo{width:28px;height:28px;background:white;border-radius:50%;display:flex;align-items:center;
  justify-content:center;color:#1a73e8;font-weight:bold;font-size:13px}
.d-body{max-width:820px;margin:0 auto;padding:24px 20px;width:100%}
.d-title{font-size:24px;font-weight:700;margin-bottom:4px;color:#202124}
.d-meta{font-size:12px;color:#80868b;margin-bottom:20px}
.d-text{font-size:14px;color:#3c4043;line-height:1.9}
.d-cursor{display:inline-block;width:2px;height:14px;background:#000;
  animation:blink 1s infinite;vertical-align:middle}
.d-hint{position:absolute;bottom:16px;right:16px;font-size:10px;color:#ccc;
  background:rgba(0,0,0,.08);padding:3px 7px;border-radius:3px}
#tooltip{position:fixed;background:#0d0d1a;border:1px solid #7b5ea7;color:#ccc;
  font-size:10px;padding:3px 7px;border-radius:3px;pointer-events:none;z-index:200;display:none;
  font-family:'Patrick Hand',cursive}

@media (max-width: 960px) {
  #wrapper { width: 100vw; }
  #topbar { width: 100vw; font-size: 11px; padding: 0 8px; }
  #canvas { width: 100vw; height: auto; }
  #keypanel { width: 100vw; font-size: 10px; padding: 4px 6px; gap: 4px; }
  #hud { width: 100vw; font-size: 11px; padding: 4px 6px; gap: 4px; }
  .sbtn { min-width: 56px; min-height: 48px; padding: 2px; }
  .sbtn .sico { font-size: 18px; }
  .sbtn .sname { font-size: 7px; }
  .sbtn .skey { font-size: 11px; }
  .sbtn .scnt { font-size: 10px; }
  .kp-skill, .kp-btn, .kp-nuke, .kp-menu { min-height: 36px; padding: 6px 10px; font-size: 11px; }
  .ctrl-col { padding: 0 4px; }
  .ctrl-row input[type=range] { width: 60px; }
  .ctrl-row label { width: 40px; font-size: 8px; }
  .lobby-card { width: 90vw; max-width: 420px; }
  .lobby-title { font-size: 42px; }
  .overlay { overflow-y: auto; }
  .res-title { font-size: 36px; }
  .res-stars { font-size: 32px; }
  .big-btn { padding: 10px 24px; font-size: 16px; }
}
@media (max-width: 600px) {
  #topbar { height: 36px; gap: 4px; }
  .tstat { min-width: 50px; }
  .tstat .tv { font-size: 13px; }
  .tstat .tl { font-size: 7px; }
  #game-title { font-size: 14px; letter-spacing: 1px; }
  #lvltag { font-size: 9px; }
  #hud { flex-wrap: wrap; justify-content: center; }
  .sbtn { width: 68px; height: 56px; }
  .hdiv { height: 40px; }
  .ctrl-col { flex-direction: row; flex-wrap: wrap; gap: 4px; padding: 2px; }
  .ctrl-row { gap: 4px; }
  .lobby-title { font-size: 32px; }
  .lobby-sub { font-size: 12px; margin-bottom: 20px; }
  .lc-num { font-size: 28px; }
  .res-btns { flex-direction: column; gap: 8px; align-items: center; }
  .big-btn { width: 80vw; }
  .kp-label { display: none; }
  #keypanel { justify-content: center; }
}

#keypanel{width:960px;background:#060610;border:2px solid #222;border-bottom:none;border-top:none;display:flex;align-items:center;padding:5px 12px;gap:8px;flex-wrap:wrap;touch-action:manipulation}
.kp-label{font-size:9px;color:#3a3a5a;text-transform:uppercase;letter-spacing:1.5px;margin-right:2px;white-space:nowrap}
.kp-skill{background:#1a0a2e;border:1.5px solid #7b5ea7;color:#c9b1ff;padding:4px 12px;cursor:pointer;font-size:11px;border-radius:4px;font-family:inherit;font-weight:bold;letter-spacing:.5px}
.kp-btn{background:#0a0a18;border:1px solid #2a2a3a;color:#777;padding:4px 10px;cursor:pointer;font-size:11px;border-radius:4px;font-family:inherit}
.kp-nuke{background:#1a0808;border:1.5px solid #5a1a1a;color:#ff5555;padding:4px 12px;cursor:pointer;font-size:11px;border-radius:4px;font-family:inherit;font-weight:bold}
.kp-menu{background:#0a0a18;border:1px solid #2a2a3a;color:#555;padding:4px 10px;cursor:pointer;font-size:11px;border-radius:4px;font-family:inherit}
.kp-sep{width:1px;height:20px;background:#1a1a2a;margin:0 2px}
#res-leaderboard{margin-top:12px}

#landscape-prompt{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;
  background:rgba(0,0,0,0.92);z-index:9999;align-items:center;justify-content:center;
  flex-direction:column;color:#ff4d6d;font-family:'Permanent Marker',cursive;font-size:24px;text-align:center}
#landscape-prompt span{font-size:48px;display:block;margin-bottom:16px}
