@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&display=swap');:root{--ui-scale:1}*{margin:0;padding:0;box-sizing:border-box}body{background:#08081a;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;font-family:'Press Start 2P',monospace;color:#ccc;overflow:hidden;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}canvas{image-rendering:pixelated;image-rendering:crisp-edges}#hud{position:relative;width:640px;max-width:100%;margin-top:calc(4px * var(--ui-scale));display:flex;gap:calc(6px * var(--ui-scale));font-size:calc(9px * var(--ui-scale));align-items:center;flex-wrap:wrap;justify-content:center;min-height:calc(22px * var(--ui-scale))}.hud-bar{display:flex;align-items:center;gap:calc(4px * var(--ui-scale));padding:calc(2px * var(--ui-scale)) calc(6px * var(--ui-scale));border-radius:calc(3px * var(--ui-scale));background:#111;border:1px solid #222}.bar-fill{height:calc(8px * var(--ui-scale));border-radius:2px;transition:width 0.3s}.bar-bg{width:calc(60px * var(--ui-scale));height:calc(8px * var(--ui-scale));background:#222;border-radius:2px;overflow:hidden}#skill-bar{display:flex;gap:calc(6px * var(--ui-scale));margin-top:calc(3px * var(--ui-scale));font-size:calc(8px * var(--ui-scale));min-height:calc(20px * var(--ui-scale));justify-content:center}#skill-bar span{padding:calc(2px * var(--ui-scale)) calc(8px * var(--ui-scale));border-radius:calc(3px * var(--ui-scale));background:rgba(20,20,40,0.9);border:1px solid #333;color:#888}#skill-bar span.ready{border-color:#ffaa44;color:#ffd666;text-shadow:0 0 4px #ff880044}#skill-bar span.cooldown{border-color:#222;color:#444}#log{margin-top:calc(3px * var(--ui-scale));font-size:calc(8px * var(--ui-scale));color:#776;max-width:100%;text-align:center;min-height:calc(14px * var(--ui-scale));text-shadow:0 0 6px #0008}.screen{position:fixed;top:0;left:0;right:0;bottom:0;background:#08081a;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100}.screen.hidden{display:none}.screen h1{font-size:28px;color:#ffc850;text-shadow:0 0 30px #ff880044,0 2px 0 #aa6620;margin-bottom:4px;letter-spacing:2px}.screen .subtitle{font-size:10px;color:#665;margin-bottom:24px;letter-spacing:1px}.screen h2{font-size:22px;margin-bottom:8px}.screen .stats{color:#998;font-size:9px;margin-bottom:20px;text-align:center;line-height:2.2}.btn{font-family:'Press Start 2P',monospace;font-size:11px;padding:10px 28px;background:linear-gradient(180deg,#1a1520,#0e0a14);color:#ffc850;border:2px solid #ffc850;cursor:pointer;transition:all .15s;margin:4px;text-shadow:0 0 8px #ff880044;letter-spacing:1px}.btn:hover{background:linear-gradient(180deg,#ffc850,#dd9930);color:#0a0a1a;text-shadow:none;box-shadow:0 0 20px #ffc85044}.btn-overlay-close{font-size:calc(9px * var(--ui-scale)) !important;padding:calc(8px * var(--ui-scale)) calc(20px * var(--ui-scale)) !important;color:#6699ff;border-color:#6699ff}.class-cards{display:flex;gap:14px;margin:16px 0;flex-wrap:wrap;justify-content:center}.class-card{width:155px;background:linear-gradient(180deg,#0e0e1e,#12101a);border:2px solid #2a2a3a;border-radius:8px;padding:14px;text-align:center;cursor:pointer;transition:all .25s;position:relative;overflow:hidden}.class-card::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,200,80,0.03),transparent 70%);opacity:0;transition:opacity .3s}.class-card:hover::before{opacity:1}.class-card:hover{border-color:#ffc850;transform:translateY(-3px);box-shadow:0 8px 24px #0004}.class-card.selected{border-color:#ffc850;background:linear-gradient(180deg,#1a1520,#14101e);box-shadow:0 0 20px #ffc85022}.class-card h3{font-size:12px;margin-bottom:6px}.class-card canvas{margin:6px auto;display:block}.class-card p{font-size:8px;color:#776;line-height:1.8}.class-card .class-stats{font-size:8px;color:#998;margin-top:6px;line-height:2}.controls-hint{margin-top:16px;font-size:8px;color:#443;text-align:center;line-height:2.2}#shop-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(8,8,26,0.95);z-index:200;display:none;flex-direction:column;align-items:center;justify-content:center}#shop-overlay h2{color:#ffc850;font-size:calc(18px * var(--ui-scale));margin-bottom:calc(12px * var(--ui-scale));text-shadow:0 0 16px #ff880033}.shop-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:calc(8px * var(--ui-scale));max-width:calc(460px * var(--ui-scale));margin-bottom:calc(12px * var(--ui-scale))}.shop-item{background:linear-gradient(180deg,#111120,#0d0d18);border:1px solid #2a2a3a;border-radius:calc(6px * var(--ui-scale));padding:calc(8px * var(--ui-scale)) calc(12px * var(--ui-scale));cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:calc(8px * var(--ui-scale))}.shop-item:hover{border-color:#ffc850;box-shadow:0 0 12px #ffc85022}.shop-item.too-expensive{opacity:.35;cursor:not-allowed}.shop-item .item-icon{width:calc(32px * var(--ui-scale));height:calc(32px * var(--ui-scale));image-rendering:pixelated}.shop-item .item-info{flex:1}.shop-item .item-name{font-size:calc(8px * var(--ui-scale));color:#ddc}.shop-item .item-desc{font-size:calc(7px * var(--ui-scale));color:#776;margin-top:calc(2px * var(--ui-scale))}.shop-item .item-price{font-size:calc(9px * var(--ui-scale));color:#ffc850;white-space:nowrap}.shop-item .sell-price{color:#6d6}.shop-item:active{background:#1a1a2e}.shop-tabs{display:flex;gap:calc(6px * var(--ui-scale));margin-bottom:calc(10px * var(--ui-scale));justify-content:center}.shop-tab{font-family:'Press Start 2P',monospace;font-size:calc(9px * var(--ui-scale));padding:calc(6px * var(--ui-scale)) calc(20px * var(--ui-scale));background:#111120;border:1px solid #333;color:#776;border-radius:calc(4px * var(--ui-scale));cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.shop-tab.active{border-color:#ffc850;color:#ffc850;background:#1a1520}.shop-tab:active{background:#222}.shop-empty{grid-column:1 / -1;text-align:center;font-size:calc(8px * var(--ui-scale));color:#554;padding:calc(20px * var(--ui-scale)) 0}#shop-content{max-height:60vh;overflow-y:auto;width:90%;max-width:calc(460px * var(--ui-scale));margin-bottom:calc(10px * var(--ui-scale))}#shop-content .shop-grid{max-width:100%}#shop-gold{color:#ffc850;font-size:calc(10px * var(--ui-scale));margin-bottom:calc(8px * var(--ui-scale))}#mobile-controls{display:none;width:100%;max-width:640px;justify-content:space-between;align-items:center;padding:6px 16px;gap:8px;touch-action:none}.mobile-left{display:flex;align-items:center;justify-content:center;width:140px;height:140px;touch-action:none}#joystick-canvas{image-rendering:auto;touch-action:none}.mobile-right{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.action-btn{font-family:'Press Start 2P',monospace;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:background 0.1s,transform 0.1s}.action-btn:active{transform:scale(0.92)}.action-interact{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(255,200,80,0.25),rgba(255,160,40,0.08));border:3px solid rgba(255,200,80,0.5);color:#ffc850;font-size:10px;text-shadow:0 0 6px rgba(255,200,80,0.3);box-shadow:0 0 12px rgba(255,200,80,0.1)}.action-interact:active{background:radial-gradient(circle at 35% 35%,rgba(255,200,80,0.5),rgba(255,160,40,0.2));border-color:#ffc850;box-shadow:0 0 20px rgba(255,200,80,0.3)}.action-equip{width:52px;height:52px;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(187,102,255,0.2),rgba(140,80,220,0.06));border:2px solid rgba(187,102,255,0.45);color:#bb88ff;font-size:9px;text-shadow:0 0 6px rgba(187,102,255,0.3);box-shadow:0 0 10px rgba(187,102,255,0.08)}.action-equip:active{background:radial-gradient(circle at 35% 35%,rgba(187,102,255,0.45),rgba(140,80,220,0.15));border-color:#bb66ff;box-shadow:0 0 16px rgba(187,102,255,0.25)}#game-area{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;width:100%;min-height:0}@media (max-width:680px){body{justify-content:flex-start;padding-top:0}#game-area{flex:1;justify-content:center;min-height:0}.screen h1{font-size:18px;margin-bottom:2px}.screen .subtitle{font-size:8px;margin-bottom:8px}.class-cards{gap:6px;margin:6px 0}.class-card{width:130px;padding:8px}.class-card h3{font-size:10px}.class-card p{font-size:7px}.class-card .class-stats{font-size:7px}.controls-hint{font-size:7px;line-height:1.8}.btn{font-size:10px;padding:8px 20px}#hud{width:100% !important;max-width:100vw;padding:0 4px}#skill-bar{flex-wrap:wrap;padding:0 4px;max-width:100vw}#skill-bar span{min-height:calc(28px * var(--ui-scale));display:flex;align-items:center}#log{padding:0 4px}.shop-grid{grid-template-columns:1fr;max-width:90vw;max-height:50vh;overflow-y:auto}#mobile-controls{width:100%;padding:4px 12px;padding-bottom:calc(4px+env(safe-area-inset-bottom))}}@media (max-height:500px) and (orientation:landscape){#mobile-controls{padding:2px 8px}.mobile-left{width:100px !important;height:100px !important}#joystick-canvas{width:100px !important;height:100px !important}.action-interact{width:56px !important;height:56px !important;font-size:8px}.action-equip{width:40px !important;height:40px !important;font-size:7px}}#equip-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(8,8,26,0.96);z-index:200;display:none;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:calc(20px * var(--ui-scale));overflow-y:auto;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}#equip-overlay h2{color:#bb66ff;font-size:calc(16px * var(--ui-scale));margin-bottom:calc(10px * var(--ui-scale));text-shadow:0 0 12px #bb66ff33}.equip-section{max-width:calc(500px * var(--ui-scale));width:90%;margin-bottom:calc(10px * var(--ui-scale))}.equip-section h3{font-size:calc(10px * var(--ui-scale));color:#998;margin-bottom:calc(6px * var(--ui-scale));border-bottom:1px solid #222;padding-bottom:calc(4px * var(--ui-scale))}.equip-slots{display:flex;flex-direction:column;gap:calc(6px * var(--ui-scale))}.equip-slot{background:linear-gradient(180deg,#111120,#0d0d18);border:1px solid #2a2a3a;border-radius:calc(6px * var(--ui-scale));padding:calc(8px * var(--ui-scale)) calc(12px * var(--ui-scale));cursor:pointer;transition:all .15s}.equip-slot:hover{border-color:#bb66ff;box-shadow:0 0 8px #bb66ff22}.equip-slot.empty{opacity:0.5}.eq-name{font-size:calc(9px * var(--ui-scale));font-weight:bold}.eq-info{font-size:calc(8px * var(--ui-scale));color:#aaa;margin-top:calc(2px * var(--ui-scale))}.eq-affixes{color:#bb88ff;font-size:calc(7px * var(--ui-scale))}.eq-rarity{font-size:calc(7px * var(--ui-scale));margin-top:calc(2px * var(--ui-scale))}.eq-hint{font-size:calc(7px * var(--ui-scale));color:#555;margin-top:calc(2px * var(--ui-scale))}.eq-empty-name{font-size:calc(9px * var(--ui-scale));color:#555}.equip-total{font-size:calc(8px * var(--ui-scale));color:#998;margin-top:calc(6px * var(--ui-scale));line-height:1.8}.bag-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:calc(5px * var(--ui-scale))}.bag-slot{background:linear-gradient(180deg,#0e0e1a,#0a0a14);border:1px solid #222;border-radius:calc(4px * var(--ui-scale));padding:calc(6px * var(--ui-scale));min-height:calc(64px * var(--ui-scale));cursor:pointer;transition:all .15s;text-align:center;position:relative}.bag-slot.filled:hover{box-shadow:0 0 8px #ffc85033;transform:translateY(-1px)}.bag-slot.filled:active{background:#16162a}.bag-slot.empty{opacity:0.3;cursor:default}.bag-icon img{width:calc(28px * var(--ui-scale));height:calc(28px * var(--ui-scale))}.bag-name{font-size:calc(7px * var(--ui-scale));margin-top:calc(2px * var(--ui-scale));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bag-info{font-size:calc(6px * var(--ui-scale));color:#776}.equip-detail-popup{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(4,4,16,0.92);z-index:300;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(16px * var(--ui-scale));-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.equip-detail-card{background:linear-gradient(180deg,#12101e,#0a0a14);border:2px solid #2a2a3a;border-radius:calc(8px * var(--ui-scale));padding:calc(16px * var(--ui-scale));max-width:calc(320px * var(--ui-scale));width:90%;text-align:center}.equip-detail-card .ed-name{font-size:calc(12px * var(--ui-scale));font-weight:bold;margin-bottom:calc(6px * var(--ui-scale))}.equip-detail-card .ed-rarity{font-size:calc(8px * var(--ui-scale));margin-bottom:calc(8px * var(--ui-scale))}.equip-detail-card .ed-base{font-size:calc(9px * var(--ui-scale));color:#ccc;margin-bottom:calc(4px * var(--ui-scale))}.equip-detail-card .ed-affixes{font-size:calc(8px * var(--ui-scale));color:#bb88ff;line-height:2;margin-bottom:calc(10px * var(--ui-scale))}.equip-detail-card .ed-slot{font-size:calc(8px * var(--ui-scale));color:#776;margin-bottom:calc(12px * var(--ui-scale))}.equip-detail-card .ed-actions{display:flex;gap:calc(8px * var(--ui-scale));justify-content:center;flex-wrap:wrap}.equip-detail-card .ed-btn{font-family:'Press Start 2P',monospace;font-size:calc(9px * var(--ui-scale));padding:calc(8px * var(--ui-scale)) calc(16px * var(--ui-scale));border-radius:calc(4px * var(--ui-scale));border:1px solid #333;background:#1a1a2e;color:#ccc;cursor:pointer;min-width:calc(80px * var(--ui-scale));touch-action:manipulation;-webkit-tap-highlight-color:transparent}.equip-detail-card .ed-btn-equip{border-color:#4a4;color:#6d6}.equip-detail-card .ed-btn-equip:active{background:#1a2e1a}.equip-detail-card .ed-btn-unequip{border-color:#ffc850;color:#ffc850}.equip-detail-card .ed-btn-unequip:active{background:#2e2a1a}.equip-detail-card .ed-btn-drop{border-color:#a44;color:#d66}.equip-detail-card .ed-btn-drop:active{background:#2e1a1a}.equip-detail-card .ed-btn-cancel{border-color:#444;color:#888}.equip-detail-card .ed-btn-cancel:active{background:#222}.drag-ghost{position:fixed;transform:translate(-50%,-120%);padding:calc(4px * var(--ui-scale)) calc(10px * var(--ui-scale));background:rgba(20,16,32,0.92);border:1px solid #bb66ff;border-radius:calc(4px * var(--ui-scale));color:#ddd;font-family:'Press Start 2P',monospace;font-size:calc(8px * var(--ui-scale));pointer-events:none;z-index:400;white-space:nowrap;box-shadow:0 0 12px rgba(187,102,255,0.3)}.equip-slot.drop-highlight{border-color:#4f4 !important;box-shadow:0 0 14px rgba(80,255,80,0.35);animation:drop-pulse 0.6s ease-in-out infinite alternate}@keyframes drop-pulse{from{box-shadow:0 0 8px rgba(80,255,80,0.2)}to{box-shadow:0 0 18px rgba(80,255,80,0.5)}}#equip-content{max-height:calc(100vh - 100px);overflow-y:auto;width:90%;max-width:calc(500px * var(--ui-scale))}#user-bar{margin-bottom:10px;display:flex;align-items:center;justify-content:center;gap:6px}#user-logged-in{display:flex;align-items:center;gap:8px}#user-name-display{font-size:10px;color:#ffc850;text-shadow:0 0 6px rgba(255,200,80,0.3)}.btn-sm{font-size:8px !important;padding:5px 14px !important}.btn-ghost{background:transparent !important;border-color:#444 !important;color:#888 !important}.btn-ghost:hover{border-color:#888 !important;color:#ccc !important}.title-bottom-btns{display:flex;gap:8px;margin-top:8px;justify-content:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(4,4,16,0.94);z-index:500;display:flex;align-items:center;justify-content:center;padding:calc(16px * var(--ui-scale));-webkit-user-select:none;user-select:none}.modal-card{background:linear-gradient(180deg,#12101e,#0a0a14);border:2px solid #2a2a3a;border-radius:calc(8px * var(--ui-scale));padding:calc(20px * var(--ui-scale));max-width:calc(320px * var(--ui-scale));width:90%;text-align:center}.modal-card h3{font-size:calc(14px * var(--ui-scale));color:#ffc850;margin-bottom:calc(14px * var(--ui-scale));text-shadow:0 0 12px #ff880033}.modal-card input{font-family:'Press Start 2P',monospace;font-size:calc(9px * var(--ui-scale));width:100%;padding:calc(8px * var(--ui-scale)) calc(10px * var(--ui-scale));margin-bottom:calc(8px * var(--ui-scale));background:#0a0a18;border:1px solid #333;border-radius:calc(4px * var(--ui-scale));color:#ddd;outline:none}.modal-card input:focus{border-color:#ffc850}.auth-error{font-size:calc(8px * var(--ui-scale));color:#ff6666;min-height:calc(14px * var(--ui-scale));margin-bottom:calc(6px * var(--ui-scale))}.modal-actions{display:flex;gap:calc(8px * var(--ui-scale));justify-content:center;margin-top:calc(10px * var(--ui-scale))}.modal-wide{max-width:calc(520px * var(--ui-scale))}.leaderboard-scroll{max-height:50vh;overflow-y:auto;margin-bottom:calc(12px * var(--ui-scale))}.lb-table{width:100%;border-collapse:collapse;font-size:calc(8px * var(--ui-scale))}.lb-table th{color:#998;font-weight:normal;padding:calc(4px * var(--ui-scale)) calc(6px * var(--ui-scale));border-bottom:1px solid #222;text-align:center;white-space:nowrap}.lb-table td{padding:calc(5px * var(--ui-scale)) calc(6px * var(--ui-scale));border-bottom:1px solid #1a1a2a;text-align:center;color:#aaa}.lb-table tr:nth-child(-n+3) td:first-child{font-weight:bold}.lb-table tr:nth-child(1) td:first-child{color:#ffc850}.lb-table tr:nth-child(2) td:first-child{color:#c0c0c0}.lb-table tr:nth-child(3) td:first-child{color:#cd7f32}.lb-table .lb-name{color:#ddc;text-align:left}.lb-table .lb-floor{color:#cc88ff;font-weight:bold}.lb-table .lb-self{background:rgba(255,200,80,0.06)}.lb-empty{color:#554;font-size:calc(9px * var(--ui-scale));padding:calc(30px * var(--ui-scale)) 0}.save-indicator{position:fixed;top:8px;right:12px;font-family:'Press Start 2P',monospace;font-size:calc(7px * var(--ui-scale));color:#4a4;opacity:0;transition:opacity 0.3s;z-index:150;pointer-events:none}.save-indicator.show{opacity:1}@media (max-width:400px){.class-cards{flex-direction:column;align-items:center}.class-card{width:90%}.mobile-left{width:120px;height:120px}#joystick-canvas{width:120px;height:120px}.action-interact{width:60px;height:60px;font-size:9px}.action-equip{width:44px;height:44px;font-size:8px}.modal-card{padding:14px}.modal-card h3{font-size:12px}}