*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;overflow:hidden}body{font-family:Microsoft YaHei,sans-serif;background:#1a1a2e;color:#fff}@media screen and (max-width: 768px){.game-wrapper{height:calc(100vh - 50px);overflow-y:auto;-webkit-overflow-scrolling:touch}.top-bar{height:44px;padding:0 10px}.game-title{font-size:16px}.top-btn{padding:4px 8px;font-size:12px}.chapter-info{padding:6px}.chapter-name{font-size:14px}.stage-info{font-size:11px}.battle-scene{height:70px}.player-char,.enemy-char{font-size:32px}.status-panel{padding:8px;gap:8px}.status-card{padding:8px}.status-name{font-size:12px}.hp-bar-container{height:12px}.hp-text{font-size:10px}.skill-slots{gap:4px;margin-top:6px;transform-origin:center center}.skill-btn{width:36px;height:36px;font-size:18px}@media (max-width: 360px){.skill-slots{transform:scale(.82)}}@media (min-width: 361px) and (max-width: 380px){.skill-slots{transform:scale(.85)}}@media (min-width: 381px) and (max-width: 420px){.skill-slots{transform:scale(.88)}}@media (min-width: 421px) and (max-width: 440px){.skill-slots{transform:scale(.9)}}@media (min-width: 441px) and (max-width: 480px){.skill-slots{transform:scale(.92)}}@media (min-width: 481px){.skill-slots{transform:scale(1)}}.enemy-skill{width:32px;height:32px;margin-top:4px}.enemy-skill .skill-icon{font-size:16px}.orb-board{gap:1px;padding:3px;width:100%;max-width:280px;margin:0 auto;box-sizing:border-box;transform-origin:center center}@media (max-width: 360px){.orb-board{transform:scale(.75)}}@media (min-width: 361px) and (max-width: 380px){.orb-board{transform:scale(.78)}}@media (min-width: 381px) and (max-width: 420px){.orb-board{transform:scale(.82)}}@media (min-width: 421px) and (max-width: 440px){.orb-board{transform:scale(.85)}}@media (min-width: 441px) and (max-width: 480px){.orb-board{transform:scale(.88)}}@media (min-width: 481px) and (max-width: 768px){.orb-board{transform:scale(.92)}}@media (min-width: 769px) and (max-width: 1024px){.orb-board{transform:scale(.96)}}@media (min-width: 1025px){.orb-board{transform:scale(1)}}.orb{width:28px;height:28px;font-size:14px;border-width:1px}.battle-log-section{padding:6px 10px}.battle-log{max-height:60px;font-size:10px}.game-area{padding:8px;justify-content:center}.game-area>div:first-child{font-size:12px;margin-bottom:8px}}.top-bar{position:fixed;top:0;left:0;right:0;height:50px;background:linear-gradient(90deg,#1a1a3e,#16213e);display:flex;justify-content:space-between;align-items:center;padding:0 15px;z-index:1000;border-bottom:none}@media screen and (max-width: 768px){.top-bar{height:40px;padding:0 10px;padding-top:env(safe-area-inset-top);border-bottom:none}}.game-title{font-size:18px;font-weight:700;color:#e94560;display:flex;align-items:center;gap:8px}.top-actions{display:flex;gap:10px}.top-btn{background:#e9456033;border:1px solid rgba(233,69,96,.5);color:#fff;padding:6px 12px;border-radius:20px;cursor:pointer;font-size:13px;transition:all .3s}.top-btn:hover{background:#e9456066}.game-wrapper{padding-top:50px;height:100vh;display:flex;flex-direction:column;overflow:hidden}@media screen and (max-width: 768px){.game-wrapper{padding-top:44px;height:100vh;height:100dvh}}.chapter-info{position:absolute;top:45px;left:50%;transform:translate(-50%);text-align:center;padding:6px 15px;background:#0009;border-bottom:none;z-index:100;border-radius:20px;margin:0 auto;min-width:150px}@media screen and (max-width: 768px){.chapter-info{padding:4px}.chapter-name{font-size:14px}.stage-info{font-size:10px}}.chapter-name{font-size:18px;color:#f39c12;font-weight:700}.stage-info{font-size:12px;color:#888;margin-top:4px}.battle-scene{position:relative;height:100px;background:linear-gradient(180deg,#0f0f23,#1a1a3e,#2a2a4a);border-bottom:none;overflow:visible;transition:background .5s ease;margin-top:-10px}.battle-scene[data-region=forest]{background:linear-gradient(180deg,#0f2315,#1a3e2e,#2a4a3a)}.battle-scene[data-region=cave]{background:linear-gradient(180deg,#1a1a1a,#2a2a2a,#3a3a3a)}.battle-scene[data-region=castle]{background:linear-gradient(180deg,#231515,#3e1a1a,#4a2a2a)}.battle-scene[data-region=ice]{background:linear-gradient(180deg,#0f1523,#1a253e,#2a354a)}.battle-scene[data-region=volcano]{background:linear-gradient(180deg,#23150f,#3e1a1a,#4a2a1a)}.battle-scene[data-region=desert]{background:linear-gradient(180deg,#231f0f,#3e351a,#4a452a)}.battle-scene[data-region=swamp]{background:linear-gradient(180deg,#0f2318,#1a3e28,#2a4a38)}.battle-scene[data-region=sky]{background:linear-gradient(180deg,#0f1a23,#1a2e3e,#2a3e4a)}.battle-scene[data-region=abyss]{background:linear-gradient(180deg,#0a0a0a,#151515,#1a1a1a)}.battle-scene[data-region=holy]{background:linear-gradient(180deg,#1a1a2e,#2a2a4e,#3a3a6e)}@media screen and (max-width: 768px){.battle-scene{height:100px}.player-char,.enemy-char{font-size:32px;bottom:30px}.player-char .career-name,.enemy-char .enemy-name{font-size:9px;bottom:-14px}}.player-char{position:absolute;left:20px;bottom:20px;font-size:40px;filter:drop-shadow(0 0 10px rgba(52,152,219,.8));animation:playerIdle 2s ease-in-out infinite;cursor:pointer;transition:transform .2s}.player-char:hover{transform:scale(1.1)}.player-char .career-name{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-size:10px;color:#64c8ff;white-space:nowrap;text-shadow:0 0 5px rgba(0,0,0,.8)}.enemy-char{position:absolute;right:20px;bottom:20px;font-size:45px;filter:drop-shadow(0 0 10px rgba(231,76,60,.8));animation:enemyIdle 2s ease-in-out infinite;cursor:pointer;transition:transform .2s}.enemy-char:hover{transform:scale(1.1) scaleX(-1)}.enemy-char .enemy-name{position:absolute;bottom:-18px;left:50%;transform:translate(-50%) scaleX(-1);font-size:10px;color:#e94560;white-space:nowrap;text-shadow:0 0 5px rgba(0,0,0,.8)}@keyframes playerIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes enemyIdle{0%,to{transform:translateY(0) scaleX(-1)}50%{transform:translateY(-5px) scaleX(-1)}}.status-panel{display:flex;justify-content:space-between;padding:8px 12px;background:#00000080;gap:10px}@media screen and (max-width: 768px){.status-panel{padding:3px 4px;gap:3px;transform:scale(.92);transform-origin:center top}.status-card{padding:3px;min-width:0;flex:1}.status-name{font-size:9px;margin-bottom:1px}.hp-bar-container{height:6px;margin-bottom:1px}.hp-text{font-size:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.detail-btn{font-size:8px;right:1px;top:1px}.attack-timer{font-size:7px;margin-top:1px}.enemy-skill{width:20px;height:20px;margin-top:1px}.enemy-skill .skill-icon{font-size:10px}.enemy-skill .skill-lv{font-size:6px}.skill-slots{gap:1px;margin-top:2px}.skill-btn{width:22px;height:22px;font-size:11px}}.status-card{flex:1;background:#ffffff0d;border-radius:8px;padding:10px;border:1px solid rgba(255,255,255,.1);position:relative}.status-name{font-size:14px;font-weight:700;margin-bottom:5px}.status-name.player{color:#3498db}.status-name.enemy{color:#e74c3c}.detail-btn{position:absolute;right:10px;top:10px;font-size:12px;cursor:pointer;opacity:.7}.detail-btn:hover{opacity:1}.hp-bar-container{height:16px;background:#00000080;border-radius:8px;overflow:hidden;margin-bottom:4px;border:1px solid rgba(255,255,255,.1)}.hp-bar{height:100%;transition:width .5s cubic-bezier(.4,0,.2,1);border-radius:8px;position:relative;overflow:hidden}.hp-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:hpBarShine 2s infinite}@keyframes hpBarShine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.hp-bar.player{background:linear-gradient(90deg,#27ae60,#2ecc71)}.hp-bar.player.hp-change{animation:hpChangeGreen .5s ease-out}.hp-bar.enemy{background:linear-gradient(90deg,#c0392b,#e74c3c)}.hp-bar.enemy.hp-change{animation:hpChangeRed .5s ease-out}@keyframes hpChangeGreen{0%{filter:brightness(1)}50%{filter:brightness(1.5);box-shadow:0 0 10px #2ecc71}to{filter:brightness(1)}}@keyframes hpChangeRed{0%{filter:brightness(1)}50%{filter:brightness(1.5);box-shadow:0 0 10px #e74c3c}to{filter:brightness(1)}}.hp-text{font-size:11px;color:#fff;text-align:center;margin-top:2px}.bar-container{position:relative;height:18px;background:#00000080;border-radius:9px;overflow:hidden;margin-bottom:4px;border:1px solid rgba(255,255,255,.1)}.bar-container .bar{position:absolute;left:0;top:0;height:100%;transition:width .3s;border-radius:9px}.bar-container .bar-text{position:absolute;left:6px;top:50%;transform:translateY(-50%);font-size:11px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8);z-index:1;white-space:nowrap}.hp-container .bar{background:linear-gradient(90deg,#27ae60,#2ecc71)}.mp-container .bar{background:linear-gradient(90deg,#3498db,#64c8ff)}.exp-container .bar{background:linear-gradient(90deg,#f39c12,#f1c40f)}.enemy-hp-container .bar{background:linear-gradient(90deg,#c0392b,#e74c3c)}.attack-timer{font-size:10px;color:#f39c12;text-align:center;margin-top:2px}.skill-slots{display:flex;gap:8px;justify-content:center;margin-top:5px}.skill-wrapper{display:flex;flex-direction:column;align-items:center}.skill-btn{width:40px;height:40px;border-radius:8px;background:#00000080;border:2px solid rgba(100,200,255,.3);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .3s;position:relative}.skill-btn:hover:not(:disabled){border-color:#64c8ff99;transform:translateY(-2px)}.skill-btn:disabled{cursor:not-allowed}.skill-btn .skill-icon{font-size:20px}.skill-btn .skill-lv{position:absolute;bottom:2px;right:2px;font-size:9px;color:#f39c12;background:#0009;padding:0 3px;border-radius:3px}.skill-wrapper .skill-info{display:flex;flex-direction:column;align-items:center;line-height:1.2;margin-top:2px}.skill-wrapper .skill-name{font-size:10px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.skill-wrapper .skill-meta{font-size:9px;color:#64c8ff}.skill-empty{border-style:dashed;border-color:#ffffff4d;background:#ffffff0d}@media screen and (max-width: 768px){.skill-empty{border-color:#fff3;background:#ffffff08}}.game-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;gap:8px;min-height:0}@media screen and (max-width: 768px){.game-area{padding:4px;gap:2px;justify-content:center}}.orb-board{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;padding:15px;background:#0006;border-radius:12px;border:2px solid rgba(233,69,96,.3);margin:0 auto;max-width:fit-content;box-sizing:border-box;align-self:center}.orb{width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:26px;transition:all .2s;border:2px solid rgba(255,255,255,.1);-webkit-user-select:none;user-select:none}.orb:hover{transform:scale(1.1)}.orb.selected{border-color:#f39c12;box-shadow:0 0 15px #f39c1280}.orb.matched{animation:matchPulse .3s}@keyframes matchPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(0)}}.orb-red{background:linear-gradient(135deg,#e74c3c,#c0392b)}.orb-blue{background:linear-gradient(135deg,#3498db,#2980b9)}.orb-green{background:linear-gradient(135deg,#27ae60,#229954)}.orb-yellow{background:linear-gradient(135deg,#f1c40f,#d4ac0d)}.orb-purple{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.orb-heart{background:linear-gradient(135deg,#e91e63,#c2185b)}.battle-log-section{padding:8px 15px;flex-shrink:0}@media screen and (max-width: 768px){.battle-log-section{padding:4px 10px;padding-bottom:calc(4px + env(safe-area-inset-bottom))}}.battle-log{width:100%;max-height:80px;overflow-y:auto;background:#0000004d;border-radius:6px;padding:8px;font-size:11px}.log-entry{padding:3px 0;border-bottom:1px solid rgba(255,255,255,.05)}.log-entry.log-match{color:#64c8ff}.log-entry.log-damage{color:#e74c3c}.log-entry.log-heal{color:#2ecc71}.log-entry.log-enemy{color:#f39c12}.log-entry.log-levelup{color:#f1c40f;font-weight:700}.log-entry.log-player{color:#74b9ff;font-weight:500}.log-entry.log-reward{color:#9b59b6}.log-entry.log-system{color:#95a5a6}.log-entry.log-orb-sword{color:#ff6b6b;font-weight:500}.log-entry.log-orb-magic{color:#a29bfe;font-weight:500}.log-entry.log-orb-shield{color:#4ecdc4;font-weight:500}.log-entry.log-orb-heart{color:#55efc4;font-weight:500}.log-entry.log-orb-coin,.log-entry.log-orb-star{color:#ffeaa7;font-weight:500}.log-entry.log-orb-skull{color:#a29bfe;font-weight:500}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;z-index:2000;display:flex;justify-content:center;align-items:center}.modal-overlay:not(.active){display:none}.modal-box{background:linear-gradient(135deg,#1a1a3e,#16213e);border:2px solid rgba(100,200,255,.3);border-radius:16px;padding:25px;max-width:400px;width:90%;text-align:center}.modal-btn{background:linear-gradient(135deg,#64c8ff,#a855f7);border:none;border-radius:8px;color:#fff;padding:12px 20px;cursor:pointer;font-size:14px;margin:5px;transition:all .3s}.modal-btn:hover{transform:translateY(-2px);box-shadow:0 5px 20px #64c8ff66}.game-over-box{background:linear-gradient(135deg,#1a1a3e,#0d0d2a);border:2px solid rgba(255,107,107,.4);border-radius:20px;padding:35px 30px;max-width:380px;width:90%;text-align:center;box-shadow:0 20px 60px #00000080,0 0 30px #ff6b6b1a}.game-over-box h2{font-size:28px;margin-bottom:25px;color:#fff;text-shadow:0 0 20px rgba(255,107,107,.5)}.game-over-stats{background:#0000004d;border-radius:12px;padding:20px;margin-bottom:25px;border:1px solid rgba(255,255,255,.1)}.game-over-stats>div{padding:10px 0;font-size:15px;color:#ccc;border-bottom:1px solid rgba(255,255,255,.05)}.game-over-stats>div:last-child{border-bottom:none}.game-over-stats .score{color:gold;font-weight:700;font-size:18px;text-shadow:0 0 10px rgba(255,215,0,.3)}.game-over-box .modal-btn{background:linear-gradient(135deg,#ff6b6b,#ee5a5a);border:none;border-radius:10px;color:#fff;padding:14px 35px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #ff6b6b4d}.game-over-box .modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 25px #ff6b6b80;background:linear-gradient(135deg,#ff7b7b,#ee6a6a)}.game-over-box.victory{border-color:#2ecc7166;box-shadow:0 20px 60px #00000080,0 0 30px #2ecc711a}.game-over-box.victory h2{color:#2ecc71;text-shadow:0 0 20px rgba(46,204,113,.5)}.game-over-box.victory .modal-btn{background:linear-gradient(135deg,#2ecc71,#27ae60);box-shadow:0 4px 15px #2ecc714d}.game-over-box.victory .modal-btn:hover{box-shadow:0 6px 25px #2ecc7180;background:linear-gradient(135deg,#3edc81,#2fbe70)}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.1)}.detail-label{color:#888;font-size:13px}.detail-value{color:#fff;font-size:13px;font-weight:700}.codex-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;justify-content:center;align-items:center}.codex-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000d9}.codex-container{position:relative;background:linear-gradient(135deg,#1a1a3e,#16213e);border:2px solid rgba(100,200,255,.3);border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow:hidden}.codex-header{padding:15px 20px;border-bottom:1px solid rgba(100,200,255,.2);display:flex;justify-content:space-between;align-items:center}.codex-header h2{color:#64c8ff;font-size:18px;margin:0}.codex-close{background:none;border:none;color:#888;font-size:24px;cursor:pointer}.codex-close:hover{color:#e94560}.codex-tabs{display:flex;border-bottom:1px solid rgba(100,200,255,.2)}.codex-tab{flex:1;padding:12px;background:none;border:none;color:#888;cursor:pointer;font-size:14px}.codex-tab:hover{color:#fff;background:#64c8ff1a}.codex-tab.active{color:#64c8ff;background:#64c8ff26;border-bottom:2px solid #64c8ff}.codex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:20px;max-height:400px;overflow-y:auto}.codex-cell{aspect-ratio:1;background:#0006;border:2px solid rgba(100,200,255,.3);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative}.codex-cell:hover{transform:scale(1.05);border-color:#64c8ff99}.codex-cell.locked{opacity:.5}.codex-cell-icon{font-size:28px}.codex-cell-name{font-size:11px;color:#888;text-align:center;margin-top:4px}.codex-fusion-badge{position:absolute;top:2px;right:2px;font-size:8px;background:linear-gradient(135deg,#f39c12,#e74c3c);color:#fff;padding:2px 4px;border-radius:4px}.codex-hint{position:absolute;bottom:15px;left:50%;transform:translate(-50%);background:#000000e6;border:1px solid rgba(233,69,96,.5);border-radius:8px;padding:10px 20px;z-index:100;animation:codexHintSlideIn .3s ease-out;transition:opacity .3s}@keyframes codexHintSlideIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.codex-hint-content{display:flex;align-items:center;gap:8px;white-space:nowrap}.codex-hint-icon{font-size:16px}.codex-hint-text{font-size:13px;color:#888}.career-skill-cell{width:80px;aspect-ratio:1;background:#0006;border:2px solid rgba(100,200,255,.3);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}.career-skill-cell:hover{transform:scale(1.05);border-color:#64c8ff99}.career-skill-cell-icon{font-size:28px}.career-skill-cell-name{font-size:11px;color:#888;text-align:center;margin-top:4px}.career-select-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-height:400px;overflow-y:auto}.career-select-cell{position:relative;background:#0006;border:2px solid rgba(100,200,255,.3);border-radius:8px;padding:15px;text-align:center;cursor:pointer;transition:all .3s}.career-select-cell:hover:not(.locked){transform:scale(1.05);border-color:#64c8ff99;background:#64c8ff1a}.career-select-cell.locked{opacity:.5;cursor:not-allowed}.career-locked-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:8px;z-index:1}.career-detail-btn{position:absolute;top:5px;right:5px;font-size:12px;cursor:pointer;z-index:2;opacity:.7}.career-detail-btn:hover{opacity:1}.career-select-icon{font-size:32px;margin-bottom:8px}.career-select-name{font-size:14px;font-weight:700;margin-bottom:4px}.career-select-desc{font-size:11px;color:#888}.codex-skill-filter{display:flex;gap:8px;padding:10px 20px;border-bottom:1px solid rgba(100,200,255,.2);justify-content:center}.codex-filter-btn{background:#64c8ff1a;border:1px solid rgba(100,200,255,.3);color:#888;padding:6px 16px;border-radius:20px;cursor:pointer;font-size:12px;transition:all .3s}.codex-filter-btn:hover{background:#64c8ff33;color:#fff}.codex-filter-btn.active{background:#64c8ff4d;border-color:#64c8ff99;color:#64c8ff}.codex-category-badge{position:absolute;top:2px;right:2px;font-size:8px;padding:2px 4px;border-radius:4px}.codex-category-badge.active{background:#3498dbcc;color:#fff}.codex-category-badge.passive{background:#2ecc71cc;color:#fff}.skill-detail-modal{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:100;display:flex;justify-content:center;align-items:center;animation:skillDetailFadeIn .2s ease-out}@keyframes skillDetailFadeIn{0%{opacity:0}to{opacity:1}}.skill-detail-modal .modal-box{animation:skillDetailSlideIn .3s ease-out}@keyframes skillDetailSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.codex-skill-detail,.codex-chapter-detail{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:100;display:flex;justify-content:center;align-items:center;animation:codexDetailFadeIn .2s ease-out}@keyframes codexDetailFadeIn{0%{opacity:0}to{opacity:1}}.codex-skill-detail .modal-box,.codex-chapter-detail .modal-box{animation:codexDetailSlideIn .3s ease-out}@keyframes codexDetailSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.codex-clear-badge{position:absolute;top:2px;right:2px;background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;font-size:9px;padding:2px 5px;border-radius:8px;font-weight:700}.codex-enemy-tag{background:#e74c3c33;border:1px solid rgba(231,76,60,.4);color:#e74c3c;font-size:11px;padding:3px 8px;border-radius:12px;display:inline-flex;align-items:center;gap:3px}.leaderboard-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;justify-content:center;align-items:center}.lb-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000d9}.lb-content{position:relative;background:linear-gradient(135deg,#1a1a3e,#16213e);border:2px solid rgba(100,200,255,.3);border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow:hidden}.lb-header{padding:15px 20px;border-bottom:1px solid rgba(100,200,255,.2);display:flex;justify-content:space-between;align-items:center}.lb-header h2{color:#64c8ff;font-size:18px;margin:0}.lb-close{background:none;border:none;color:#888;font-size:24px;cursor:pointer}.lb-close:hover{color:#e94560}.lb-body{padding:20px;max-height:60vh;overflow-y:auto}.lb-refresh{background:#64c8ff33;border:1px solid rgba(100,200,255,.5);color:#fff;padding:4px 12px;border-radius:20px;cursor:pointer;font-size:12px;margin-left:10px;transition:all .3s;vertical-align:middle}.lb-refresh:hover{background:#64c8ff66}.lb-table{width:100%;border-collapse:collapse}.lb-table th{color:#64c8ff;font-size:12px;padding:10px;border-bottom:1px solid rgba(100,200,255,.2);text-align:center}.lb-table td{padding:10px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05);text-align:center}.lb-rank{font-weight:700;color:#f39c12}.lb-row-me{background:#64c8ff1a}.enemy-skill{width:40px;height:40px;border-radius:8px;background:#e74c3c33;border:2px solid rgba(231,76,60,.5);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all .3s;margin:5px auto 0;position:relative}.enemy-skill:hover{border-color:#e74c3ccc;transform:translateY(-2px);box-shadow:0 0 10px #e74c3c4d}.enemy-skill .skill-icon{font-size:20px}.enemy-skill .skill-lv{position:absolute;bottom:2px;right:2px;font-size:9px;color:#f39c12;background:#0009;padding:0 3px;border-radius:3px}.career-select-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}@media screen and (max-width: 768px){.career-select-grid{grid-template-columns:repeat(3,1fr);gap:6px;margin-top:10px}.career-card{padding:8px 4px}.career-card .career-icon{font-size:24px;margin-bottom:4px}.career-card .career-name{font-size:12px}.career-card .career-desc{font-size:9px}}.career-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;text-align:center;cursor:pointer;transition:all .3s ease}.career-card:hover:not(.locked){background:#ffffff1a;border-color:#e9456080;transform:translateY(-2px)}.career-card.locked{opacity:.5;cursor:not-allowed}.career-card .career-icon{font-size:32px;margin-bottom:8px}.career-card .career-name{font-size:14px;font-weight:700;margin-bottom:4px}.career-card .career-desc{font-size:11px;color:#888}.codex-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px}.codex-tabs .top-btn{flex:1}.codex-tabs .top-btn.active,.skill-filters .top-btn.active{background:#e9456066;border-color:#e94560cc}.codex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.codex-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;text-align:center;cursor:pointer;transition:all .2s}.codex-item:hover{background:#ffffff1a;transform:translateY(-2px)}.codex-item.locked{opacity:.3;cursor:not-allowed}.codex-item .item-icon{font-size:24px;margin-bottom:4px}.codex-item .item-name{font-size:11px;color:#888}.reward-card{padding:15px 10px;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center}.reward-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.reward-card:active{transform:translateY(-2px)}.detail-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;z-index:2000;display:flex;justify-content:center;align-items:center;animation:fadeIn .2s ease-out}.detail-box{background:linear-gradient(135deg,#1a1a3e,#16213e);border:2px solid rgba(233,69,96,.3);border-radius:16px;padding:20px;max-width:350px;width:90%;max-height:80vh;overflow-y:auto;animation:slideIn .3s ease-out}.detail-box h3{text-align:center;margin-bottom:15px;font-size:20px}.detail-desc{color:#888;font-size:13px;margin-bottom:15px;text-align:center}.detail-stats{background:#ffffff0d;border-radius:12px;padding:15px;margin-bottom:15px}.stat-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:13px;align-items:flex-start}.stat-row:last-child{margin-bottom:0}.stat-row span:first-child{flex-shrink:0;margin-right:10px}.stat-row span:last-child{text-align:right;word-break:break-all}.detail-skill{background:#ffffff0d;border-radius:12px;padding:12px;margin-bottom:15px;text-align:center}.skill-title{font-size:12px;color:#f39c12;margin-bottom:8px}.skill-info{display:flex;align-items:center;justify-content:center;gap:8px}.skill-icon{font-size:24px}.close-btn{width:100%;padding:12px;background:#e9456033;border:2px solid rgba(233,69,96,.6);border-radius:8px;color:#fff;cursor:pointer;font-size:14px;transition:all .3s;margin-top:10px}.close-btn:hover{background:#e9456066;border-color:#e94560cc}.detail-effect{background:#f39c121a;border:1px solid rgba(243,156,18,.3);border-radius:8px;padding:10px;margin-bottom:15px;text-align:center;font-size:13px;color:#f39c12}.unlock-section{background:#ffffff0d;border:1px solid rgba(243,156,18,.3);border-radius:12px;padding:12px;margin-bottom:15px}.unlock-title{font-size:13px;color:#f39c12;margin-bottom:8px;font-weight:700}.unlock-item{font-size:12px;color:#fff;margin-bottom:6px;padding-left:4px}.unlock-item:last-child{margin-bottom:0}.detail-weakness{background:#ffffff0d;border:1px solid rgba(231,76,60,.3);border-radius:12px;padding:12px;margin-bottom:15px}.weakness{font-size:13px;margin-bottom:6px}.resistance{font-size:13px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.shake{animation:shake .3s ease-in-out}@keyframes damageFloat{0%{transform:translate(-50%) scale(1);opacity:1}50%{transform:translate(-50%,-30px) scale(1.2);opacity:1}to{transform:translate(-50%,-60px) scale(.8);opacity:0}}.damage-number{animation:damageFloat .8s ease-out forwards;will-change:transform,opacity}@keyframes orbMatch{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}to{transform:scale(0);opacity:0}}@keyframes orbDrop{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes orbPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.orb{will-change:transform;transition:transform .15s ease-out,box-shadow .15s ease-out}.orb:hover{transform:scale(1.1);box-shadow:0 0 10px #ffffff4d}.orb.selected{transform:scale(1.15);box-shadow:0 0 15px #fff9;z-index:10}.orb.matched{animation:orbMatch .3s ease-out forwards}.orb.dropping{animation:orbDrop .3s ease-out forwards}.orb.pulse{animation:orbPulse .5s ease-in-out}.hp-bar{transition:width .3s cubic-bezier(.4,0,.2,1);will-change:width}.skill-btn{transition:all .2s ease-out;will-change:transform,box-shadow}.skill-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.skill-btn:active:not(:disabled){transform:translateY(0)}.skill-btn:disabled{opacity:.5;cursor:not-allowed}.top-btn{transition:all .2s ease-out}.top-btn:active{transform:scale(.95)}.modal-overlay{transition:opacity .3s ease-out}.modal-box{transition:transform .3s ease-out,opacity .3s ease-out;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading{animation:spin 1s linear infinite}@keyframes flash{0%,to{opacity:1}50%{opacity:.5}}.flash{animation:flash .5s ease-in-out 3}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.breathe{animation:breathe 2s ease-in-out infinite}.attack-warning{animation:attackWarning .5s ease-in-out infinite}@keyframes attackWarning{0%,to{box-shadow:0 0 5px #e74c3c80}50%{box-shadow:0 0 20px #e74c3c,0 0 40px #e74c3c80}}.damage-number{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:20px;font-weight:700;animation:damageFloat 1s ease-out forwards;pointer-events:none;z-index:100}@keyframes damageFloat{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-30px)}}.game-wrapper{display:flex;flex-direction:column;height:100vh;overflow:hidden}.top-section,.upper-section{flex-shrink:0}.middle-section{flex:1;overflow:hidden;display:flex;flex-direction:column}.bottom-section{flex-shrink:0;max-height:120px}#maze-container{display:flex;flex-direction:column;align-items:center;padding:5px 10px 10px;background:#0000004d;border-radius:12px;margin:0 10px 20px}.maze-grid{display:flex;flex-direction:column;gap:1px;background:#00000080;padding:6px;border-radius:6px;border:1px solid rgba(100,200,255,.3)}.maze-row{display:flex;gap:2px}.maze-cell{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:3px;font-size:15px;transition:all .2s}.maze-cell.wall{background:#0d0d1a;border:1px solid #1a1a2e}.maze-cell.path{background:#64c8ff33;border:1px solid rgba(100,200,255,.3)}.maze-cell.visited{background:#64c8ff73;border:1px solid rgba(100,200,255,.6)}.maze-cell.player{background:#2ecc7166;border:2px solid #2ecc71;box-shadow:0 0 10px #2ecc7180;animation:playerPulse 1.5s ease-in-out infinite}.maze-cell.exit{background:#f39c124d;border:2px solid #f39c12;animation:exitGlow 2s ease-in-out infinite}.maze-cell.fog{background:#1a1a2e}@keyframes playerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes exitGlow{0%,to{box-shadow:0 0 5px #f39c1280}50%{box-shadow:0 0 15px #f39c12cc,0 0 25px #f39c1266}}.maze-controls{margin-top:10px;flex-shrink:0}.maze-dpad{display:flex;flex-direction:column;align-items:center;gap:8px}.maze-dpad-mid{display:flex;gap:8px}.maze-btn{width:60px;height:60px;background:linear-gradient(135deg,#64c8ff33,#64c8ff1a);border:2px solid rgba(100,200,255,.3);border-radius:12px;color:#fff;font-size:24px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.maze-btn:hover{background:linear-gradient(135deg,#64c8ff4d,#64c8ff33);transform:scale(1.05)}.maze-btn:active{transform:scale(.95)}.maze-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px;padding:4px}.maze-status{font-size:13px;color:#f39c12}.maze-boss-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;color:#fff;padding:5px 12px;border-radius:15px;font-size:11px;cursor:pointer;animation:bossBtnPulse 1.5s ease-in-out infinite;box-shadow:0 0 8px #e74c3c80}.maze-boss-btn:hover{background:linear-gradient(135deg,#ff6b6b,#e74c3c)}@keyframes bossBtnPulse{0%,to{box-shadow:0 0 5px #e74c3c80}50%{box-shadow:0 0 12px #e74c3ccc}}.maze-info h3{color:#f39c12;margin-bottom:5px}.maze-progress{margin-top:10px}.maze-progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:5px}.maze-progress-fill{height:100%;background:linear-gradient(90deg,#2ecc71,#f39c12);border-radius:4px;transition:width .3s ease}.maze-progress p{font-size:11px;color:#888}.maze-cell.boss{background:#e74c3c66;border:2px solid #e74c3c;animation:bossPulse 1.5s ease-in-out infinite}.maze-cell.boss-locked{background:#6464644d;border:2px solid #666}.maze-cell.visited{background:#64c8ff40;border:1px solid rgba(100,200,255,.3)}.maze-cell.path-preview{background:#2ecc714d;border:1px solid rgba(46,204,113,.5);animation:pathPulse 1s ease-in-out infinite}.maze-cell.move-highlight{background:#f39c1266;border:2px solid rgba(243,156,18,.8);animation:movePulse .5s ease-in-out infinite}@keyframes pathPulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes movePulse{0%,to{transform:scale(1);box-shadow:0 0 5px #f39c1280}50%{transform:scale(1.05);box-shadow:0 0 15px #f39c12cc}}.maze-player-icon{font-size:24px;filter:drop-shadow(0 0 5px rgba(255,255,255,.5))}.maze-enemy-icon{font-size:22px;filter:drop-shadow(0 0 8px rgba(231,76,60,.6));animation:enemyFloat 2s ease-in-out infinite}.maze-enemy-icon.defeated{filter:grayscale(100%) opacity(.4);animation:none}.maze-cell.enemy{background:#e74c3c33;border:2px solid rgba(231,76,60,.5)}.maze-cell.enemy-defeated{background:#64646426;border:1px solid rgba(100,100,100,.3)}@keyframes enemyFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes bossPulse{0%,to{box-shadow:0 0 5px #e74c3c80}50%{box-shadow:0 0 15px #e74c3ccc,0 0 25px #e74c3c66}}.maze-info p{color:#888;font-size:12px}.maze-transition{animation:mazeFadeIn .5s ease-out}@keyframes mazeFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
