@import "https://fonts.googleapis.com/css2?family=Cinzel:wght@400;700&family=Noto+Sans+TC:wght@400;700&display=swap";:root{--bg-deep:#0a0a14;--bg-panel:#12121f;--bg-card:#1a1a2e;--bg-card-hover:#22223a;--accent-red:#e94560;--accent-red-dim:#8a1f30;--accent-gold:#f5a623;--accent-blue:#3a7fdf;--accent-mp:#4a9eff;--accent-heal:#4aff9f;--text-primary:#e8e8e8;--text-muted:#7a7a9a;--border:#2a2a4a;--hp-color:#e94560;--mp-color:#4a9eff;--xp-color:#f5a623}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-deep);color:var(--text-primary);min-height:100vh;font-family:Noto Sans TC,sans-serif}h1,h2,h3{font-family:Cinzel,serif}button{cursor:pointer;font-family:Noto Sans TC,sans-serif}input,select{font-family:Noto Sans TC,sans-serif}.page{max-width:900px;min-height:100vh;margin:0 auto;padding:20px}.page-title{text-align:center;color:var(--accent-gold);text-shadow:0 0 20px #f5a62366;margin-bottom:2rem;font-size:2rem}.auth-page{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-logo{color:var(--accent-gold);text-shadow:0 0 30px #f5a62380;margin-bottom:.5rem;font-family:Cinzel,serif;font-size:2.5rem}.auth-subtitle{color:var(--text-muted);margin-bottom:2rem;font-size:.9rem}.auth-tabs{border:1px solid var(--border);border-radius:8px;gap:0;margin-bottom:1.5rem;display:flex;overflow:hidden}.auth-tab{background:var(--bg-panel);color:var(--text-muted);border:none;padding:8px 24px;font-size:.9rem;transition:all .2s}.auth-tab.active{background:var(--accent-red);color:#fff}.auth-form{flex-direction:column;gap:12px;width:100%;max-width:360px;display:flex}.auth-input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:6px;width:100%;padding:12px 16px;font-size:1rem;transition:border-color .2s}.auth-input:focus{border-color:var(--accent-red);outline:none}.auth-btn{background:var(--accent-red);color:#fff;border:none;border-radius:6px;padding:12px;font-size:1rem;font-weight:700;transition:all .2s}.auth-btn:hover{background:#ff5a75;transform:translateY(-1px)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:var(--accent-red);text-align:center;font-size:.85rem}.auth-link{color:var(--accent-gold);text-align:center;cursor:pointer;margin-top:1rem;font-size:.8rem}.class-page{padding:20px}.class-page .page-title{margin-bottom:1rem}.class-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:1rem;display:grid}.class-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:12px;padding:20px;transition:all .2s;position:relative;overflow:hidden}.class-card:hover{border-color:var(--accent-red);transform:translateY(-2px);box-shadow:0 8px 30px #e9456033}.class-card.selected{border-color:var(--accent-gold);box-shadow:0 0 20px #f5a6234d}.class-icon{margin-bottom:8px;font-size:2.5rem}.class-name{color:var(--accent-gold);margin-bottom:4px;font-family:Cinzel,serif;font-size:1.3rem}.class-name-en{color:var(--text-muted);margin-bottom:10px;font-size:.75rem}.class-desc{color:var(--text-muted);margin-bottom:10px;font-size:.8rem;line-height:1.4}.class-stats{flex-direction:column;gap:5px;display:flex}.stat-row{align-items:center;gap:8px;font-size:.78rem;display:flex}.stat-label{color:var(--text-muted);width:40px}.stat-bar{background:var(--bg-deep);border-radius:2px;flex:1;height:4px;overflow:hidden}.stat-fill{border-radius:2px;height:100%}.stat-fill.hp{background:var(--hp-color)}.stat-fill.mp{background:var(--mp-color)}.stat-fill.atk{background:#ff8c00}.stat-fill.def{background:#9a6aff}.stat-fill.spd{background:#4aff9f}.class-skills{flex-wrap:wrap;gap:4px;margin-top:10px;display:flex}.skill-tag{background:var(--bg-deep);border:1px solid var(--border);color:var(--accent-blue);border-radius:4px;padding:2px 8px;font-size:.7rem}.name-input-wrap{text-align:center;margin:1.5rem 0}.name-input-wrap input{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);text-align:center;border-radius:6px;width:240px;padding:10px 16px;font-size:1rem}.name-input-wrap input:focus{border-color:var(--accent-gold);outline:none}.start-btn{background:linear-gradient(135deg, var(--accent-red), #c0354a);color:#fff;letter-spacing:2px;border:none;border-radius:8px;margin:1rem auto 0;padding:14px 40px;font-size:1.1rem;font-weight:700;transition:all .2s;display:block;box-shadow:0 4px 20px #e9456066}.start-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px #e9456080}.game-layout{flex-direction:column;height:100vh;display:flex}.game-topbar{background:var(--bg-panel);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 16px;display:flex}.hp-bar-wrap,.mp-bar-wrap{flex:1;align-items:center;gap:8px;display:flex}.bar-label{width:24px;color:var(--text-muted);font-size:.7rem}.bar-track{background:var(--bg-deep);border-radius:4px;flex:1;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .3s}.bar-fill.hp{background:linear-gradient(90deg,#e94560,#ff8c94)}.bar-fill.mp{background:linear-gradient(90deg,#3a7fdf,#4a9eff)}.bar-text{text-align:right;width:60px;color:var(--text-muted);font-size:.7rem}.topbar-info{color:var(--accent-gold);gap:12px;font-size:.8rem;display:flex}.topbar-info span{background:var(--bg-card);border-radius:4px;padding:4px 10px}.game-main{flex:1;overflow-y:auto}.dungeon-map{flex-direction:column;align-items:center;gap:16px;padding:20px;display:flex}.floor-header{text-align:center}.floor-title{color:var(--accent-gold);font-family:Cinzel,serif;font-size:1.5rem}.floor-theme{color:var(--text-muted);margin-top:4px;font-size:.8rem}.map-grid{background:var(--bg-panel);border:2px solid var(--border);aspect-ratio:16/10;border-radius:8px;grid-template-columns:repeat(16,1fr);gap:1px;width:100%;max-width:600px;display:grid;overflow:hidden}.map-cell{background:var(--bg-card);justify-content:center;align-items:center;font-size:.6rem;display:flex}.map-cell.wall{background:#1a1a2e}.map-cell.player{background:var(--accent-blue);border-radius:50%;width:70%;height:70%;box-shadow:0 0 8px #3a7fdfcc}.map-cell.enemy{background:var(--accent-red-dim);border-radius:2px}.map-cell.exit{background:#1a2a1a}.explore-btn{background:var(--accent-red);color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:1rem;font-weight:700;transition:all .2s;box-shadow:0 4px 20px #e945604d}.explore-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #e9456066}.floor-progress{width:100%;max-width:600px}.floor-progress-track{background:var(--bg-deep);border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.floor-progress-fill{background:var(--accent-gold);border-radius:2px;height:100%;transition:width .5s}.combat-page{flex-direction:column;gap:12px;height:100%;padding:16px;display:flex}.combat-enemies{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.enemy-card{background:var(--bg-card);border:1px solid var(--accent-red);text-align:center;border-radius:8px;width:140px;padding:12px;transition:all .15s}.enemy-card.hit{animation:.15s hitFlash}.enemy-card.dead{opacity:.3}@keyframes hitFlash{0%,to{background:var(--bg-card)}50%{background:var(--accent-red)}}.enemy-name{color:var(--accent-red);margin-bottom:6px;font-size:.85rem}.enemy-hp-bar{background:var(--bg-deep);border-radius:3px;height:6px;overflow:hidden}.enemy-hp-fill{background:var(--accent-red);height:100%;transition:width .3s}.enemy-hp-text{color:var(--text-muted);margin-top:4px;font-size:.7rem}.combat-log{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;flex:1;max-height:120px;padding:10px;overflow-y:auto}.log-entry{border-bottom:1px solid var(--border);color:var(--text-muted);padding:3px 0;font-size:.78rem}.log-entry:last-child{border:none}.log-entry.crit{color:var(--accent-gold)}.log-entry.dodge{color:var(--accent-blue)}.log-entry.heal{color:var(--accent-heal)}.log-entry.kill{color:var(--accent-red);font-weight:700}.combat-actions{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.action-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;padding:10px;font-size:.85rem;transition:all .15s}.action-btn:hover{border-color:var(--accent-red);background:var(--bg-card-hover)}.action-btn.active{background:var(--accent-red);border-color:var(--accent-red)}.action-btn:disabled{opacity:.4;cursor:not-allowed}.skill-panel{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:8px;display:flex}.skill-btn{background:var(--bg-card);border:1px solid var(--accent-blue);color:var(--mp-color);border-radius:6px;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;font-size:.8rem;transition:all .15s;display:flex}.skill-btn:hover{background:var(--accent-blue);color:#fff}.skill-btn:disabled{opacity:.4;cursor:not-allowed}.skill-mp{font-size:.65rem}.story-overlay{z-index:100;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.story-card{background:var(--bg-panel);border:1px solid var(--accent-gold);border-radius:16px;width:100%;max-width:560px;padding:32px;box-shadow:0 0 60px #f5a62333}.story-title{color:var(--accent-gold);text-align:center;margin-bottom:16px;font-family:Cinzel,serif;font-size:1.5rem}.story-text{color:var(--text-primary);white-space:pre-line;margin-bottom:20px;font-size:.95rem;line-height:1.8}.story-continue-btn{background:var(--accent-gold);color:#000;border:none;border-radius:8px;width:100%;padding:12px;font-size:1rem;font-weight:700;transition:all .2s}.story-continue-btn:hover{background:#ffc040}.levelup-overlay{z-index:100;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.levelup-card{background:var(--bg-panel);border:2px solid var(--accent-gold);text-align:center;border-radius:16px;padding:32px;animation:1s ease-out levelupGlow;box-shadow:0 0 80px #f5a62366}@keyframes levelupGlow{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.levelup-title{color:var(--accent-gold);text-shadow:0 0 30px #f5a62399;margin-bottom:20px;font-family:Cinzel,serif;font-size:2rem}.levelup-stats{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.levelup-stat{justify-content:space-between;font-size:.9rem;display:flex}.levelup-old{color:var(--text-muted);text-decoration:line-through}.levelup-new{color:var(--accent-heal);font-weight:700}.gameover-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100vh;display:flex}.gameover-title{color:var(--accent-red);text-shadow:0 0 30px #e9456080;font-family:Cinzel,serif;font-size:2.5rem}.gameover-sub{color:var(--text-muted);font-size:1rem}.gameover-stats{color:var(--accent-gold);font-size:1.1rem}.gameover-btn{background:var(--accent-red);color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:1rem}.lb-page{padding:20px}.lb-title{color:var(--accent-gold);text-align:center;margin-bottom:1.5rem;font-family:Cinzel,serif;font-size:1.5rem}.lb-table{border-collapse:collapse;width:100%}.lb-table th{color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:8px;font-size:.75rem}.lb-table td{border-bottom:1px solid var(--border);padding:10px 8px;font-size:.85rem}.lb-rank{color:var(--accent-gold);width:30px;font-weight:700}.lb-floor{color:var(--accent-red);font-weight:700}.game-nav{border-top:1px solid var(--border);background:var(--bg-panel);display:flex}.nav-btn{color:var(--text-muted);background:0 0;border:none;border-top:2px solid #0000;flex:1;padding:12px;font-size:.8rem;transition:all .2s}.nav-btn:hover{color:var(--text-primary)}.nav-btn.active{color:var(--accent-gold);border-top-color:var(--accent-gold)}
