/* Font — local file (assets/fonts/PressStart2P-Regular.ttf)
   Download: https://fonts.google.com/specimen/Press+Start+2P */
@font-face {
  font-family: 'Press Start 2P';
  src: url('assets/fonts/PressStart2P-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

*{margin:0;padding:0;box-sizing:border-box;}
/* Keyboard navigation focus — mirrors :hover styles */
.level-row.kb-focus{background:rgba(85,255,136,0.1);border-color:#55ff88;}
.level-row.gold.kb-focus{background:rgba(255,204,0,0.15);border-color:#ffcc44;}
.menu-info-btn.gold.kb-focus{background:rgba(255,204,68,0.12);border-color:#ffcc44;}
.menu-info-btn.blue.kb-focus{background:rgba(136,204,255,0.12);border-color:#88ccff;}
.menu-bottom-btn.kb-focus{background:rgba(85,255,136,0.08);border-color:#55ff88;color:#fff;}
.menu-bottom-btn.red.kb-focus{background:rgba(255,68,68,0.1);border-color:#ff4444;color:#ff6666;}
.btn.kb-focus{background:#88ffbb;outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 12px rgba(85,255,136,0.6);}
.profile-card.kb-focus{background:rgba(85,255,136,0.08);border-color:#55ff88;transform:scale(1.03);}
.profile-card.profile-empty.kb-focus{opacity:1;border-color:#55ff88;}
.ai-option.kb-focus{outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 10px rgba(255,255,255,0.3);}
.ai-option.selected.kb-focus{outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 10px rgba(85,255,136,0.5);}
.start-btn.kb-focus{background:#88ffbb;outline:2px solid #fff;outline-offset:2px;box-shadow:0 0 12px rgba(85,255,136,0.6);}
.skill-btn.buyable.kb-focus{background:rgba(255,255,255,0.07);}
.skill-btn.maxed.kb-focus{outline:1px solid #555;outline-offset:1px;}
.skill-btn.kb-focus{outline:1px solid #555;outline-offset:1px;}
.pk-toggle.kb-focus{outline:2px solid #55ff88;outline-offset:1px;}
.ach-item.kb-focus{border-color:#55ff88;background:rgba(85,255,136,0.06);}
.slider.kb-focus{outline:2px solid #55ff88;outline-offset:2px;border-radius:3px;}
.pvp-opt.kb-focus{border-color:#55ff88;background:rgba(85,255,136,0.08);}
.pvp-chip.kb-focus{border-color:#55ff88;color:#55ff88;background:rgba(85,255,136,0.08);}
.pvp-perk.kb-focus{outline:2px solid #55ff88;outline-offset:1px;}
.kb-key.kb-focus{border-color:#55ff88;background:#1a2a1a;}
.level-row-pvp.kb-focus{background:rgba(255,136,85,0.12) !important;border-color:#ffaa77 !important;}
body{background:#0a0a0a;overflow:hidden;font-family:'Press Start 2P',monospace;}
#wrapper{position:fixed;transform-origin:top left;}
canvas{display:block;border:3px solid #2a2a2a;border-radius:4px;}
#hud{position:absolute;top:-44px;left:0;right:0;display:flex;justify-content:space-between;align-items:center;color:#aaffaa;font-size:9px;letter-spacing:1px;padding:6px 4px 0;}
#hud.hidden{display:none;}

/* OVERLAYS */
.screen{position:absolute;inset:0;display:none;flex-direction:column;justify-content:flex-start;align-items:center;background:#0a0a0a;color:#fff;z-index:10;gap:8px;padding:12px 10px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#333 transparent;}
.screen.visible{display:flex;}
.screen h1{font-size:22px;color:#55ff88;text-shadow:0 0 20px #22aa55;letter-spacing:3px;margin-bottom:8px;}
.screen h2{font-size:14px;color:#55ff88;letter-spacing:2px;margin-bottom:4px;}
.hint{font-size:10px;color:#ffcc44;animation:blink 1s infinite;margin-top:8px;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}

/* AI Selection modal */
#ai-select{position:absolute;inset:0;background:#0a0a0a;display:none;flex-direction:column;justify-content:center;align-items:center;z-index:15;gap:12px;padding:12px;}
#ai-select.visible{display:flex;}
.ai-columns{display:flex;gap:16px;justify-content:center;}
.ai-col{display:flex;flex-direction:column;gap:6px;width:220px;}
.ai-col-title{font-size:9px;color:#55ff88;letter-spacing:1px;margin-bottom:2px;text-align:center;}
.ai-option{padding:10px 12px;background:rgba(255,255,255,0.04);border:2px solid #333;border-radius:6px;cursor:pointer;transition:all .2s;text-align:left;}
.ai-option:hover{background:rgba(85,255,136,0.08);border-color:#55ff88;}
.ai-option.selected{border-color:#55ff88;background:rgba(85,255,136,0.1);}
.ai-option .ao-title{font-size:9px;color:#ddd;}
.ai-option .ao-desc{font-size:6px;color:#888;margin-top:3px;}
.ai-option .ao-icon{font-size:14px;float:left;margin-right:8px;}
.ai-btn-row{display:flex;gap:10px;}

/* PLAYER CARDS (gameover co-op) */
.player-card{display:flex;align-items:center;gap:10px;padding:6px 10px;margin:4px 0;background:rgba(255,255,255,0.04);border:1px solid #333;border-radius:6px;}
.pc-head{font-size:12px;font-weight:bold;min-width:30px;}
.pc-stats{display:flex;gap:10px;font-size:7px;color:#aaa;}
.pc-stats b{color:#ddd;}

/* LOBBY */
#lobby-overlay{display:none;position:absolute;inset:0;z-index:90;background:rgba(0,0,0,0.85);align-items:center;justify-content:center;}
#lobby-overlay.visible{display:flex;}
.lobby-box{text-align:center;padding:20px;max-height:90vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#333 transparent;}
.lobby-title{font-size:12px;color:#55ff88;margin-bottom:8px;letter-spacing:2px;}
.lobby-mode-desc{font-size:7px;color:#ffcc44;margin-bottom:10px;line-height:1.6;max-width:420px;margin-left:auto;margin-right:auto;}
.lobby-settings{display:flex;flex-wrap:wrap;gap:4px 8px;justify-content:center;margin-bottom:12px;max-width:420px;margin-left:auto;margin-right:auto;}
.lobby-stag{font-size:6px;color:#888;background:rgba(255,255,255,0.04);border:1px solid #333;border-radius:3px;padding:2px 6px;}
.lobby-stag b{color:#ccc;font-weight:normal;}
.lobby-slots{display:flex;gap:12px;justify-content:center;margin-bottom:16px;flex-wrap:wrap;}
.lobby-slot{width:140px;padding:14px 10px;border:2px solid #333;border-radius:8px;background:rgba(255,255,255,0.03);}
.lobby-joined{background:rgba(85,255,136,0.05);}
.lobby-empty{opacity:0.4;}
.lobby-p{font-size:14px;font-weight:bold;margin-bottom:6px;}
.lobby-device{font-size:7px;color:#aaa;margin-bottom:4px;}
.lobby-keys{font-size:6px;color:#666;letter-spacing:1px;}
.lobby-hint{font-size:6px;color:#555;}
.lobby-join-hint{font-size:7px;color:#ffcc44;margin-bottom:12px;animation:blink 1.2s infinite;letter-spacing:1px;}
.lobby-btn-disabled{opacity:0.3;cursor:default !important;}
.lobby-btns{display:flex;gap:10px;justify-content:center;}

/* LEVEL SELECT */
.level-list{display:flex;flex-direction:column;gap:6px;width:420px;overflow-y:auto;flex-shrink:1;min-height:0;scrollbar-width:thin;scrollbar-color:#333 transparent;}

/* Menu info row (points + achievements) */
.menu-info-row{display:flex;gap:6px;width:420px;margin:8px auto 4px;flex-shrink:0;}
.menu-info-btn{flex:1;font-size:9px;padding:6px 0;border:1px solid #333;border-radius:4px;cursor:pointer;transition:all .2s;color:#ccc;text-align:center;}
.menu-info-btn.gold{border-color:#aa8800;color:#ffcc44;background:rgba(255,204,68,0.06);}
.menu-info-btn.gold:hover{background:rgba(255,204,68,0.12);border-color:#ffcc44;}
.menu-info-btn.blue{border-color:#336688;color:#88ccff;background:rgba(136,204,255,0.06);}
.menu-info-btn.blue:hover{background:rgba(136,204,255,0.12);border-color:#88ccff;}
/* Menu bottom row (stats, settings, exit) */
.menu-bottom-row{display:flex;gap:6px;width:450px;margin:4px auto 0;flex-shrink:0;}
.menu-bottom-btn{flex:1;font-size:8px;padding:8px 0;border:2px solid #444;border-radius:6px;cursor:pointer;transition:all .2s;color:#aaa;background:rgba(255,255,255,0.03);text-align:center;}
.menu-bottom-btn:hover{background:rgba(85,255,136,0.08);border-color:#55ff88;color:#fff;}
.menu-bottom-btn.red{border-color:#553333;color:#aa6666;}
.menu-bottom-btn.red:hover{background:rgba(255,68,68,0.1);border-color:#ff4444;color:#ff6666;}
.level-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:rgba(255,255,255,0.05);border:1px solid #333;border-radius:4px;cursor:pointer;transition:all .2s;min-height:38px;}
.level-row:hover{background:rgba(85,255,136,0.1);border-color:#55ff88;}
.level-row.locked{opacity:0.3;cursor:default;}
.level-row.locked:hover{background:rgba(255,255,255,0.05);border-color:#333;}
.level-row .lr-left{flex:1;min-width:0;}
.level-row .lr-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.level-row .lr-times{display:flex;flex-direction:column;align-items:flex-end;gap:1px;min-width:70px;}
.level-row .lname{font-size:8px;color:#ddd;}
.level-row .lstatus{font-size:7px;color:#55ff88;text-align:right;min-width:18px;}
.level-row .lstatus.locked-s{color:#666;}
.level-row .lrecord{font-size:6px;color:#ffcc44;text-align:right;}
.level-row .ltime{font-size:6px;color:#88ccff;text-align:right;}
.level-row .ltime-perfect{color:#ffcc44;}
.level-row.gold{background:rgba(255,204,0,0.08);border-color:#aa8800;}
.level-row.gold:hover{background:rgba(255,204,0,0.15);border-color:#ffcc44;}
.level-row.gold .lname{color:#ffdd44;}
.level-row.gold .lstatus{color:#ffdd44;}
.level-row.gold .ltime{color:#aa9944;}

/* Star icon */
.star-icon{width:16px;height:16px;vertical-align:middle;image-rendering:pixelated;}
.star-icon-sm{width:10px;height:10px;vertical-align:middle;image-rendering:pixelated;}

/* Pixel art icons */
.pi{display:inline-block;width:14px;height:14px;vertical-align:middle;image-rendering:pixelated;filter:brightness(0) invert(1);}
.pi-sm{width:11px;height:11px;}
.pi-lg{width:18px;height:18px;}
.pi-gold{filter:brightness(0) invert(1) sepia(1) saturate(5) hue-rotate(10deg);}
.pi-green{filter:brightness(0) invert(0.7) sepia(1) saturate(5) hue-rotate(90deg);}
.pi-red{filter:brightness(0) invert(0.5) sepia(1) saturate(10) hue-rotate(0deg);}
.pi-blue{filter:brightness(0) invert(0.7) sepia(1) saturate(5) hue-rotate(180deg);}
.pi-purple{filter:brightness(0) invert(0.6) sepia(1) saturate(5) hue-rotate(240deg);}

/* GAME OVER */
#gameover-text{font-size:18px;color:#ff4444;text-shadow:0 0 15px #ff2222;}
#win-text{font-size:16px;color:#55ff88;text-shadow:0 0 15px #22aa55;}
.result-info{font-size:9px;color:#aaa;text-align:center;line-height:2;}

/* SKILL TREE */
.sk-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding-bottom:8px;border-bottom:1px solid #1a2a1a;flex-shrink:0;}
.sk-pts{font-size:9px;color:#ffcc44;letter-spacing:1px;}
.sk-content{display:grid;grid-template-columns:200px 1fr;gap:10px;width:100%;flex:1;min-height:0;}
.sk-back-btn{flex-shrink:0;margin-top:6px;width:100%;max-width:200px;}

/* Tank preview */
#tank-preview{display:flex;flex-direction:column;gap:4px;align-items:flex-start;}
#tank-preview canvas{border:1px solid #2a2a2a;border-radius:3px;flex-shrink:0;}
.tp-stats{width:100%;display:flex;flex-direction:column;gap:2px;}
.tp-cat{font-size:6px;letter-spacing:1px;margin-top:4px;margin-bottom:1px;font-weight:bold;}
.sb-row{display:flex;align-items:center;gap:4px;}
.sb-label{font-size:5px;color:#666;width:40px;text-align:right;flex-shrink:0;letter-spacing:0.5px;}
.sb-bar{flex:1;height:3px;background:#181818;border-radius:2px;overflow:hidden;}
.sb-fill{height:100%;border-radius:2px;}
.sb-val{font-size:5px;color:#888;width:28px;text-align:left;flex-shrink:0;}

/* Skill grid (right column) */
.skill-grid{display:flex;flex-direction:column;gap:6px;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:#2a2a2a transparent;}
.skill-category{background:rgba(255,255,255,0.025);border:1px solid #1e2e1e;border-radius:6px;padding:8px 10px;}
.sk-cat-header{display:flex;align-items:center;gap:6px;margin-bottom:6px;padding-bottom:5px;border-bottom:1px solid #1a2a1a;}
.sk-cat-icon{font-size:11px;}
.sk-cat-title{font-size:8px;letter-spacing:1.5px;font-weight:bold;}

/* Skill buttons */
.skill-btn{background:rgba(255,255,255,0.03);border:1px solid #2a2a2a;border-radius:4px;padding:6px 8px;margin-bottom:4px;cursor:default;transition:all 0.15s;}
.skill-btn.buyable{cursor:pointer;}
.skill-btn.buyable:hover{background:rgba(255,255,255,0.07);transform:translateX(2px);}
.skill-btn.maxed{opacity:0.6;}
.sk-btn-top{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:3px;}
.sk-btn-bot{display:flex;justify-content:space-between;align-items:center;}
.sk-name{font-size:7px;color:#ddd;letter-spacing:0.5px;}
.sk-desc{font-size:5px;color:#666;}
.sk-pips{display:flex;gap:2px;flex-shrink:0;}
.sk-pip{width:8px;height:4px;border-radius:1px;background:#1a1a1a;border:1px solid #2a2a2a;}
.sk-cost{font-size:6px;}
.sk-cost.can{color:#55ff88;}
.sk-cost.cant{color:#444;}
.sk-cost-maxed{font-size:6px;color:#ffcc44;}

/* Perk section */
.perk-section{border-color:#332200;}
.perk-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;}
.perk-card{background:rgba(255,255,255,0.02);border:1px solid #2a2a2a;border-radius:4px;padding:5px 6px;display:flex;flex-direction:column;gap:2px;position:relative;}
.perk-card.pk-unlocked{border-color:#665500;background:rgba(255,204,68,0.03);}
.perk-card.pk-disabled{opacity:0.4;border-color:#333;}
.perk-card.pk-locked{opacity:0.2;}
.pk-lvl-badge{font-size:5px;color:#555;letter-spacing:0.5px;}
.pk-name{font-size:6px;line-height:1.3;}
.pk-desc{font-size:5px;color:#666;line-height:1.3;flex:1;}
.pk-toggle{font-size:5px;padding:2px 5px;border-radius:2px;cursor:pointer;border:1px solid;text-align:center;margin-top:2px;}
.pk-toggle.on{color:#55ff88;border-color:#33aa55;background:rgba(85,255,136,0.07);}
.pk-toggle.off{color:#ff6644;border-color:#aa3322;background:rgba(255,68,68,0.07);}

/* Achievement screen */
.ach-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;width:100%;max-width:720px;padding:0 4px;}
.ach-item{font-size:7px;padding:6px 8px;background:rgba(255,255,255,0.02);border:1px solid #2a2a2a;border-radius:4px;}
.ach-item.unlocked{border-color:#55aa44;background:rgba(85,255,136,0.04);transition:all .2s;cursor:default;}
.ach-item.unlocked:hover{background:rgba(85,255,136,0.1);border-color:#55ff88;transform:scale(1.02);}
.ach-item .ach-name{color:#888;font-size:7px;margin-bottom:2px;}
.ach-item.unlocked .ach-name{color:#55ff88;}
.ach-item .ach-desc{color:#555;font-size:6px;}
.ach-item.unlocked .ach-desc{color:#888;}
.ach-item .ach-prog{color:#ffcc44;font-size:6px;margin-top:2px;}
.ach-counter{font-size:8px;color:#888;margin-bottom:6px;}

/* Ach bottom row */
.ach-bottom-row{display:flex;gap:10px;justify-content:center;flex-shrink:0;margin-top:4px;}

/* Global stats screen */
#stats-global-screen.visible{flex-direction:column;align-items:center;max-height:100%;}
#stats-global-screen h2{margin-bottom:6px;}
.gs-scroll{width:100%;max-width:500px;overflow-y:auto;flex:1;padding:0 8px 4px;margin-bottom:4px;}
.gs-cat{font-size:8px;color:#55aa88;margin:10px 0 4px;border-bottom:1px solid #2a2a2a;padding-bottom:2px;}
.gs-cat:first-child{margin-top:2px;}
.gs-row{display:flex;justify-content:space-between;font-size:7px;padding:3px 0;color:#aaa;border-bottom:1px solid rgba(255,255,255,0.03);}
.gs-val{color:#fff;font-weight:bold;}
.gs-enemy-row{display:flex;justify-content:space-between;align-items:center;font-size:7px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,0.03);}
.gs-enemy-name{flex:1;font-weight:bold;}
.gs-enemy-stat{margin-left:12px;color:#aaa;}
.gs-enemy-stat b{color:#fff;}
.gs-empty{font-size:8px;color:#666;margin:30px 0;}

/* Pause settings */
.pause-settings{width:90%;max-width:400px;margin:8px 0;display:flex;flex-direction:column;gap:10px;}
.pause-ach{font-size:6px;color:#777;padding:3px 6px;background:rgba(255,255,255,0.02);border:1px solid #2a2a2a;border-radius:3px;display:flex;justify-content:space-between;}
.pause-ach .pa-name{color:#aaa;}
.pause-ach .pa-prog{color:#ffcc44;}

/* Nickname modal */
#nickname-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:50;justify-content:center;align-items:center;}
#nickname-modal.visible{display:flex;}
.nick-box{background:#111;border:2px solid #55ff88;border-radius:8px;padding:20px 30px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center;}
.nick-title{font-size:10px;color:#55ff88;letter-spacing:1px;}
.nick-input{font-family:inherit;font-size:10px;padding:6px 12px;background:#1a1a1a;border:2px solid #333;border-radius:4px;color:#fff;width:220px;outline:none;text-align:center;}
.nick-input:focus{border-color:#55ff88;}
.nick-tag{font-size:7px;color:#888;}
.nick-error{font-size:7px;color:#ff4444;min-height:10px;}

/* Konami modal */
#konami-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.85);z-index:50;justify-content:center;align-items:center;}
#konami-modal.visible{display:flex;}
.konami-box{background:#111;border:2px solid #ffcc44;border-radius:8px;padding:20px 30px;text-align:center;}
.konami-text{font-size:10px;color:#ffcc44;margin-bottom:16px;line-height:1.8;}
.konami-btns{display:flex;gap:12px;justify-content:center;}
.btn{padding:8px 20px;background:#55ff88;color:#000;border:none;font-family:inherit;font-size:9px;border-radius:4px;cursor:pointer;letter-spacing:1px;margin-top:8px;}
.btn:hover{background:#88ffbb;}
.btn-row{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap;justify-content:center;}

/* Stats animation */
#stats-container{width:100%;max-width:500px;padding:0 10px;}
.stat-line{font-size:8px;color:#aaa;padding:3px 8px;display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,0.04);width:100%;}
.stat-line.header{color:#55ff88;font-size:9px;border-bottom:1px solid rgba(85,255,136,0.2);padding:5px 8px;margin-top:6px;}
.stat-line .val{color:#ffcc44;text-align:right;min-width:60px;}
.stat-line.highlight{color:#fff;font-size:9px;}
.stat-line.highlight .val{color:#55ff88;font-size:10px;}
.stat-line.fun{color:#888;font-style:italic;font-size:7px;border-bottom:none;justify-content:center;}
.stat-line.perfect{color:#ffdd44;font-size:10px;border-bottom:none;justify-content:center;text-shadow:0 0 12px rgba(255,204,0,0.6);letter-spacing:2px;padding:8px 0;}
.enemy-card{width:100%;border-left:2px solid rgba(255,136,68,0.3);margin:0 0 6px 0;padding:4px 10px 5px 10px;background:rgba(255,255,255,0.015);}
.enemy-card .ec-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px;}
.enemy-card .ec-name{font-size:8px;}
.enemy-card .ec-kills{font-size:8px;color:#ff8844;}
.enemy-card .ec-deaths{font-size:6px;color:#555;margin-left:4px;}
.enemy-card .ec-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:1px;}
.enemy-card .ec-stat{font-size:7px;color:#888;}
.enemy-card .ec-stat b{color:#ccaa44;}
.enemy-card .ec-bonuses{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px;}
.enemy-card .ec-bonus{font-size:6px;color:#55aa55;background:rgba(85,255,136,0.05);padding:1px 4px;border-radius:2px;}

/* Pause */
#pause-btn{position:absolute;top:8px;right:8px;background:rgba(255,255,255,0.08);border:1px solid #444;color:#aaa;font-family:inherit;font-size:8px;padding:5px 10px;border-radius:3px;cursor:pointer;z-index:5;display:none;}
#pause-btn:hover{background:rgba(255,255,255,0.15);color:#fff;}
#pause-screen{position:absolute;inset:0;background:rgba(0,0,0,0.75);display:none;flex-direction:column;justify-content:center;align-items:center;z-index:15;gap:16px;}
#pause-screen.visible{display:flex;}
#pause-screen h2{font-size:16px;color:#ffcc44;letter-spacing:2px;}
#pause-screen .pause-btns{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.pause-exit-btn{border-color:#ff4444 !important;color:#ff4444 !important;margin-top:6px;}
.pause-exit-btn:hover{background:rgba(255,68,68,0.1) !important;}

/* Mobile controls */

/* Start screen */
.start-center{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;}
.start-center h1{margin-bottom:20px;}
.start-btn{width:260px;text-align:center;font-size:10px;padding:10px 20px;}
.start-btn-dim{background:#336644;color:#aaffaa;}
.start-btn-dim:hover,.start-btn-dim.kb-focus{background:#44aa66;color:#fff;}

/* Profile screen */
.profile-list{display:flex;gap:12px;justify-content:center;margin:16px 0;}
.profile-card{width:200px;padding:14px 16px;background:rgba(255,255,255,0.04);border:2px solid #444;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center;}
.profile-card:hover{background:rgba(85,255,136,0.08);border-color:#55ff88;transform:scale(1.03);}
.profile-card .pc-header{font-size:10px;color:#55ff88;margin-bottom:8px;letter-spacing:1px;}
.profile-card .pc-stat{font-size:7px;color:#aaa;margin-top:3px;}
.profile-card .pc-empty{font-size:8px;color:#555;margin-top:16px;}
.profile-card{position:relative;}
.profile-card.profile-empty{border-color:#333;opacity:0.6;}
.profile-card.profile-empty:hover{opacity:1;border-color:#55ff88;}
.profile-delete-btn{position:absolute;top:6px;right:6px;width:18px;height:18px;padding:0;font-size:8px;line-height:18px;text-align:center;background:transparent;border:1px solid #555;border-radius:3px;color:#666;cursor:pointer;transition:all .2s;font-family:inherit;}
.profile-delete-btn:hover{border-color:#ff4444;color:#ff4444;background:rgba(255,68,68,0.1);}

/* Settings screen */
.settings-list{display:flex;flex-direction:column;gap:14px;width:100%;max-width:400px;margin:16px 0;}
.setting-row{display:flex;align-items:center;gap:10px;}
.setting-label{font-size:8px;color:#aaa;width:80px;text-align:right;flex-shrink:0;}
.setting-val{font-size:8px;color:#ffcc44;width:40px;text-align:left;flex-shrink:0;}
.slider{-webkit-appearance:none;appearance:none;flex:1;height:6px;background:#2a2a2a;border-radius:3px;outline:none;}
.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#55ff88;border-radius:50%;cursor:pointer;border:2px solid #33aa55;}
.slider::-moz-range-thumb{width:16px;height:16px;background:#55ff88;border-radius:50%;cursor:pointer;border:2px solid #33aa55;}

/* Version label */
#version-label{position:absolute;bottom:4px;right:6px;font-size:6px;color:rgba(255,255,255,0.2);pointer-events:none;z-index:100;letter-spacing:0.5px;}

/* LAN browser */
.lan-name-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;width:100%;max-width:450px;}
.lan-name-label{font-size:7px;color:#55ff88;white-space:nowrap;letter-spacing:1px;}
.lan-name-input{flex:1;padding:6px 10px;font-size:9px;font-family:'Press Start 2P',monospace;background:#111;border:2px solid #333;border-radius:4px;color:#fff;outline:none;transition:border-color .2s;}
.lan-name-input:focus{border-color:#55ff88;}
.lan-name-input::placeholder{color:#555;}
.lan-server-list{width:100%;max-width:450px;min-height:120px;max-height:250px;overflow-y:auto;border:1px solid #333;border-radius:6px;padding:6px;margin:8px 0;scrollbar-width:thin;scrollbar-color:#333 transparent;}
.lan-searching{font-size:7px;color:#666;text-align:center;padding:20px 0;}
.lan-server-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #333;border-radius:4px;margin-bottom:4px;cursor:pointer;transition:all .2s;}
.lan-server-row:hover{border-color:#55ff88;background:rgba(85,255,136,0.06);}
.lan-server-row.kb-focus{border-color:#55ff88;background:rgba(85,255,136,0.08);}
.lan-server-ingame{opacity:0.4;cursor:default !important;}
.lan-server-ingame:hover{border-color:#333;background:transparent;}
.lan-server-reconnect{opacity:1 !important;cursor:pointer !important;border-color:#ffcc44 !important;}
.lan-server-reconnect:hover{border-color:#ffdd66 !important;background:rgba(255,204,68,0.08) !important;}
.lan-server-reconnect .lan-srv-status{color:#ffcc44;}
.lan-srv-host{font-size:8px;color:#fff;flex:1;}
.lan-srv-mode{font-size:6px;color:#ffcc44;width:60px;}
.lan-srv-players{font-size:7px;color:#aaa;width:30px;text-align:center;}
.lan-srv-status{font-size:10px;width:16px;text-align:center;}
.lan-btn-row{display:flex;gap:10px;margin-top:4px;}
.lan-waiting{font-size:7px;color:#ffcc44;text-align:center;margin:8px 0;animation:blink 1.2s infinite;}
#lan-lobby-overlay{display:none;position:absolute;inset:0;z-index:90;background:rgba(0,0,0,0.85);align-items:center;justify-content:center;}
#lan-lobby-overlay.visible{display:flex;}

/* Countdown overlay */
#countdown-overlay{display:none;position:absolute;inset:0;z-index:95;background:rgba(0,0,0,0.8);align-items:center;justify-content:center;}
#countdown-overlay.visible{display:flex;}
.countdown-num{font-size:60px;color:#55ff88;text-shadow:0 0 30px #22aa55,0 0 60px #116633;animation:countdown-pop 0.6s ease-out;}
@keyframes countdown-pop{0%{transform:scale(2);opacity:0}30%{transform:scale(1);opacity:1}100%{opacity:1}}

/* LAN kick button */
.lan-kick-btn:hover{background:rgba(255,68,68,0.15) !important;}

/* PvP level row */
.level-row-pvp{border-color:#ff8855 !important;background:rgba(255,136,85,0.06) !important;}
.level-row-pvp:hover{background:rgba(255,136,85,0.12) !important;border-color:#ffaa77 !important;}

/* PvP settings */
.pvp-scroll{display:flex;flex-direction:column;gap:10px;width:100%;max-width:500px;overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:#333 transparent;}
.pvp-section{display:flex;flex-direction:column;gap:4px;}
.pvp-label{font-size:8px;color:#55ff88;letter-spacing:1px;}
.pvp-options{display:flex;flex-direction:column;gap:4px;}
.pvp-row{flex-direction:row;gap:6px;flex-wrap:wrap;}
.pvp-opt{padding:8px 10px;background:rgba(255,255,255,0.04);border:2px solid #333;border-radius:6px;cursor:pointer;transition:all .2s;}
.pvp-opt.selected{border-color:#55ff88;background:rgba(85,255,136,0.08);}
.pvp-opt-title{font-size:8px;color:#fff;}
.pvp-opt-desc{font-size:6px;color:#888;margin-top:2px;}
.pvp-chip{padding:5px 12px;font-size:8px;background:#1a1a1a;border:2px solid #333;border-radius:4px;cursor:pointer;transition:all .2s;color:#888;}
.pvp-chip.selected{border-color:#55ff88;color:#55ff88;background:rgba(85,255,136,0.08);}
.pvp-chip:hover{border-color:#555;}
.pvp-custom{padding:0;}
.pvp-custom input{width:36px;padding:5px 6px;font-size:8px;font-family:inherit;background:transparent;border:none;color:#888;text-align:center;outline:none;}
.pvp-custom.selected input{color:#55ff88;}
.pvp-custom input::placeholder{color:#555;font-family:inherit;}
.pvp-custom input::-webkit-inner-spin-button,.pvp-custom input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
.pvp-perks{display:flex;flex-wrap:wrap;gap:4px;}
.pvp-perk{padding:5px 8px;background:#1a1a1a;border:2px solid #333;border-radius:4px;cursor:pointer;transition:all .2s;width:calc(50% - 4px);box-sizing:border-box;}
.pvp-perk.active{border-color:#ffcc44;background:rgba(255,204,68,0.08);}
.pvp-perk-name{font-size:7px;color:#ffcc44;}
.pvp-perk.active .pvp-perk-name{color:#ffdd66;}
.pvp-perk:not(.active) .pvp-perk-name{color:#666;}
.pvp-perk-desc{font-size:5px;color:#555;margin-top:1px;}
.pvp-perk.active .pvp-perk-desc{color:#888;}
.pvp-btn-row{display:flex;gap:10px;margin-top:6px;}
/* PvP HUD */
.pvp-hud{position:absolute;top:2px;left:0;right:0;display:flex;justify-content:center;gap:12px;font-size:8px;z-index:5;pointer-events:none;}
.pvp-hud-slot{display:flex;align-items:center;gap:4px;}
.pvp-hud-kills{color:#fff;}

.pvp-winner-card{border:2px solid #ffcc44 !important;background:rgba(255,204,68,0.08) !important;}
.pvp-elim-card{opacity:0.5;}

/* Keybindings */
.kb-columns{display:flex;gap:24px;justify-content:center;width:100%;max-width:500px;margin:8px 0;}
.kb-col{display:flex;flex-direction:column;gap:6px;flex:1;}
.kb-col-title{font-size:9px;color:#55ff88;letter-spacing:1px;margin-bottom:4px;text-align:center;}
.kb-row{display:flex;align-items:center;gap:8px;justify-content:space-between;}
.kb-action{font-size:7px;color:#aaa;width:60px;text-align:right;flex-shrink:0;}
.kb-key{font-size:7px;padding:5px 10px;min-width:70px;text-align:center;background:#1a1a1a;border:2px solid #333;color:#ffcc44;cursor:pointer;transition:all .2s;margin-top:0;}
.kb-key:hover{border-color:#55ff88;background:#222;}
.kb-key.kb-listening{border-color:#ffcc44;color:#fff;animation:blink 0.8s infinite;background:#2a2a00;}
.kb-error{font-size:7px;color:#ff4444;min-height:14px;text-align:center;}
.kb-btn-row{display:flex;gap:10px;margin-top:4px;}

/* Leaderboard */
.lb-nick-row{display:flex;align-items:center;gap:6px;margin-bottom:8px;}
.lb-nick-label{font-size:8px;color:#aaa;}
.lb-nick-input{font-family:inherit;font-size:8px;padding:4px 8px;background:#1a1a1a;border:1px solid #333;border-radius:3px;color:#fff;width:140px;outline:none;}
.lb-nick-input:focus{border-color:#55ff88;}
.lb-nick-save{padding:4px 10px;font-size:7px;margin-top:0;}
.lb-tabs{display:flex;gap:6px;margin-bottom:8px;}
.lb-tab{padding:5px 16px;font-size:8px;background:#222;color:#888;border:1px solid #333;}
.lb-tab.lb-tab-active{background:#336644;color:#55ff88;border-color:#55ff88;}
.lb-filters{display:flex;flex-direction:column;gap:4px;margin-bottom:8px;width:100%;max-width:500px;}
.lb-filter-row{display:flex;gap:4px;justify-content:center;flex-wrap:wrap;}
.lb-filter-btn{padding:3px 8px;font-size:6px;background:#1a1a1a;color:#888;border:1px solid #2a2a2a;margin-top:0;}
.lb-filter-btn.lb-filter-active{background:#2a3a2a;color:#55ff88;border-color:#55ff88;}
.lb-table-wrap{width:100%;max-width:500px;flex:1;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#333 transparent;}
.lb-header-row{display:flex;font-size:7px;color:#55aa88;padding:4px 8px;border-bottom:1px solid #2a2a2a;}
.lb-row{display:flex;font-size:7px;color:#aaa;padding:4px 8px;border-bottom:1px solid rgba(255,255,255,0.03);}
.lb-row.lb-top1{color:#ffdd44;font-size:8px;}
.lb-row.lb-top2{color:#cccccc;}
.lb-row.lb-top3{color:#cc8844;}
.lb-col-rank{width:30px;flex-shrink:0;text-align:center;}
.lb-col-name{flex:1;}
.lb-col-val{width:80px;flex-shrink:0;text-align:right;color:#ffcc44;}
.lb-row.lb-me{background:rgba(85,255,136,0.08);border-left:2px solid #55ff88;}
.lb-row.lb-me .lb-col-name{color:#55ff88;}
.lb-loading{font-size:8px;color:#666;text-align:center;padding:20px 0;}
.lb-filter-btn.kb-focus{border-color:#55ff88;color:#fff;background:#2a3a2a;}
.lb-tab.kb-focus{border-color:#55ff88;color:#fff;}
#reconnect-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.75);display:flex;align-items:center;justify-content:center;z-index:9999;}
.reconnect-box{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 48px;background:#111;border:2px solid #333;border-radius:8px;}
.reconnect-text{font-size:10px;color:#ccc;font-family:'Press Start 2P',monospace;}
.reconnect-spinner{width:24px;height:24px;border:3px solid #333;border-top-color:#55ff88;border-radius:50%;animation:rc-spin 0.8s linear infinite;}
.reconnect-cancel{margin-top:4px;font-size:7px;}
@keyframes rc-spin{to{transform:rotate(360deg);}}
#update-banner{position:fixed;bottom:0;left:0;right:0;z-index:10000;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;font-family:'Press Start 2P',monospace;font-size:7px;}
.update-banner-available{background:#1a2a1a;border-top:1px solid #55aa44;color:#88dd66;}
.update-banner-progress{background:#1a1a2a;border-top:1px solid #4455aa;color:#6688dd;}
.update-banner-ready{background:#2a1a1a;border-top:1px solid #aa5544;color:#dd8866;}
#update-banner button{font-family:'Press Start 2P',monospace;font-size:6px;padding:4px 8px;background:#222;border:1px solid #555;color:#fff;cursor:pointer;}
#update-banner button:hover{background:#333;border-color:#888;}
