/* RESET & BASE */
*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;overflow:hidden;background:#000;font-family:"SimSun","宋体",serif;touch-action:none}
body{padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}
canvas{display:block;cursor:crosshair}

/* UI OVERLAY LAYER */
#ui-layer{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}
#ui-layer *{pointer-events:auto}

/* TOP BAR */
#top-bar{position:absolute;top:8px;left:50%;transform:translateX(-50%);display:flex;gap:16px;align-items:center;
  background:linear-gradient(180deg,rgba(40,28,12,0.95),rgba(20,14,6,0.9));
  border:1px solid #8b6914;border-radius:4px;padding:6px 18px;
  box-shadow:0 0 12px rgba(139,105,20,0.3),inset 0 1px 0 rgba(255,215,0,0.1)}
#top-bar .stat{color:#d4a843;font-size:13px;text-shadow:1px 1px 2px #000}
#top-bar .stat span{color:#ffd700;font-weight:bold}

/* BOTTOM HUD */
#bottom-hud{position:absolute;bottom:0;left:0;width:100%;
  background:linear-gradient(0deg,rgba(15,10,5,0.97),rgba(30,20,10,0.92));
  border-top:2px solid #8b6914;padding:8px 12px;display:flex;flex-direction:column;gap:6px}

/* BARS */
.bar-container{display:flex;align-items:center;gap:8px}
.bar-label{color:#d4a843;font-size:11px;width:28px;text-align:right;text-shadow:1px 1px 1px #000}
.bar-track{flex:1;height:16px;background:#1a0a00;border:1px solid #5a3a10;border-radius:2px;position:relative;overflow:hidden;max-width:260px}
.bar-fill{height:100%;border-radius:1px;transition:width 0.3s}
.bar-fill.hp{background:linear-gradient(180deg,#e03030,#8b0000)}
.bar-fill.mp{background:linear-gradient(180deg,#3060e0,#00008b)}
.bar-fill.exp{background:linear-gradient(180deg,#40c040,#006400);height:8px}
.bar-track.exp-track{height:10px}
.bar-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;text-shadow:1px 1px 1px #000;white-space:nowrap}

/* SKILLS BAR */
#skills-bar{display:flex;gap:6px;justify-content:center;margin-top:4px}
.skill-slot{width:48px;height:48px;background:rgba(30,20,10,0.9);border:2px solid #6b4914;border-radius:4px;
  position:relative;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:border-color 0.2s}
.skill-slot:hover{border-color:#ffd700}
.skill-slot .skill-icon{font-size:20px}
.skill-slot .skill-key{position:absolute;top:1px;right:3px;font-size:9px;color:#8b6914}
.skill-slot .skill-name{font-size:8px;color:#d4a843;margin-top:2px}
.skill-slot .cooldown-overlay{position:absolute;top:0;left:0;width:100%;height:100%;
  background:rgba(0,0,0,0.7);border-radius:2px;display:flex;align-items:center;justify-content:center;
  color:#ff6;font-size:14px;font-weight:bold}

/* POTION DISPLAY */
#potion-display{display:flex;gap:12px;align-items:center;margin-left:16px}
.potion-info{display:flex;align-items:center;gap:4px;color:#d4a843;font-size:12px;
  background:rgba(0,0,0,0.4);padding:3px 8px;border-radius:3px;border:1px solid #3a2a10}
.potion-info .potion-icon{font-size:16px}
.potion-info .potion-count{color:#ffd700;font-weight:bold}
.potion-info .potion-key{color:#8b6914;font-size:9px;margin-left:2px}

/* CHAT LOG */
#chat-log{position:absolute;bottom:90px;left:8px;width:340px;max-height:180px;overflow-y:auto;
  background:rgba(10,5,0,0.8);border:1px solid #5a3a10;border-radius:4px;padding:6px 8px;
  scrollbar-width:thin;scrollbar-color:#5a3a10 transparent}
#chat-log::-webkit-scrollbar{width:4px}
#chat-log::-webkit-scrollbar-thumb{background:#5a3a10;border-radius:2px}
#chat-log p{font-size:11px;line-height:1.5;margin-bottom:2px}
.msg-combat{color:#ff8c00}.msg-system{color:#00ff00}.msg-loot{color:#ffd700}.msg-levelup{color:#ff00ff}
.msg-crit{color:#ff2222;font-weight:bold}.msg-heal{color:#00ff88}.msg-shop{color:#00bfff}

/* INVENTORY / EQUIPMENT / SHOP PANELS */
.panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:linear-gradient(180deg,rgba(40,28,12,0.97),rgba(20,14,6,0.97));
  border:2px solid #8b6914;border-radius:6px;min-width:300px;display:none;
  box-shadow:0 0 30px rgba(0,0,0,0.8),0 0 12px rgba(139,105,20,0.3);max-height:80vh;overflow-y:auto}
.panel.active{display:block}
.panel-title{text-align:center;color:#ffd700;font-size:16px;font-weight:bold;padding:10px;
  border-bottom:1px solid #5a3a10;text-shadow:0 0 8px rgba(255,215,0,0.4);
  background:linear-gradient(180deg,rgba(60,40,15,0.5),transparent)}
.panel-close{position:absolute;top:6px;right:10px;color:#8b6914;cursor:pointer;font-size:18px}
.panel-close:hover{color:#ffd700}

/* INVENTORY GRID */
#inv-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:10px}
.inv-slot{width:52px;height:52px;background:rgba(0,0,0,0.5);border:1px solid #3a2a10;border-radius:3px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative}
.inv-slot:hover{border-color:#ffd700;background:rgba(139,105,20,0.2)}
.inv-slot .item-icon{font-size:22px}
.inv-slot .item-name{font-size:7px;color:#d4a843;margin-top:1px;text-align:center;max-width:48px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.inv-slot .item-count{position:absolute;bottom:2px;right:4px;font-size:9px;color:#ffd700;text-shadow:1px 1px 1px #000}

/* EQUIPMENT PANEL */
#equip-grid{padding:10px;display:flex;flex-direction:column;gap:6px}
.equip-row{display:flex;gap:6px;justify-content:center}
.equip-slot{width:60px;height:60px;background:rgba(0,0,0,0.5);border:1px solid #3a2a10;border-radius:3px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative}
.equip-slot:hover{border-color:#ffd700}
.equip-slot .slot-label{font-size:8px;color:#5a3a10;position:absolute;bottom:2px}
.equip-slot .item-icon{font-size:24px}
.equip-slot .item-name{font-size:7px;color:#ffd700;margin-top:1px}

/* SHOP PANEL */
#shop-panel{min-width:380px}
#shop-grid{padding:10px;display:flex;flex-direction:column;gap:4px}
.shop-item{display:flex;align-items:center;gap:10px;padding:6px 10px;background:rgba(0,0,0,0.3);
  border:1px solid #3a2a10;border-radius:3px;cursor:pointer;transition:all 0.2s}
.shop-item:hover{border-color:#ffd700;background:rgba(139,105,20,0.15)}
.shop-item .shop-icon{font-size:22px;width:30px;text-align:center}
.shop-item .shop-info{flex:1}
.shop-item .shop-name{color:#d4a843;font-size:12px}
.shop-item .shop-desc{color:#8b6914;font-size:10px}
.shop-item .shop-price{color:#ffd700;font-size:12px;font-weight:bold;white-space:nowrap}
.shop-tabs{display:flex;gap:0;border-bottom:1px solid #5a3a10}
.shop-tab{flex:1;text-align:center;padding:8px;color:#8b6914;font-size:12px;cursor:pointer;
  border-bottom:2px solid transparent;transition:all 0.2s}
.shop-tab:hover,.shop-tab.active{color:#ffd700;border-bottom-color:#ffd700}
.shop-sell-area{padding:10px;border-top:1px solid #3a2a10;margin-top:4px}
.shop-sell-area h4{color:#d4a843;font-size:11px;margin-bottom:6px}

/* SAVE INDICATOR */
#save-indicator{position:fixed;top:50px;right:10px;color:#00ff88;font-size:12px;
  background:rgba(0,0,0,0.7);padding:4px 10px;border-radius:3px;
  border:1px solid rgba(0,255,136,0.3);display:none;z-index:100;
  animation:saveFade 1.5s ease-out forwards}
@keyframes saveFade{0%{opacity:1}70%{opacity:1}100%{opacity:0}}

/* ZONE NAME DISPLAY */
#zone-name{position:fixed;top:18%;left:50%;transform:translateX(-50%);
  color:#ffd700;font-size:28px;font-weight:bold;text-shadow:0 0 20px rgba(255,215,0,0.5),2px 2px 4px #000;
  pointer-events:none;z-index:55;display:none;opacity:0;transition:opacity 0.5s}
#zone-name.show{display:block;opacity:1}
#zone-name.fade{opacity:0}

/* ITEM TOOLTIP */
#tooltip{position:fixed;background:rgba(20,14,6,0.97);border:1px solid #8b6914;border-radius:4px;
  padding:8px 12px;color:#d4a843;font-size:11px;pointer-events:none;display:none;z-index:100;
  max-width:220px;box-shadow:0 0 16px rgba(0,0,0,0.9)}
#tooltip .tt-name{color:#ffd700;font-size:13px;font-weight:bold;margin-bottom:4px}
#tooltip .tt-rare{color:#ff4500}
#tooltip .tt-stat{color:#80ff80;margin:1px 0}

/* CONTROLS OVERLAY */
#controls-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:rgba(20,14,6,0.95);border:2px solid #8b6914;border-radius:8px;padding:24px 32px;
  color:#d4a843;z-index:50;text-align:center;max-height:90vh;overflow-y:auto}
#controls-overlay h2{color:#ffd700;font-size:20px;margin-bottom:16px;text-shadow:0 0 8px rgba(255,215,0,0.4)}
#controls-overlay .ctrl-row{display:flex;justify-content:space-between;gap:24px;margin:6px 0;font-size:13px}
#controls-overlay .ctrl-key{color:#ffd700;font-weight:bold;min-width:60px;text-align:right}
#controls-overlay .ctrl-desc{color:#d4a843;text-align:left;flex:1}
#controls-overlay button{margin-top:16px;background:linear-gradient(180deg,#8b6914,#5a3a10);color:#ffd700;
  border:1px solid #ffd700;padding:8px 32px;border-radius:4px;cursor:pointer;font-size:14px;font-family:inherit}
#controls-overlay button:hover{background:linear-gradient(180deg,#a07818,#6b4914)}

/* LEVEL UP EFFECT */
#levelup-fx{position:fixed;top:30%;left:50%;transform:translateX(-50%);color:#ffd700;font-size:36px;
  font-weight:bold;text-shadow:0 0 20px #ff0,0 0 40px #ff8c00;display:none;z-index:60;
  animation:lvlup 2s ease-out forwards;pointer-events:none}
@keyframes lvlup{0%{opacity:1;transform:translateX(-50%) scale(0.5)}30%{transform:translateX(-50%) scale(1.2)}
  60%{transform:translateX(-50%) scale(1)}100%{opacity:0;transform:translateX(-50%) translateY(-60px)}}

/* RARITY COLORS */
.rarity-common{color:#c0c0c0}.rarity-rare{color:#00bfff}.rarity-epic{color:#ff00ff}.rarity-legendary{color:#ff8c00}

/* ENHANCEMENT PANEL */
#enhance-panel{min-width:340px}
#enhance-content{padding:14px;display:flex;flex-direction:column;gap:10px}
.enhance-slot{width:80px;height:80px;background:rgba(0,0,0,0.6);border:2px dashed #5a3a10;border-radius:6px;
  margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;
  transition:all 0.3s;position:relative}
.enhance-slot:hover{border-color:#ffd700}
.enhance-slot.has-item{border-style:solid;border-color:#8b6914}
.enhance-slot .item-icon{font-size:32px}
.enhance-slot .item-name{font-size:9px;color:#ffd700;margin-top:2px}
.enhance-slot .enhance-level{position:absolute;top:2px;right:4px;font-size:11px;color:#ff8c00;font-weight:bold}
.enhance-info{text-align:center;color:#d4a843;font-size:11px;padding:8px;background:rgba(0,0,0,0.3);border-radius:4px}
.enhance-info .rate{color:#00ff88;font-size:14px;font-weight:bold}
.enhance-info .cost{color:#ffd700;font-size:12px}
.enhance-info .risk{color:#ff4444;font-size:10px;margin-top:4px}
.enhance-btn{background:linear-gradient(180deg,#8b4513,#5a2a06);color:#ffd700;border:1px solid #ff8c00;
  padding:10px 24px;border-radius:4px;cursor:pointer;font-size:14px;font-family:inherit;
  text-align:center;transition:all 0.3s;margin:0 auto;display:block}
.enhance-btn:hover{background:linear-gradient(180deg,#a05518,#6b3508);box-shadow:0 0 12px rgba(255,140,0,0.4)}
.enhance-btn:disabled{opacity:0.4;cursor:not-allowed}
.enhance-stones{display:flex;justify-content:center;gap:8px;align-items:center;color:#d4a843;font-size:12px}
.enhance-stones .count{color:#ff8c00;font-weight:bold;font-size:14px}
.enhance-result{text-align:center;font-size:16px;font-weight:bold;padding:8px;border-radius:4px;display:none;
  animation:enhanceFlash 1s ease-out forwards}
.enhance-result.success{color:#00ff88;background:rgba(0,255,136,0.1);border:1px solid rgba(0,255,136,0.3)}
.enhance-result.fail{color:#ff4444;background:rgba(255,0,0,0.1);border:1px solid rgba(255,0,0,0.3)}
.enhance-result.broke{color:#ff0000;background:rgba(255,0,0,0.15);border:1px solid rgba(255,0,0,0.5)}
@keyframes enhanceFlash{0%{opacity:0;transform:scale(0.8)}20%{opacity:1;transform:scale(1.1)}100%{opacity:1;transform:scale(1)}}
.enhance-inv{display:grid;grid-template-columns:repeat(5,1fr);gap:3px;padding:8px;max-height:180px;overflow-y:auto;
  border-top:1px solid #3a2a10;margin-top:6px}
.enhance-inv .inv-slot{width:48px;height:48px}
.enhance-select-hint{color:#8b6914;font-size:11px;text-align:center;padding:6px}

/* AUTO BATTLE PANEL */
#auto-btn{position:absolute;top:8px;left:12px;
  background:linear-gradient(180deg,rgba(40,28,12,0.95),rgba(20,14,6,0.9));
  border:1px solid #5a3a10;border-radius:4px;padding:6px 14px;cursor:pointer;
  color:#8b6914;font-size:13px;font-family:inherit;transition:all 0.3s;
  box-shadow:0 0 8px rgba(0,0,0,0.4)}
#auto-btn:hover{border-color:#ffd700;color:#ffd700}
#auto-btn.active{border-color:#00ff88;color:#00ff88;
  box-shadow:0 0 12px rgba(0,255,136,0.3);
  animation:autoPulse 1.5s ease-in-out infinite}
@keyframes autoPulse{0%,100%{box-shadow:0 0 8px rgba(0,255,136,0.2)}50%{box-shadow:0 0 16px rgba(0,255,136,0.5)}}

#auto-settings{position:absolute;top:44px;left:12px;
  background:linear-gradient(180deg,rgba(40,28,12,0.97),rgba(20,14,6,0.97));
  border:1px solid #8b6914;border-radius:6px;padding:12px 14px;display:none;
  box-shadow:0 0 20px rgba(0,0,0,0.7);min-width:200px}
#auto-settings.active{display:block}
#auto-settings h3{color:#ffd700;font-size:13px;margin-bottom:8px;text-shadow:0 0 6px rgba(255,215,0,0.3);
  border-bottom:1px solid #3a2a10;padding-bottom:6px}
.auto-row{display:flex;justify-content:space-between;align-items:center;margin:5px 0;font-size:11px;color:#d4a843}
.auto-row label{flex:1}
.auto-row select,.auto-row input[type=range]{background:#1a0a00;color:#ffd700;border:1px solid #5a3a10;
  border-radius:3px;padding:2px 4px;font-size:11px;font-family:inherit}
.auto-row select{width:100px}
.auto-row input[type=range]{width:70px;accent-color:#ffd700}
.auto-row input[type=checkbox]{accent-color:#ffd700;width:14px;height:14px;cursor:pointer}
.auto-row .val{color:#ffd700;font-size:10px;width:30px;text-align:right}

/* AUTO BATTLE STATUS */
#auto-status{position:absolute;top:8px;left:160px;color:#00ff88;font-size:11px;
  background:rgba(0,0,0,0.6);padding:3px 8px;border-radius:3px;display:none;
  border:1px solid rgba(0,255,136,0.3)}
#auto-status.active{display:flex;align-items:center;gap:6px}
#auto-status .pulse-dot{width:6px;height:6px;border-radius:50%;background:#00ff88;
  animation:dotPulse 1s ease-in-out infinite}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:0.3}}
#auto-insight{position:absolute;top:38px;left:160px;display:none;gap:6px;flex-wrap:wrap;max-width:380px;z-index:31}
#auto-insight.active{display:flex}
#auto-insight span{padding:3px 7px;border-radius:999px;background:rgba(20,14,6,0.88);border:1px solid rgba(139,105,20,0.35);font-size:9px;color:#d4a634;box-shadow:0 8px 18px rgba(0,0,0,0.22);white-space:nowrap}
#auto-state-chip{color:#fff3d1;border-color:rgba(255,215,0,0.4)}
#auto-target-chip{color:#8bd8ff;border-color:rgba(91,150,255,0.28)}
#auto-yield-chip{color:#9dffb1;border-color:rgba(0,255,136,0.28)}
#auto-kills-chip{color:#ff9d9d;border-color:rgba(255,100,100,0.28)}
#auto-time-chip{color:#c8b8ff;border-color:rgba(180,150,255,0.28)}
#auto-dps-chip{color:#ffe08a;border-color:rgba(255,200,80,0.3)}
#auto-death-chip{color:#ff6b6b;border-color:rgba(255,80,80,0.4)}
#auto-zone-chip{color:#88ddff;border-color:rgba(100,180,255,0.35);animation:dotPulse 1.5s ease-in-out infinite}
#auto-presets{background:rgba(10,5,0,0.75);border-top:1px solid rgba(139,105,20,0.2)}
#auto-presets button:hover{background:#3a2a00!important}
#auto-dashboard #auto-dashboard-chart{display:block;margin:0 auto}

/* AUTO EQUIP INDICATOR */
.auto-equip-flash{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  color:#00ff88;font-size:14px;font-weight:bold;text-shadow:0 0 10px rgba(0,255,136,0.6);
  pointer-events:none;z-index:55;animation:autoEquipFade 1.2s ease-out forwards}
@keyframes autoEquipFade{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-70%) scale(0.8)}}


/* MOUNT PANEL */
#mount-panel{min-width:320px}
.mount-card{display:flex;align-items:center;gap:10px;padding:8px;border-bottom:1px solid #3a2a10}
.mount-card .mc-icon{font-size:28px}
.mount-card .mc-info{flex:1}
.mount-card .mc-name{color:#ffd700;font-size:13px;font-weight:bold}
.mount-card .mc-stats{color:#8b6914;font-size:10px}
.mount-card .mc-btn{padding:4px 10px;border-radius:3px;font-size:10px;cursor:pointer;font-family:inherit}
.mount-card .mc-ride{background:#5a3a10;color:#ffd700;border:1px solid #8b6914}
.mount-card .mc-ride:hover{background:#7b5020}
.mount-card .mc-ride.active{background:#006400;color:#00ff88;border-color:#00ff88}
.mount-card .mc-buy{background:#3a2010;color:#ffd700;border:1px solid #5a3a10}
.mount-card .mc-buy:hover{background:#5a3a10}

/* GEM SOCKETING PANEL */
#gem-panel{min-width:340px}
.gem-section{padding:10px}
.gem-inv-title{color:#ffd700;font-size:12px;font-weight:bold;margin-bottom:6px;border-bottom:1px solid #3a2a10;padding-bottom:4px}
.gem-inv-grid{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.gem-item{display:flex;align-items:center;gap:4px;padding:4px 8px;background:rgba(0,0,0,0.4);border:1px solid #3a2a10;border-radius:3px;font-size:11px;color:#d4a843}
.gem-item .gi-icon{font-size:16px}
.gem-equip-title{color:#d4a843;font-size:11px;margin:8px 0 4px}
.gem-equip-item{display:flex;align-items:center;gap:6px;padding:6px 8px;background:rgba(0,0,0,0.3);border:1px solid #3a2a10;border-radius:3px;margin-bottom:4px}
.gem-equip-item .gei-name{color:#ffd700;font-size:12px;flex:1}
.gem-equip-item .gei-sockets{display:flex;gap:3px}
.gem-equip-item .gei-socket{width:18px;height:18px;border-radius:50%;border:1px solid #5a3a10;background:rgba(0,0,0,0.5);display:flex;align-items:center;justify-content:center;font-size:10px}
.gem-equip-item .gei-socket.filled{border-color:#ffd700}
.gem-equip-item .gei-socket.empty{cursor:pointer}
.gem-equip-item .gei-socket.empty:hover{border-color:#ffd700;background:rgba(139,105,20,0.2)}

/* VOLUME CONTROL */
#vol-ctrl{position:absolute;top:8px;right:140px;display:flex;align-items:center;gap:6px;
  background:rgba(20,14,6,0.9);border:1px solid #5a3a10;border-radius:4px;padding:4px 10px}
#vol-ctrl label{color:#8b6914;font-size:11px}
#vol-ctrl input[type=range]{width:60px;accent-color:#ffd700}

/* LOGIN SCREEN */
#login-screen{position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;
  background:radial-gradient(ellipse at center,#1a0e00 0%,#000 70%);
  display:flex;flex-direction:column;align-items:center;justify-content:center}
#login-screen h1{color:#ffd700;font-size:42px;margin-bottom:8px;
  text-shadow:0 0 30px rgba(255,215,0,0.5),0 0 60px rgba(255,140,0,0.3);
  font-family:"SimSun","宋体",serif;letter-spacing:8px}
#login-screen .subtitle{color:#8b6914;font-size:14px;margin-bottom:40px;letter-spacing:4px}
#login-box{background:linear-gradient(180deg,rgba(40,28,12,0.95),rgba(20,14,6,0.95));
  border:2px solid #8b6914;border-radius:8px;padding:30px 40px;min-width:360px;
  box-shadow:0 0 40px rgba(139,105,20,0.2),0 0 80px rgba(0,0,0,0.8)}
#login-box .tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #5a3a10}
#login-box .tab{flex:1;text-align:center;padding:10px;color:#8b6914;font-size:14px;
  cursor:pointer;border-bottom:2px solid transparent;transition:all 0.2s}
#login-box .tab:hover,#login-box .tab.active{color:#ffd700;border-bottom-color:#ffd700}
#login-box input{width:100%;background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;
  padding:10px 14px;border-radius:4px;font-size:14px;font-family:inherit;
  margin-bottom:12px;outline:none;transition:border-color 0.2s}
#login-box input:focus{border-color:#ffd700}
#login-box input::placeholder{color:#5a3a10}
#login-box .login-btn{width:100%;background:linear-gradient(180deg,#8b6914,#5a3a10);
  color:#ffd700;border:1px solid #ffd700;padding:12px;border-radius:4px;cursor:pointer;
  font-size:16px;font-family:inherit;transition:all 0.2s;margin-top:8px}
#login-box .login-btn:hover{background:linear-gradient(180deg,#a07818,#6b4914);
  box-shadow:0 0 12px rgba(255,215,0,0.3)}
#login-box .error{color:#ff4444;font-size:12px;text-align:center;margin-top:8px;min-height:16px}
#login-box .server-info{color:#5a3a10;font-size:11px;text-align:center;margin-top:12px}

/* CHARACTER CREATE SCREEN */
#char-create{position:fixed;top:0;left:0;width:100%;height:100%;z-index:190;
  background:rgba(0,0,0,0.9);display:none;flex-direction:column;align-items:center;justify-content:center}
#char-create.active{display:flex}
#char-create h2{color:#ffd700;font-size:24px;margin-bottom:24px;text-shadow:0 0 12px rgba(255,215,0,0.4)}
#char-create input{background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;
  padding:10px 14px;border-radius:4px;font-size:16px;font-family:inherit;
  width:280px;outline:none;text-align:center;margin-bottom:16px}
#char-create input:focus{border-color:#ffd700}
#char-create .create-btn{background:linear-gradient(180deg,#8b6914,#5a3a10);
  color:#ffd700;border:1px solid #ffd700;padding:10px 40px;border-radius:4px;
  cursor:pointer;font-size:16px;font-family:inherit}
#char-create .create-btn:hover{background:linear-gradient(180deg,#a07818,#6b4914)}
#char-create .error{color:#ff4444;font-size:12px;margin-top:8px;min-height:16px}

/* ONLINE PLAYERS INDICATOR */
#online-count{position:absolute;top:8px;right:10px;color:#00ff88;font-size:12px;
  background:rgba(0,0,0,0.7);padding:4px 10px;border-radius:3px;
  border:1px solid rgba(0,255,136,0.3)}

/* PK MODE */
#pk-btn{position:absolute;top:38px;right:10px;
  background:linear-gradient(180deg,rgba(40,28,12,0.95),rgba(20,14,6,0.9));
  border:1px solid #5a3a10;border-radius:4px;padding:4px 12px;cursor:pointer;
  color:#8b6914;font-size:12px;font-family:inherit;transition:all 0.3s}
#pk-btn:hover{border-color:#ffd700;color:#ffd700}
#pk-btn.active{border-color:#ff4444;color:#ff4444;box-shadow:0 0 8px rgba(255,0,0,0.3)}

/* LEADERBOARD PANEL */
#lb-panel{min-width:350px}
#lb-content{padding:10px}
.lb-row{display:flex;align-items:center;gap:10px;padding:5px 8px;border-bottom:1px solid #2a1a08;font-size:12px}
.lb-row:nth-child(-n+3) .lb-rank{color:#ffd700;font-weight:bold}
.lb-rank{color:#8b6914;width:28px;text-align:center}
.lb-name{color:#d4a843;flex:1}
.lb-level{color:#ffd700;width:50px;text-align:center}
.lb-gold{color:#ffa500;width:60px;text-align:right}

/* TRADE PANEL */
#trade-panel{min-width:400px}
#trade-content{padding:12px;display:flex;flex-direction:column;gap:8px}
.trade-section{background:rgba(0,0,0,0.3);border:1px solid #3a2a10;border-radius:4px;padding:8px}
.trade-section h4{color:#d4a843;font-size:11px;margin-bottom:6px}
.trade-items{display:flex;gap:4px;flex-wrap:wrap;min-height:40px}
.trade-gold-input{background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;
  padding:4px 8px;border-radius:3px;font-size:12px;width:100px;font-family:inherit}
.trade-actions{display:flex;gap:8px;justify-content:center;margin-top:8px}
.trade-btn{background:linear-gradient(180deg,#5a3a10,#3a2010);color:#ffd700;
  border:1px solid #8b6914;padding:6px 20px;border-radius:4px;cursor:pointer;
  font-size:12px;font-family:inherit}
.trade-btn.accept{border-color:#00ff88;color:#00ff88}
.trade-btn.cancel{border-color:#ff4444;color:#ff4444}
.trade-item-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:3px;padding:6px;max-height:120px;overflow-y:auto}
.trade-item-slot{width:40px;height:40px;background:rgba(0,0,0,0.5);border:1px solid #3a2a10;border-radius:3px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:16px}
.trade-item-slot:hover{border-color:#ffd700}
.trade-item-slot.selected{border-color:#00ff88;background:rgba(0,255,136,0.15)}
.trade-offered{display:flex;flex-wrap:wrap;gap:3px;min-height:40px;padding:4px;background:rgba(0,0,0,0.3);border-radius:3px}
.trade-offered-item{width:36px;height:36px;background:rgba(0,0,0,0.4);border:1px solid #5a3a10;border-radius:3px;
  display:flex;align-items:center;justify-content:center;font-size:16px}

/* WORLD CHAT INPUT */
#chat-input-bar{position:absolute;bottom:90px;left:8px;width:340px;display:flex;gap:4px}
#chat-input-bar select{background:#1a0a00;color:#ffd700;border:1px solid #5a3a10;
  border-radius:3px;padding:4px;font-size:11px;font-family:inherit;width:60px}
#chat-input-bar input{flex:1;background:#1a0a00;border:1px solid #5a3a10;color:#d4a843;
  padding:4px 8px;border-radius:3px;font-size:11px;font-family:inherit;outline:none}
#chat-input-bar input:focus{border-color:#ffd700}
#chat-input-bar button{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;
  padding:4px 10px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit}

/* QUEST TRACKER */
#quest-tracker{position:absolute;top:48px;right:10px;
  background:rgba(20,14,6,0.9);border:1px solid #5a3a10;border-radius:4px;
  padding:8px 12px;min-width:180px;max-width:220px}
#quest-tracker .qt-title{color:#ffd700;font-size:12px;font-weight:bold;margin-bottom:4px;
  border-bottom:1px solid #3a2a10;padding-bottom:4px}
#quest-tracker .qt-name{color:#d4a843;font-size:11px;margin-bottom:2px}
#quest-tracker .qt-desc{color:#8b6914;font-size:10px}
#quest-tracker .qt-progress{color:#00ff88;font-size:11px;margin-top:3px}
#quest-tracker .qt-done{color:#888;font-size:11px;font-style:italic}

/* COMBO DISPLAY */
#combo-display{position:fixed;top:40%;right:30px;color:#ffd700;font-size:24px;font-weight:bold;
  text-shadow:0 0 12px rgba(255,215,0,0.6),2px 2px 4px #000;pointer-events:none;z-index:55;
  display:none;transition:opacity 0.3s}
#combo-display.active{display:block}
#combo-display .combo-num{font-size:42px;color:#ff8c00}

/* SHOP BUTTON */
#shop-btn{position:absolute;top:8px;left:80px;
  background:linear-gradient(180deg,rgba(40,28,12,0.95),rgba(20,14,6,0.9));
  border:1px solid #5a3a10;border-radius:4px;padding:6px 14px;cursor:pointer;
  color:#8b6914;font-size:13px;font-family:inherit;transition:all 0.3s}
#shop-btn:hover{border-color:#ffd700;color:#ffd700}
/* HP/MP ORBS */
.orb-container{display:flex;align-items:center;gap:4px}
.orb{width:48px;height:48px;border-radius:50%;position:relative;overflow:hidden;
  border:2px solid #5a3a10;box-shadow:0 0 8px rgba(0,0,0,0.6),inset 0 0 10px rgba(0,0,0,0.4)}
.orb-fill{position:absolute;bottom:0;left:0;width:100%;transition:height 0.3s}
.orb.hp-orb .orb-fill{background:linear-gradient(0deg,#8b0000,#e03030)}
.orb.mp-orb .orb-fill{background:linear-gradient(0deg,#00008b,#3060e0)}
.orb-shine{position:absolute;top:6px;left:10px;width:12px;height:8px;border-radius:50%;
  background:rgba(255,255,255,0.15);transform:rotate(-30deg)}
.orb-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  color:#fff;font-size:9px;font-weight:bold;text-shadow:1px 1px 2px #000;z-index:1;white-space:nowrap}
.orb-label{color:#8b6914;font-size:10px;text-align:center;margin-top:2px}

/* POISON STATUS */
.poison-status{position:absolute;top:50px;left:12px;color:#00ff00;font-size:12px;
  background:rgba(0,40,0,0.8);padding:4px 10px;border-radius:3px;border:1px solid #00ff00;display:none}
.poison-status.active{display:block;animation:poisonPulse 1s ease-in-out infinite}
@keyframes poisonPulse{0%,100%{opacity:1}50%{opacity:0.5}}

/* ═══════════════════════════════════════════
   社交系统面板 (组队/好友/行会)
   ═══════════════════════════════════════════ */

/* 组队面板 */
#party-panel{min-width:320px}
#party-content{padding:10px}
.party-member{display:flex;align-items:center;gap:8px;padding:6px 8px;border-bottom:1px solid #2a1a08;font-size:12px}
.party-member .pm-name{color:#d4a843;flex:1}
.party-member .pm-level{color:#8b6914;width:50px}
.party-member .pm-hp-bar{width:80px;height:8px;background:#1a0a00;border:1px solid #3a2a10;border-radius:2px;overflow:hidden}
.party-member .pm-hp-fill{height:100%;background:linear-gradient(180deg,#e03030,#8b0000);transition:width 0.3s}
.party-member .pm-kick{color:#ff4444;cursor:pointer;font-size:10px;padding:2px 6px;border:1px solid #ff4444;border-radius:2px}
.party-member .pm-kick:hover{background:rgba(255,68,68,0.2)}
.party-member .pm-leader{color:#ffd700;font-size:10px}
.party-invite-bar{display:flex;gap:4px;padding:8px}
.party-invite-bar input{flex:1;background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;padding:4px 8px;border-radius:3px;font-size:11px;font-family:inherit}
.party-invite-bar button{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;padding:4px 10px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit}
.party-btn{background:linear-gradient(180deg,#5a3a10,#3a2010);color:#ffd700;border:1px solid #8b6914;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:11px;font-family:inherit;margin:4px}
.party-btn.leave{border-color:#ff4444;color:#ff4444}

/* 好友面板 */
#friends-panel{min-width:300px}
#friends-content{padding:10px}
.friend-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid #2a1a08;font-size:12px}
.friend-row .fr-status{width:8px;height:8px;border-radius:50%}
.friend-row .fr-status.online{background:#00ff88}
.friend-row .fr-status.offline{background:#555}
.friend-row .fr-name{color:#d4a843;flex:1}
.friend-row .fr-level{color:#8b6914;width:50px}
.friend-row .fr-remove{color:#ff4444;cursor:pointer;font-size:10px;padding:2px 6px;border:1px solid #ff4444;border-radius:2px}
.friend-row .fr-remove:hover{background:rgba(255,68,68,0.2)}
.friend-add-bar{display:flex;gap:4px;padding:8px;border-top:1px solid #3a2a10}
.friend-add-bar input{flex:1;background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;padding:4px 8px;border-radius:3px;font-size:11px;font-family:inherit}
.friend-add-bar button{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;padding:4px 10px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit}

/* 行会面板 */
#guild-panel{min-width:340px}
#guild-content{padding:10px}
.guild-info{background:rgba(0,0,0,0.3);border:1px solid #3a2a10;border-radius:4px;padding:8px;margin-bottom:8px}
.guild-info .gi-name{color:#ffd700;font-size:14px;font-weight:bold}
.guild-info .gi-notice{color:#d4a843;font-size:11px;margin-top:4px}
.guild-info .gi-leader{color:#8b6914;font-size:10px;margin-top:2px}
.guild-member{display:flex;align-items:center;gap:8px;padding:4px 8px;border-bottom:1px solid #2a1a08;font-size:12px}
.guild-member .gm-status{width:6px;height:6px;border-radius:50%}
.guild-member .gm-status.online{background:#00ff88}
.guild-member .gm-status.offline{background:#555}
.guild-member .gm-name{color:#d4a843;flex:1}
.guild-member .gm-level{color:#8b6914}
.guild-member .gm-role{color:#ffd700;font-size:10px}
.guild-create-area{padding:8px;border-top:1px solid #3a2a10}
.guild-create-area input{width:100%;background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;padding:6px 10px;border-radius:3px;font-size:12px;font-family:inherit;margin-bottom:6px}
.guild-create-area button{width:100%;background:linear-gradient(180deg,#5a3a10,#3a2010);color:#ffd700;border:1px solid #8b6914;padding:6px;border-radius:3px;cursor:pointer;font-size:12px;font-family:inherit}
.guild-btn{background:linear-gradient(180deg,#5a3a10,#3a2010);color:#ffd700;border:1px solid #8b6914;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:11px;font-family:inherit;margin:4px}
.guild-btn.leave{border-color:#ff4444;color:#ff4444}
.guild-chat-bar{display:flex;gap:4px;padding:8px;border-top:1px solid #3a2a10}
.guild-chat-bar input{flex:1;background:#1a0a00;border:1px solid #5a3a10;color:#ffd700;padding:4px 8px;border-radius:3px;font-size:11px;font-family:inherit}
.guild-chat-bar button{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;padding:4px 10px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit}

/* 安全区指示器 */
#safe-zone-indicator{position:fixed;top:70px;left:50%;transform:translateX(-50%);
  color:#00ff88;font-size:14px;font-weight:bold;
  background:rgba(0,60,0,0.7);padding:4px 16px;border-radius:4px;
  border:1px solid #00ff88;display:none;z-index:55;
  text-shadow:0 0 8px rgba(0,255,136,0.5)}
#safe-zone-indicator.active{display:block}

/* 竞技场面板/状态 */
#arena-status{position:fixed;top:90px;left:50%;transform:translateX(-50%);
  background:rgba(40,10,10,0.9);border:2px solid #ff4444;border-radius:6px;
  padding:8px 20px;display:none;z-index:55;text-align:center;min-width:200px}
#arena-status.active{display:block}
#arena-status .arena-title{color:#ff4444;font-size:14px;font-weight:bold}
#arena-status .arena-timer{color:#ffd700;font-size:24px;font-weight:bold;margin:4px 0}
#arena-status .arena-vs{color:#d4a843;font-size:12px}
#arena-status .arena-leave-btn{background:rgba(255,68,68,0.2);color:#ff4444;border:1px solid #ff4444;padding:4px 12px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit;margin-top:6px}

/* 排行榜标签页 */
.lb-tabs{display:flex;gap:0;border-bottom:1px solid #5a3a10}
.lb-tab{flex:1;text-align:center;padding:8px;color:#8b6914;font-size:12px;cursor:pointer;
  border-bottom:2px solid transparent;transition:all 0.2s}
.lb-tab:hover,.lb-tab.active{color:#ffd700;border-bottom-color:#ffd700}

/* 队伍成员HP悬浮显示 */
#party-hud{position:fixed;top:120px;left:8px;display:none;z-index:20}
#party-hud.active{display:block}
.party-hud-member{background:rgba(10,5,0,0.85);border:1px solid #5a3a10;border-radius:3px;
  padding:4px 8px;margin-bottom:3px;min-width:140px}
.party-hud-member .phm-name{color:#d4a843;font-size:11px}
.party-hud-member .phm-bar{width:100%;height:6px;background:#1a0a00;border-radius:2px;margin-top:2px;overflow:hidden}
.party-hud-member .phm-fill{height:100%;background:linear-gradient(90deg,#e03030,#ff4444);transition:width 0.3s}

/* 组队邀请弹窗 */
#party-invite-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:linear-gradient(180deg,rgba(40,28,12,0.97),rgba(20,14,6,0.97));
  border:2px solid #ffd700;border-radius:6px;padding:16px 24px;display:none;z-index:100;
  text-align:center;min-width:260px;box-shadow:0 0 30px rgba(0,0,0,0.8)}
#party-invite-popup.active{display:block}
#party-invite-popup .pip-text{color:#d4a843;font-size:13px;margin-bottom:12px}
#party-invite-popup .pip-btns{display:flex;gap:8px;justify-content:center}
#party-invite-popup .pip-btn{padding:6px 20px;border-radius:4px;cursor:pointer;font-size:12px;font-family:inherit}
#party-invite-popup .pip-accept{background:linear-gradient(180deg,#2a5a2a,#1a3a1a);color:#00ff88;border:1px solid #00ff88}
#party-invite-popup .pip-decline{background:linear-gradient(180deg,#5a2a2a,#3a1a1a);color:#ff4444;border:1px solid #ff4444}

/* NPC DIALOGUE */
#npc-dialogue{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);
  background:linear-gradient(180deg,rgba(40,28,12,0.97),rgba(20,14,6,0.97));
  border:2px solid #8b6914;border-radius:8px;padding:16px 24px;min-width:320px;max-width:400px;
  display:none;z-index:60;box-shadow:0 0 30px rgba(0,0,0,0.8)}
#npc-dialogue.active{display:block}
#npc-dialogue .npc-name{color:#00ff88;font-size:14px;font-weight:bold;margin-bottom:8px}
#npc-dialogue .npc-text{color:#d4a843;font-size:13px;line-height:1.6;margin-bottom:12px}
#npc-dialogue .npc-options{display:flex;flex-direction:column;gap:6px}
.npc-option{background:rgba(0,0,0,0.4);border:1px solid #5a3a10;border-radius:4px;
  padding:8px 12px;color:#ffd700;font-size:12px;cursor:pointer;font-family:inherit;
  transition:all 0.2s;text-align:center}
.npc-option:hover{border-color:#ffd700;background:rgba(139,105,20,0.2)}

/* ACHIEVEMENT PANEL */
#achieve-panel{min-width:340px;max-width:400px}
#achieve-content{padding:10px;max-height:400px;overflow-y:auto}
.achieve-item{display:flex;align-items:center;gap:8px;padding:8px;border-bottom:1px solid #3a2a10}
.achieve-item.locked{opacity:0.5}
.achieve-item .ach-icon{font-size:20px;width:28px;text-align:center}
.achieve-item .ach-info{flex:1}
.achieve-item .ach-name{color:#ffd700;font-size:12px;font-weight:bold}
.achieve-item .ach-desc{color:#8b6914;font-size:10px}
.achieve-item .ach-title{color:#00ff88;font-size:10px}
.achieve-title-btn{background:rgba(0,0,0,0.4);border:1px solid #5a3a10;border-radius:3px;
  padding:3px 8px;color:#ffd700;font-size:9px;cursor:pointer;font-family:inherit}
.achieve-title-btn:hover{border-color:#ffd700}
.achieve-title-btn.active{border-color:#00ff88;color:#00ff88}
.active-title-display{text-align:center;padding:8px;color:#ffd700;font-size:13px;
  border-bottom:1px solid #5a3a10;margin-bottom:6px}

/* EQUIPMENT SET BONUSES */
.set-bonus-section{padding:8px 10px;border-top:1px solid #3a2a10;margin-top:6px}
.set-bonus-title{color:#ffd700;font-size:11px;font-weight:bold;margin-bottom:4px}
.set-bonus-item{color:#00ff88;font-size:10px;padding:2px 0}
.set-bonus-inactive{color:#5a3a10;font-size:10px;padding:2px 0}

/* AUCTION HOUSE */
#auction-panel{min-width:420px;max-width:500px}
.auction-tabs{display:flex;border-bottom:1px solid #5a3a10}
.auction-tab{flex:1;text-align:center;padding:8px;color:#8b6914;font-size:12px;cursor:pointer;
  border-bottom:2px solid transparent}
.auction-tab:hover,.auction-tab.active{color:#ffd700;border-bottom-color:#ffd700}
.auction-list{padding:8px;max-height:300px;overflow-y:auto}
.auction-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-bottom:1px solid #2a1a08;cursor:pointer}
.auction-item:hover{background:rgba(139,105,20,0.1)}
.auction-item .ai-icon{font-size:20px;width:28px;text-align:center}
.auction-item .ai-info{flex:1}
.auction-item .ai-name{font-size:11px;font-weight:bold}
.auction-item .ai-seller{font-size:9px;color:#8b6914}
.auction-item .ai-price{color:#ffd700;font-size:12px;font-weight:bold;white-space:nowrap}
.auction-item .ai-buy{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;border-radius:3px;
  padding:3px 8px;font-size:10px;cursor:pointer;font-family:inherit}
.auction-item .ai-buy:hover{background:#7b5020}
.auction-create{padding:10px;border-top:1px solid #3a2a10}
.auction-create-row{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.auction-create-row label{color:#d4a843;font-size:11px;min-width:50px}
.auction-create-row input,.auction-create-row select{background:#1a0a00;color:#ffd700;border:1px solid #5a3a10;
  border-radius:3px;padding:4px 6px;font-size:11px;font-family:inherit}
.auction-create-btn{background:linear-gradient(180deg,#5a3a10,#3a2010);color:#ffd700;border:1px solid #8b6914;
  padding:6px 16px;border-radius:3px;cursor:pointer;font-size:11px;font-family:inherit;width:100%}
.auction-create-btn:hover{background:linear-gradient(180deg,#7b5020,#5a3a10)}

/* DUNGEON SYSTEM */
#dungeon-panel{min-width:360px}
.dungeon-card{padding:10px;border-bottom:1px solid #3a2a10;cursor:pointer}
.dungeon-card:hover{background:rgba(139,105,20,0.1)}
.dungeon-card .dc-name{color:#ffd700;font-size:14px;font-weight:bold}
.dungeon-card .dc-desc{color:#d4a843;font-size:11px;margin:4px 0}
.dungeon-card .dc-info{color:#8b6914;font-size:10px}
.dungeon-card .dc-enter{background:#5a3a10;color:#ffd700;border:1px solid #8b6914;border-radius:3px;
  padding:4px 12px;font-size:11px;cursor:pointer;float:right;margin-top:-20px}
.dungeon-card .dc-enter:hover{background:#7b5020}
.dungeon-card .dc-locked{color:#ff4444;font-size:10px}
#dungeon-hud{position:fixed;top:50px;left:50%;transform:translateX(-50%);
  background:rgba(20,14,6,0.95);border:1px solid #8b6914;border-radius:4px;padding:6px 16px;
  display:none;z-index:55;text-align:center}
#dungeon-hud.active{display:block}
#dungeon-hud .dh-name{color:#ffd700;font-size:13px;font-weight:bold}
#dungeon-hud .dh-wave{color:#d4a843;font-size:11px}
#dungeon-hud .dh-timer{color:#ff4444;font-size:12px}

/* ============ MOBILE CONTROLS ============ */
#mobile-controls{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:90}
#mobile-controls>*{pointer-events:auto}
#joystick-zone{position:absolute;bottom:calc(30px + env(safe-area-inset-bottom,0));left:calc(20px + env(safe-area-inset-left,0));width:150px;height:150px}
#joystick-base{width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,0.12);border:2px solid rgba(255,255,255,0.25);position:relative;display:flex;align-items:center;justify-content:center}
#joystick-thumb{width:50px;height:50px;border-radius:50%;background:rgba(255,215,0,0.5);border:2px solid rgba(255,215,0,0.7);position:absolute;transition:none}
#mobile-btns-right{position:absolute;bottom:calc(30px + env(safe-area-inset-bottom,0));right:calc(15px + env(safe-area-inset-right,0));display:flex;flex-direction:column;gap:8px;align-items:center}
.m-btn{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff;border:2px solid rgba(255,215,0,0.5);background:rgba(40,28,12,0.7);user-select:none;-webkit-user-select:none;touch-action:none}
.m-btn:active,.m-btn.pressed{background:rgba(139,105,20,0.7);transform:scale(0.92)}
.m-btn-attack{width:64px;height:64px;font-size:24px;border-color:rgba(255,60,60,0.6);background:rgba(80,20,20,0.7)}
#mobile-btns-right .m-btn-skill{font-size:16px;font-weight:bold;width:48px;height:48px}
#mobile-btns-right{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr);gap:8px;bottom:25px;right:10px}
.m-btn-attack{grid-column:1/3;justify-self:center}
#mobile-btns-top{position:absolute;top:calc(45px + env(safe-area-inset-top,0));right:calc(8px + env(safe-area-inset-right,0));display:flex;gap:5px}
.m-btn-sm{min-width:38px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#d4a634;border:1px solid rgba(139,105,20,0.5);background:rgba(40,28,12,0.8);padding:0 6px;user-select:none;-webkit-user-select:none}
.m-btn-sm:active{background:rgba(139,105,20,0.6)}
#mobile-more-menu{position:absolute;top:calc(82px + env(safe-area-inset-top,0));right:calc(8px + env(safe-area-inset-right,0));display:grid;grid-template-columns:repeat(3,1fr);gap:4px;background:rgba(20,14,6,0.95);border:1px solid #5a3a10;border-radius:6px;padding:8px;z-index:95}
.m-menu-btn{padding:8px 10px;text-align:center;color:#d4a634;font-size:12px;border:1px solid rgba(90,58,16,0.5);border-radius:4px;background:rgba(40,28,12,0.6);user-select:none;-webkit-user-select:none}
.m-menu-btn:active{background:rgba(139,105,20,0.5)}
#mobile-status-card{position:absolute;top:calc(90px + env(safe-area-inset-top,0));left:calc(12px + env(safe-area-inset-left,0));width:190px;padding:10px 12px;background:linear-gradient(180deg,rgba(20,14,6,0.94),rgba(10,7,3,0.9));border:1px solid rgba(139,105,20,0.55);border-radius:10px;box-shadow:0 12px 28px rgba(0,0,0,0.28)}
.msc-head,.msc-meta,.msc-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.msc-head{margin-bottom:8px}
#msc-name{color:#ffd700;font-size:13px;font-weight:bold;max-width:72px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#msc-zone{color:#d4a634;font-size:10px;text-align:right;opacity:0.9}
.msc-bars{display:flex;flex-direction:column;gap:6px}
.msc-row strong{color:#fff;font-size:10px;min-width:34px;text-align:right}
.msc-label{color:#8b6914;font-size:10px;width:18px}
.msc-track{flex:1;height:7px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden}
.msc-fill{height:100%;border-radius:inherit;transition:width .2s ease}
.msc-fill.hp{background:linear-gradient(90deg,#ff5454,#941d1d)}
.msc-fill.mp{background:linear-gradient(90deg,#5d8eff,#183f92)}
.msc-meta{margin-top:8px;color:#d4a634;font-size:10px}
#mobile-target-card{position:absolute;top:calc(90px + env(safe-area-inset-top,0));right:calc(12px + env(safe-area-inset-right,0));width:180px;padding:10px 12px;background:linear-gradient(180deg,rgba(20,14,6,0.94),rgba(10,7,3,0.9));border:1px solid rgba(139,105,20,0.5);border-radius:10px;box-shadow:0 12px 28px rgba(0,0,0,0.28)}
.mtc-name{color:#ffd700;font-size:12px;font-weight:bold;margin-bottom:4px}
.mtc-desc{color:#d4a634;font-size:10px;line-height:1.35}
#mobile-quick-tabs{position:absolute;bottom:calc(112px + env(safe-area-inset-bottom,0));left:50%;transform:translateX(-50%);display:flex;gap:6px;padding:6px 8px;border-radius:999px;background:rgba(20,14,6,0.9);border:1px solid rgba(139,105,20,0.45);box-shadow:0 10px 22px rgba(0,0,0,0.22)}
.m-quick-tab{min-width:52px;height:28px;padding:0 10px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#d4a634;background:rgba(40,28,12,0.55);border:1px solid rgba(139,105,20,0.25);user-select:none;-webkit-user-select:none}
.m-quick-tab.active,.m-quick-tab:active{color:#fff3d1;border-color:rgba(255,215,0,0.55);background:rgba(139,105,20,0.45)}
#m-chat-toggle{position:absolute;top:calc(90px + env(safe-area-inset-top,0));right:calc(200px + env(safe-area-inset-right,0));min-width:34px;z-index:91}
body.mobile-chat-collapsed #chat-log,body.mobile-chat-collapsed #chat-input-bar{display:none}
body.mobile-chat-collapsed #mobile-target-card{top:90px}

/* ============ MOBILE RESPONSIVE ============ */
@media(max-width:768px){
  #top-bar{top:4px;gap:6px;font-size:11px;flex-wrap:wrap;max-width:70%}
  .stat{font-size:11px;padding:2px 6px}
  #bottom-hud{padding:4px 6px}
  .bar-container{margin:1px 0}
  .bar-label{font-size:10px;min-width:22px}
  .bar-text{font-size:9px}
  #skill-bar{gap:3px;justify-content:center}
  .skill-slot{width:36px;height:36px}
  .skill-slot .skill-icon{font-size:16px}
  .skill-slot .skill-key{display:none}
  .skill-slot .skill-name{font-size:7px}
  .potion-info{font-size:10px}
  #chat-log{width:200px;max-height:100px;bottom:70px;font-size:10px;left:4px}
  #chat-log p{font-size:9px;padding:1px 4px}
  #chat-input-bar{width:200px}
  #chat-input{font-size:11px}
  #quest-tracker{top:4px;right:auto;left:4px;min-width:120px;max-width:160px;padding:4px 8px;font-size:10px}
  #qt-name{font-size:10px}
  #qt-desc{font-size:9px}
  .panel{min-width:unset!important;width:92vw!important;max-height:75vh!important;left:50%!important;transform:translate(-50%,-50%)!important}
  .panel-title{font-size:14px}
  .panel-close{font-size:16px;width:28px;height:28px}
  #inv-panel .inv-grid{grid-template-columns:repeat(5,1fr)}
  .inv-slot{width:48px;height:48px}
  .inv-slot .item-name{font-size:8px}
  .shop-item{padding:6px}
  .shop-item .shop-name{font-size:11px}
  #enhance-panel{min-width:unset}
  #tooltip{max-width:180px;font-size:11px}
  #tooltip .tt-name{font-size:12px}
  #auto-btn{top:4px;left:auto;right:auto;display:none}
  #vol-ctrl{display:none}
  #safe-zone-indicator{top:auto;bottom:70px;right:4px;font-size:10px}
  #zone-name{font-size:20px;top:12%}
  #controls-overlay{padding:10px}
  #controls-overlay h2{font-size:16px}
  .ctrl-section h3{font-size:12px}
  .ctrl-row{font-size:11px}
  .ctrl-key{font-size:10px;padding:2px 6px}
  #npc-dialogue{width:88vw;left:6vw;bottom:80px}
  .trade-item-grid{grid-template-columns:repeat(4,1fr)}
  .lb-tabs{flex-wrap:wrap;gap:2px}
  .lb-tab{font-size:10px;padding:3px 6px}
  #auto-insight{top:auto;bottom:calc(164px + env(safe-area-inset-bottom,0));left:8px;max-width:calc(100vw - 16px)}
  #mobile-status-card{top:calc(78px + env(safe-area-inset-top,0));left:calc(8px + env(safe-area-inset-left,0));width:168px;padding:8px 10px}
  #mobile-target-card{top:calc(78px + env(safe-area-inset-top,0));right:calc(8px + env(safe-area-inset-right,0));width:160px;padding:8px 10px}
  #mobile-quick-tabs{bottom:calc(104px + env(safe-area-inset-bottom,0));gap:4px;padding:5px 6px}
  .m-quick-tab{min-width:46px;height:26px;font-size:10px;padding:0 8px}
  #m-chat-toggle{top:calc(78px + env(safe-area-inset-top,0));right:calc(174px + env(safe-area-inset-right,0))}
}
@media(max-width:480px){
  #top-bar{gap:3px;max-width:60%}
  .stat{font-size:10px;padding:1px 4px}
  .panel{width:96vw!important;max-height:70vh!important}
  #chat-log{width:160px;max-height:80px}
  #chat-input-bar{width:160px}
  #quest-tracker{max-width:130px}
  .inv-slot{width:42px;height:42px}
  #mobile-btns-right{bottom:20px;right:8px;gap:6px}
  .m-btn{width:48px;height:48px;font-size:18px}
  .m-btn-attack{width:56px;height:56px}
  #joystick-zone{bottom:calc(20px + env(safe-area-inset-bottom,0));left:calc(10px + env(safe-area-inset-left,0))}
  #joystick-base{width:100px;height:100px}
  #joystick-thumb{width:42px;height:42px}
  #auto-insight{bottom:calc(148px + env(safe-area-inset-bottom,0));left:6px;right:6px;max-width:none}
  #mobile-status-card{top:calc(72px + env(safe-area-inset-top,0));left:calc(6px + env(safe-area-inset-left,0));width:150px}
  #mobile-target-card{top:calc(72px + env(safe-area-inset-top,0));right:calc(6px + env(safe-area-inset-right,0));width:140px}
  #mobile-quick-tabs{bottom:calc(96px + env(safe-area-inset-bottom,0));max-width:calc(100vw - 140px);overflow-x:auto}
  #m-chat-toggle{top:calc(72px + env(safe-area-inset-top,0));right:calc(150px + env(safe-area-inset-right,0))}
}
