/* ================== 游戏主界面 ================== */
#game-container{display:none;width:100%;height:100%;flex-direction:column;background:#05050a;position:relative}

/* 顶部状态栏 */
#top-bar{background:linear-gradient(90deg,rgba(42,42,90,0.95),rgba(26,26,74,0.95));padding:8px 12px;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#ffd700;font-weight:bold;border-bottom:1px solid #5a5a8a;flex-shrink:0;box-shadow:0 2px 10px rgba(0,0,0,0.5)}
#player-status{background:linear-gradient(180deg,#1a1a3e,#0f0f1e);padding:8px 12px;border-bottom:2px solid #2a2a4a;display:flex;gap:10px;align-items:center;flex-shrink:0;box-shadow:0 4px 15px rgba(0,0,0,0.6)}

/* 状态条 */
.status-bars{flex:1;display:flex;flex-direction:column;gap:4px}
.bar-row{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:bold}
.bar-row .label{width:32px;color:#ffd700;text-shadow:1px 1px 1px #000}
.bar-bg{flex:1;background:#050510;height:12px;border:1px solid #3a3a5a;border-radius:4px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px rgba(0,0,0,0.8), 0 1px 0 rgba(255,255,255,0.1)}
.hp-fill{background:linear-gradient(to bottom,#ff6b6b,#c0392b);height:100%;transition:width .3s;box-shadow:inset 0 2px 2px rgba(255,255,255,0.4)}
.mp-fill{background:linear-gradient(to bottom,#5dade2,#2980b9);height:100%;transition:width .3s;box-shadow:inset 0 2px 2px rgba(255,255,255,0.4)}
.exp-fill{background:linear-gradient(to bottom,#f1c40f,#f39c12);height:100%;transition:width .3s;box-shadow:inset 0 2px 2px rgba(255,255,255,0.4)}
.bar-text{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;text-shadow:1px 1px 1px #000;pointer-events:none}

.status-icons{display:flex;flex-direction:column;gap:4px;font-size:12px;align-items:flex-end;font-weight:bold;color:#aed6f1}
.status-icons .key-row{display:flex;align-items:center;gap:4px}
.status-icons .key-row canvas{width:20px;height:16px;image-rendering:pixelated;image-rendering:crisp-edges}

/* 游戏画布区 */
#canvas-wrapper{flex:1;display:flex;justify-content:center;align-items:center;background:#000;position:relative;overflow:hidden;box-shadow:inset 0 0 20px rgba(0,0,0,1)}
#game-canvas{background:#000;display:block;width:100%;height:auto;max-width:min(100%, 480px);max-height:100%;aspect-ratio:352/384;object-fit:contain;margin:0 auto}

/* 日志框 */
#log-box{background:linear-gradient(180deg,#0a0a18,#050510);padding:6px 10px;height:65px;overflow-y:auto;font-size:12px;line-height:1.5;border-top:2px solid #3a3a5a;flex-shrink:0;-webkit-overflow-scrolling:touch;scrollbar-width:none;color:#85c1e9;box-shadow:inset 0 5px 10px rgba(0,0,0,0.5)}
#log-box::-webkit-scrollbar{display:none}

/* 控制区 & 3D按键 */
#touch-controls{background:linear-gradient(180deg,#1a1a3e,#0f0f1e);padding:10px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #4a4a8a;flex-shrink:0;gap:8px}
#dpad{display:grid;grid-template-columns:55px 55px 55px;grid-template-rows:55px 55px 55px;gap:6px}
.dpad-btn{background:linear-gradient(180deg,#4a4a8a 0%,#2a2a5a 100%);border:1px solid #6a6aaa;color:#fff;border-radius:10px;font-size:24px;display:flex;justify-content:center;align-items:center;font-weight:bold;box-shadow:0 6px 0 #0f0f1e, 0 8px 10px rgba(0,0,0,0.5);transition:all .1s;text-shadow:1px 1px 2px #000}
.dpad-btn:active{transform:translateY(6px);box-shadow:0 0 0 #0f0f1e, 0 2px 4px rgba(0,0,0,0.5);background:linear-gradient(180deg,#3a3a7a 0%,#1a1a4a 100%)}
.dpad-empty{background:transparent;border:none;box-shadow:none}

#action-buttons{display:grid;grid-template-columns:repeat(var(--ab-cols,3),42px);grid-auto-rows:auto;gap:5px}
.action-btn-mobile{background:linear-gradient(180deg,#f1c40f 0%,#f39c12 100%);color:#1a1a3e;border:1px solid #f39c12;border-radius:50%;width:42px;height:42px;font-size:18px;font-weight:bold;box-shadow:0 4px 0 #b8860b, 0 5px 7px rgba(0,0,0,0.4);transition:all .1s;cursor:pointer}
.action-btn-mobile:active{transform:translateY(4px);box-shadow:0 0 0 #b8860b, 0 1px 3px rgba(0,0,0,0.4)}
/* 按钮单元：圆形按钮 + 下方名称标签 */
.btn-cell{display:flex;flex-direction:column;align-items:center;width:42px}
.btn-label{color:#e8e8ff;font-size:9px;line-height:1.1;margin-top:3px;text-align:center;text-shadow:1px 1px 1px #000;font-weight:bold;letter-spacing:.5px}
/* 未分配点数快捷按钮（醒目金红 + 脉冲） */
.btn-levelup-hint{margin-top:4px;width:138px;max-width:100%;padding:7px 6px;background:linear-gradient(180deg,#ffd700 0%,#ff4500 100%);color:#1a0a00;border:2px solid #fff;border-radius:10px;font-size:12px;font-weight:bold;box-shadow:0 4px 0 #8b0000, 0 6px 12px rgba(255,69,0,.5);animation:lpPulse 1.1s ease-in-out infinite;cursor:pointer;grid-column:1 / -1;text-align:center}
.btn-levelup-hint:active{transform:translateY(4px);box-shadow:0 0 0 #8b0000, 0 2px 6px rgba(255,69,0,.5)}
@keyframes lpPulse{0%,100%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.04);filter:brightness(1.15)}}

/* 对话框 */
#dialog-box{position:fixed;bottom:15px;left:10px;right:10px;padding:15px 12px 15px 85px;background:rgba(15,15,35,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:2px solid #ffd700;border-radius:10px;color:#fff;font-size:14px;z-index:100;display:none;line-height:1.6;box-shadow:0 10px 25px rgba(0,0,0,.8),inset 0 0 15px rgba(255,215,0,.15)}
#dialog-portrait{position:absolute;left:12px;top:12px;width:60px;height:60px;background:linear-gradient(135deg,#2a2a5a,#1a1a3e);border:2px solid #ffd700;border-radius:6px;image-rendering:pixelated;image-rendering:crisp-edges;box-shadow:0 4px 8px rgba(0,0,0,.5)}
#dialog-name{color:#ffd700;font-weight:bold;margin-bottom:6px;font-size:15px;text-shadow:1px 1px 1px #000}
#dialog-text{min-height:44px}
#dialog-hint{text-align:right;color:#aed6f1;font-size:12px;margin-top:6px;animation:blink 1.2s infinite}
@keyframes blink{50%{opacity:.3}}

/* 怪物信息提示 */
#monster-tooltip{position:fixed;background:rgba(15,15,35,.95);backdrop-filter:blur(4px);border:2px solid #ffd700;border-radius:8px;padding:10px 12px;color:#fff;font-size:12px;z-index:150;pointer-events:none;display:none;line-height:1.6;box-shadow:0 10px 20px rgba(0,0,0,.8);text-align:center;max-width:180px}
#monster-tooltip .mt-name{color:#ffd700;font-weight:900;font-size:14px;margin-bottom:4px}
#monster-tooltip .mt-stat{color:#fff;background:rgba(0,0,0,.5);border-radius:4px;padding:2px;margin-bottom:4px}
#monster-tooltip .mt-warn{color:#ff6b6b;font-weight:bold}
#monster-tooltip .mt-auto{color:#2ecc71;font-weight:bold}

/* 全局计时条 */
#global-timer-bar{position:fixed;top:0;left:0;width:100%;height:6px;background:rgba(0,0,0,.6);z-index:350;display:none}
#global-timer-fill{height:100%;width:100%;background:linear-gradient(to right,#ffd700,#f39c12,#e74c3c,#5a1810);transition:width 1s linear}
#global-timer-text{position:absolute;top:8px;left:50%;transform:translateX(-50%);font-size:12px;color:#ffd700;font-weight:bold;text-shadow:1px 1px 2px #000;background:rgba(0,0,0,.8);padding:4px 12px;border-radius:6px;white-space:nowrap;border:1px solid #f39c12}

/* BOSS警告 / 自动获胜横幅 */
#boss-warning{position:fixed;top:50%;left:0;width:100%;transform:translateY(-50%);z-index:355;display:none;text-align:center;pointer-events:none}
#boss-warning .bw-band{background:linear-gradient(90deg,transparent,rgba(160,20,20,.95) 15%,rgba(200,30,30,1) 50%,rgba(160,20,20,.95) 85%,transparent);padding:22px 0;border-top:2px solid #ff6b6b;border-bottom:2px solid #ff6b6b;animation:bwSlide .5s ease-out;box-shadow:0 0 30px rgba(255,0,0,.5)}
#boss-warning .bw-title{font-size:36px;font-weight:900;color:#fff;text-shadow:0 0 15px #ff0,4px 4px 0 #000;letter-spacing:6px;animation:bwPulse .8s infinite}
#boss-warning .bw-sub{font-size:16px;color:#ffd700;margin-top:8px;text-shadow:2px 2px 0 #000;font-weight:bold}
@keyframes bwSlide{0%{transform:scaleX(0);opacity:0}100%{transform:scaleX(1);opacity:1}}
@keyframes bwPulse{50%{transform:scale(1.1);text-shadow:0 0 25px #ff0,4px 4px 0 #000}}

#auto-win-banner{position:fixed;top:35%;left:0;width:100%;z-index:340;display:none;text-align:center;pointer-events:none}
#auto-win-banner .aw-text{display:inline-block;background:linear-gradient(90deg,transparent,rgba(20,80,40,.95) 20%,rgba(30,120,60,1) 50%,rgba(20,80,40,.95) 80%,transparent);padding:15px 40px;font-size:24px;font-weight:900;color:#fff;text-shadow:0 0 15px #2ecc71,3px 3px 0 #000;letter-spacing:4px;animation:awPop .6s ease-out;border-top:2px solid #2ecc71;border-bottom:2px solid #2ecc71}
@keyframes awPop{0%{transform:scale(.3) translateY(50px);opacity:0}50%{transform:scale(1.1) translateY(0);opacity:1}100%{transform:scale(1) translateY(0);opacity:1}}