*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--gold: #c9a84c;--gold-light: #f0d080;--gold-dark: #8a6a1e;--bg: #07080f;--card-bg: rgba(8, 12, 28, .92);--border: rgba(201, 168, 76, .35);--border-focus: rgba(201, 168, 76, .9);--text: #ddd5c0;--text-dim: #7a7060;--error: #d95f5f;--success: #5fad7a;--input-bg: rgba(255, 255, 255, .04)}#auth-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden;font-family:Segoe UI,system-ui,-apple-system,sans-serif;color:var(--text)}#auth-screen:before,#auth-screen:after{content:"";position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;animation:orb-drift 18s ease-in-out infinite alternate;pointer-events:none}#auth-screen:before{width:600px;height:600px;background:radial-gradient(circle,#1a3a7a,transparent 70%);top:-150px;left:-150px;animation-duration:18s}#auth-screen:after{width:500px;height:500px;background:radial-gradient(circle,#4a1a6a,transparent 70%);bottom:-120px;right:-100px;animation-duration:22s;animation-direction:alternate-reverse}@keyframes orb-drift{0%{transform:translate(0) scale(1)}to{transform:translate(60px,40px) scale(1.15)}}.auth-stars{position:absolute;inset:0;background-image:radial-gradient(1px 1px at 15% 20%,rgba(255,255,255,.6) 0%,transparent 100%),radial-gradient(1px 1px at 45% 10%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 70% 35%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 85% 15%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 30% 55%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 60% 70%,rgba(255,255,255,.5) 0%,transparent 100%),radial-gradient(1px 1px at 10% 80%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 90% 75%,rgba(255,255,255,.4) 0%,transparent 100%),radial-gradient(1px 1px at 50% 90%,rgba(255,255,255,.3) 0%,transparent 100%),radial-gradient(1px 1px at 25% 40%,rgba(255,255,255,.5) 0%,transparent 100%);pointer-events:none}.auth-card{position:relative;z-index:1;width:min(420px,calc(100vw - 32px));background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:40px 36px 36px;backdrop-filter:blur(20px);box-shadow:0 0 0 1px #c9a84c14,0 24px 60px #000000b3,inset 0 1px #ffffff0d}.auth-card:before,.auth-card:after{content:"";position:absolute;width:20px;height:20px;border-color:var(--gold-dark);border-style:solid;opacity:.6}.auth-card:before{top:10px;left:10px;border-width:1px 0 0 1px;border-radius:3px 0 0}.auth-card:after{bottom:10px;right:10px;border-width:0 1px 1px 0;border-radius:0 0 3px}.auth-logo{text-align:center;margin-bottom:28px}.auth-logo-title{font-size:52px;font-weight:900;letter-spacing:10px;text-transform:uppercase;color:var(--gold);text-shadow:0 0 20px rgba(201,168,76,.5),0 0 60px rgba(201,168,76,.2);line-height:1;margin-bottom:4px}.auth-logo-sub{font-size:11px;letter-spacing:4px;text-transform:uppercase;color:var(--text-dim)}.auth-divider{display:flex;align-items:center;gap:12px;margin-bottom:24px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-divider span{font-size:10px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase;white-space:nowrap}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:4px;margin-bottom:28px}.auth-tab{padding:10px;border:none;background:transparent;color:var(--text-dim);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;border-radius:5px;cursor:pointer;transition:all .2s}.auth-tab:hover{color:var(--text)}.auth-tab.active{background:#c9a84c1f;color:var(--gold);box-shadow:0 0 12px #c9a84c14}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-form-panel{display:none;flex-direction:column;gap:14px}.auth-form-panel.active{display:flex}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.field input{background:var(--input-bg);border:1px solid var(--border);border-radius:6px;padding:11px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.field input::placeholder{color:#ffffff26}.field input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #c9a84c1a}.field input.invalid{border-color:var(--error);box-shadow:0 0 0 3px #d95f5f1a}.auth-btn{margin-top:6px;padding:13px;border:1px solid var(--gold-dark);border-radius:7px;background:linear-gradient(135deg,#c9a84c2e,#c9a84c14);color:var(--gold-light);font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.auth-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,168,76,.15),transparent);opacity:0;transition:opacity .2s}.auth-btn:hover:not(:disabled):before{opacity:1}.auth-btn:hover:not(:disabled){border-color:var(--gold);box-shadow:0 0 20px #c9a84c33;color:#fff}.auth-btn:active:not(:disabled){transform:translateY(1px)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-btn .spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(201,168,76,.3);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.auth-message{min-height:20px;font-size:13px;text-align:center;border-radius:5px;padding:0;transition:all .2s}.auth-message.error{color:var(--error);background:#d95f5f14;border:1px solid rgba(217,95,95,.2);padding:10px 14px}.auth-message.success{color:var(--success);background:#5fad7a14;border:1px solid rgba(95,173,122,.2);padding:10px 14px}.auth-footer{margin-top:20px;text-align:center;font-size:11px;color:var(--text-dim);letter-spacing:.5px}.auth-footer a{color:var(--gold-dark);text-decoration:none;transition:color .2s}.auth-footer a:hover{color:var(--gold)}#canvas{display:none}#chat-panel{position:fixed;bottom:18px;left:18px;z-index:100;width:340px;display:flex;flex-direction:column;gap:0;font-family:Segoe UI,system-ui,sans-serif}#chat-log{background:#060914a6;border:1px solid rgba(201,168,76,.2);border-bottom:none;border-radius:8px 8px 0 0;padding:8px 10px;height:160px;overflow-y:auto;display:flex;flex-direction:column;gap:3px;scrollbar-width:thin;scrollbar-color:rgba(201,168,76,.3) transparent;backdrop-filter:blur(6px)}.chat-msg{font-size:12.5px;line-height:1.4;word-break:break-word;color:#d8ceb8}.chat-name{font-weight:700;color:#c9a84c}.chat-msg-self .chat-name{color:#80d080}.chat-msg-system{font-size:11px;color:#b4aa8c8c;font-style:italic}#chat-input-row{background:#060914cc;border:1px solid rgba(201,168,76,.25);border-radius:0 0 8px 8px;padding:6px 8px;backdrop-filter:blur(6px);display:flex;align-items:center;gap:6px}#chat-channel-badge{font-size:11px;font-weight:700;min-width:24px;flex-shrink:0;font-family:inherit}.chat-badge-global{color:#c9a84c}.chat-badge-local{color:#80d080}.chat-badge-private{color:#d080d0}#chat-input{flex:1;background:transparent;border:none;outline:none;color:#e8dfc0;font-size:12.5px;font-family:inherit;caret-color:#c9a84c;min-width:0}#chat-input::placeholder{color:#b4a57866}.chat-prefix{font-size:11px;font-weight:700;margin-right:2px}.chat-ch-global .chat-prefix{color:#c9a84c}.chat-ch-local .chat-prefix{color:#80d080}.chat-ch-private .chat-prefix,.chat-ch-private .chat-name{color:#d080d0}.player-label{font-family:Segoe UI,system-ui,sans-serif;font-size:13px;font-weight:700;color:#f0e080;text-shadow:0 0 6px rgba(0,0,0,.9),0 1px 3px rgba(0,0,0,1);white-space:nowrap;pointer-events:none;user-select:none}#hud-top-right{position:fixed;top:14px;right:18px;z-index:100;display:flex;flex-direction:column;align-items:stretch;gap:6px}#hud-clock{display:flex;align-items:center;gap:8px;background:#080c1cbf;border:1px solid rgba(201,168,76,.3);border-radius:8px;padding:6px 12px 6px 10px;backdrop-filter:blur(8px);user-select:none;pointer-events:none}#hud-stats-top{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:0;background:#080c1cbf;border:1px solid rgba(201,168,76,.25);border-radius:10px;padding:8px 16px;backdrop-filter:blur(8px);pointer-events:none;user-select:none}.hud-stat-block{display:flex;align-items:center;gap:8px}.hud-stat-sep{width:1px;height:22px;background:#c9a84c33;margin:0 14px}.hud-bar-label{font-family:Segoe UI,system-ui,sans-serif;font-size:11px;font-weight:700;letter-spacing:1px;color:#c8b98ccc;width:18px;flex-shrink:0}.hud-bar-track{width:140px;height:10px;background:#ffffff12;border-radius:5px;overflow:hidden}.hud-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.hud-bar-hp{background:linear-gradient(90deg,#b02020,#e04040)}.hud-bar-mp{background:linear-gradient(90deg,#1840a0,#3070d0)}.hud-bar-val{font-family:Segoe UI,system-ui,monospace;font-size:11px;font-weight:600;color:#dcd2b4cc;width:52px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}#hud-logout{background:#080c1cbf;border:1px solid rgba(201,168,76,.25);border-radius:7px;color:#c8af6ecc;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:6px 10px;cursor:pointer;backdrop-filter:blur(8px);transition:border-color .2s,color .2s,background .2s}#hud-logout:hover{border-color:#c9a84cb3;color:#f0d080;background:#c9a84c1a}#hud-icon{font-size:18px;line-height:1}.hud-clock-text{display:flex;flex-direction:column;align-items:flex-start;gap:1px}#hud-time{font-family:Segoe UI,system-ui,monospace;font-size:15px;font-weight:700;color:var(--gold-light, #f0d080);letter-spacing:1px;line-height:1}#hud-label{font-family:Segoe UI,system-ui,sans-serif;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#c8b98ca6;line-height:1}.race-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.race-card{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;cursor:pointer;background:var(--input-bg);transition:border-color .2s,background .2s,box-shadow .2s;user-select:none}.race-card:hover{border-color:#c9a84c80;background:#ffffff0f}.race-card.selected{border-color:var(--gold);background:#c9a84c14;box-shadow:0 0 0 1px #c9a84c1f}.race-card-accent{width:4px;height:36px;border-radius:2px;flex-shrink:0}.race-card-info{flex:1;min-width:0}.race-card-name{font-size:12px;font-weight:700;color:var(--text);letter-spacing:.5px}.race-card-desc{font-size:10px;color:var(--text-dim);margin-top:2px;line-height:1.3}#admin-toggle{background:#8a4aaa26;border:1px solid rgba(138,74,170,.45);border-radius:7px;color:#b482d2e6;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:6px 10px;cursor:pointer;backdrop-filter:blur(8px);transition:border-color .2s,color .2s,background .2s}#admin-toggle:hover,#admin-toggle.active{border-color:#b450dccc;color:#d080ff;background:#8a4aaa40}#admin-panel{position:fixed;top:60px;right:18px;z-index:150;width:380px;max-height:calc(100vh - 80px);overflow-y:auto;background:#080a16f5;border:1px solid rgba(138,74,170,.4);border-radius:10px;box-shadow:0 0 0 1px #8a4aaa14,0 20px 60px #000c,inset 0 1px #ffffff0a;backdrop-filter:blur(20px);flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;color:var(--text);scrollbar-width:thin;scrollbar-color:rgba(138,74,170,.3) transparent}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid rgba(138,74,170,.2);flex-shrink:0}.admin-title{font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#c080f0}.admin-close{background:transparent;border:1px solid rgba(138,74,170,.3);border-radius:4px;color:#b482d2b3;font-size:11px;font-weight:700;padding:3px 8px;cursor:pointer;transition:all .15s}.admin-close:hover{border-color:#b450dccc;color:#d080ff;background:#8a4aaa1f}.admin-tabs{display:flex;gap:2px;padding:8px 12px 0;border-bottom:1px solid rgba(138,74,170,.15);flex-shrink:0}.admin-tab{padding:7px 14px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--text-dim);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-1px}.admin-tab:hover:not(:disabled){color:var(--text)}.admin-tab.active{color:#c080f0;border-bottom-color:#8a4aaa}.admin-tab:disabled{opacity:.35;cursor:not-allowed}.admin-body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:14px}.admin-info{font-size:13px;color:var(--text);padding:8px 10px;background:#8a4aaa0f;border:1px solid rgba(138,74,170,.15);border-radius:6px}.admin-info-name{color:#c080f0;font-weight:700}.admin-section{display:flex;flex-direction:column;gap:7px}.admin-section-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.admin-actions{display:flex;flex-direction:column;gap:8px;padding-top:4px}.admin-save-btn{padding:11px;border:1px solid rgba(138,74,170,.6);border-radius:7px;background:linear-gradient(135deg,#8a4aaa33,#8a4aaa14);color:#d080ff;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .2s}.admin-save-btn:hover:not(:disabled){border-color:#b450dce6;background:#8a4aaa4d;color:#e8a0ff;box-shadow:0 0 16px #8a4aaa4d}.admin-save-btn:disabled{opacity:.45;cursor:not-allowed}.admin-msg{font-size:12px;text-align:center;min-height:18px;border-radius:4px;padding:0;transition:all .2s}.admin-msg.error{color:var(--error);background:#d95f5f14;border:1px solid rgba(217,95,95,.2);padding:7px 12px}.admin-msg.success{color:var(--success);background:#5fad7a14;border:1px solid rgba(95,173,122,.2);padding:7px 12px}.hud-lv-val{font-family:Segoe UI,system-ui,monospace;font-size:14px;font-weight:700;color:var(--gold-light, #f0d080);letter-spacing:1px;min-width:24px;text-align:center;font-variant-numeric:tabular-nums}#hud-xp-bar{position:fixed;bottom:0;left:0;right:0;height:5px;background:#0006;z-index:100;pointer-events:none}#hud-xp-fill{height:100%;background:linear-gradient(90deg,#7040c0,#b060ff);transition:width .4s ease;width:0%}.remote-hp-bar{width:52px;height:6px;background:#0000008c;border-radius:3px;overflow:hidden;pointer-events:none;user-select:none}.remote-hp-fill{height:100%;border-radius:3px;transition:width .2s ease,background .2s ease}.damage-number{font-family:Segoe UI,system-ui,sans-serif;font-size:16px;font-weight:900;color:#ff4040;text-shadow:0 0 6px rgba(0,0,0,.9),0 1px 3px rgba(0,0,0,1);white-space:nowrap;pointer-events:none;user-select:none;animation:dmg-float .95s ease-out forwards}@keyframes dmg-float{0%{opacity:1;transform:translateY(0)}60%{opacity:1;transform:translateY(-28px)}to{opacity:0;transform:translateY(-44px)}}#death-overlay{position:fixed;inset:0;background:#3c0000b8;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:200;pointer-events:none;animation:death-fade-in .4s ease forwards}@keyframes death-fade-in{0%{opacity:0}to{opacity:1}}.death-title{font-family:Segoe UI,system-ui,sans-serif;font-size:72px;font-weight:900;letter-spacing:12px;text-transform:uppercase;color:#cc2020;text-shadow:0 0 30px rgba(200,0,0,.8),0 0 80px rgba(200,0,0,.4);margin-bottom:16px}.death-sub{font-family:Segoe UI,system-ui,sans-serif;font-size:20px;color:#dcbea0d9;letter-spacing:2px}#hud-levelup{position:fixed;top:30%;left:50%;transform:translate(-50%);z-index:150;background:#080c1ce0;border:1px solid rgba(201,168,76,.7);border-radius:10px;padding:18px 40px;font-family:Segoe UI,system-ui,sans-serif;font-size:22px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:var(--gold-light, #f0d080);text-shadow:0 0 20px rgba(201,168,76,.6);box-shadow:0 0 40px #c9a84c33;pointer-events:none;animation:levelup-pop 2.5s ease forwards}@keyframes levelup-pop{0%{opacity:0;transform:translate(-50%) scale(.8)}15%{opacity:1;transform:translate(-50%) scale(1.05)}25%{transform:translate(-50%) scale(1)}70%{opacity:1}to{opacity:0;transform:translate(-50%) scale(1)}}.admin-setting{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#8a4aaa0f;border:1px solid rgba(138,74,170,.15);border-radius:7px}.admin-setting-info{flex:1}.admin-setting-name{font-size:13px;font-weight:600;color:var(--text)}.admin-setting-desc{font-size:10px;color:var(--text-dim);margin-top:2px}.admin-toggle-switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0;margin-left:14px}.admin-toggle-switch input{opacity:0;width:0;height:0}.admin-toggle-slider{position:absolute;inset:0;background:#ffffff1a;border:1px solid rgba(138,74,170,.3);border-radius:24px;cursor:pointer;transition:background .2s,border-color .2s}.admin-toggle-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#c8b4dcb3;border-radius:50%;transition:transform .2s,background .2s}.admin-toggle-switch input:checked+.admin-toggle-slider{background:#8a4aaa66;border-color:#b450dcb3}.admin-toggle-switch input:checked+.admin-toggle-slider:before{transform:translate(18px);background:#d080ff}.admin-mob-coords{display:flex;flex-direction:column;gap:8px;margin-top:10px}.admin-coord-row{display:flex;align-items:center;gap:6px}.admin-coord-label{font-size:11px;font-weight:700;color:var(--text-dim);width:12px;text-align:center;letter-spacing:.5px}.admin-coord-input{width:52px;background:var(--input-bg);border:1px solid var(--border);border-radius:5px;padding:5px 8px;color:var(--text);font-size:13px;outline:none;text-align:center}.admin-coord-input:focus{border-color:#8a4aaa99}.admin-spawn-btn{flex:1;padding:7px 10px;border:1px solid rgba(138,74,170,.5);border-radius:6px;background:#8a4aaa1f;color:#c080f0;font-size:11px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .15s}.admin-spawn-btn:hover{background:#8a4aaa40;border-color:#b450dccc;color:#e0a0ff}.admin-spawn-btn.secondary{background:#ffffff0a;border-color:var(--border);color:var(--text-dim)}.admin-spawn-btn.secondary:hover{background:#8a4aaa1f;border-color:#8a4aaa80;color:#c080f0}.admin-mini-btn{padding:4px 10px;border:1px solid var(--border);border-radius:4px;background:#ffffff0a;color:var(--text-dim);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:all .15s}.admin-mini-btn:hover{border-color:#c9a84c80;color:var(--text)}.admin-mini-btn.danger{border-color:#c83c3c66;color:#dc6464cc}.admin-mini-btn.danger:hover{background:#c83c3c1a;border-color:#dc5050cc;color:#ff8080}.admin-mob-list{display:flex;flex-direction:column;gap:5px;max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(138,74,170,.3) transparent}.admin-mob-row{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#8a4aaa0d;border:1px solid rgba(138,74,170,.12);border-radius:5px}.admin-mob-row-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.admin-mob-row-name{font-size:12px;font-weight:600;color:var(--text)}.admin-mob-row-pos,.admin-mob-row-hp{font-size:10px;color:var(--text-dim)}.admin-mob-empty{font-size:12px;color:var(--text-dim);text-align:center;padding:12px;font-style:italic}#minimap-wrap{position:fixed;top:14px;left:18px;z-index:100;display:flex;flex-direction:column;align-items:center;gap:3px;pointer-events:none;user-select:none}.minimap-label{font-family:Segoe UI,system-ui,sans-serif;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:#c8b98c80}.minimap-canvas{display:block;border:1px solid rgba(201,168,76,.3);border-radius:4px;box-shadow:0 0 12px #0009,inset 0 0 0 1px #ffffff08;image-rendering:pixelated}.minimap-north{position:absolute;top:26px;right:-14px;font-size:9px;font-weight:700;color:#c8b98c80;letter-spacing:1px}#hotbar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:100;display:flex;gap:4px;align-items:center}.hotbar-slot{width:48px;height:48px;background:#060914c7;border:1px solid rgba(201,168,76,.22);border-radius:6px;position:relative;cursor:pointer;transition:border-color .15s,background .15s;backdrop-filter:blur(6px)}.hotbar-slot:hover{border-color:#c9a84c80;background:#c9a84c0f}.hotbar-slot.active{border-color:var(--gold);background:#c9a84c1a;box-shadow:0 0 8px #c9a84c33,inset 0 0 0 1px #c9a84c1a}.hotbar-key{position:absolute;top:3px;left:5px;font-size:9px;font-weight:700;color:#c8b98c66;font-family:Segoe UI,system-ui,monospace;pointer-events:none;line-height:1}.hotbar-slot.active .hotbar-key{color:#f0d080b3}#char-panel-btn{background:#060914bf;border:1px solid rgba(201,168,76,.25);border-radius:7px;color:#c8b98cb3;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:6px 10px;cursor:pointer;backdrop-filter:blur(8px);transition:border-color .2s,color .2s,background .2s}#char-panel-btn:hover,#char-panel-btn.active{border-color:var(--gold);color:var(--gold-light);background:#c9a84c14}#char-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;width:300px;background:#060914f5;border:1px solid rgba(201,168,76,.35);border-radius:10px;padding:0;flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;color:var(--text);box-shadow:0 20px 60px #000c,0 0 0 1px #c9a84c14;backdrop-filter:blur(20px)}.cp-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid rgba(201,168,76,.15)}.cp-title{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}.cp-close{background:transparent;border:1px solid rgba(201,168,76,.25);border-radius:4px;color:var(--text-dim);font-size:11px;padding:2px 8px;cursor:pointer;transition:all .15s}.cp-close:hover{border-color:var(--gold);color:var(--gold-light)}.cp-name{font-size:20px;font-weight:700;color:var(--gold-light);text-align:center;padding:14px 16px 6px;letter-spacing:1px}.cp-badges{display:flex;justify-content:center;gap:8px;padding:0 16px 12px}.cp-badge{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:1px solid;border-radius:20px;padding:2px 10px}.cp-level-row{display:flex;align-items:center;gap:10px;padding:0 16px 14px}.cp-lv-big{font-size:22px;font-weight:900;color:var(--gold);white-space:nowrap;min-width:56px}.cp-xp-info{flex:1;display:flex;flex-direction:column;gap:4px}.cp-xp-bar-wrap{height:6px;background:#ffffff12;border-radius:3px;overflow:hidden}.cp-xp-bar-fill{height:100%;background:linear-gradient(90deg,#5050c0,#8080ff);border-radius:3px;transition:width .3s ease}.cp-xp-text{font-size:10px;color:var(--text-dim);text-align:right}.cp-divider{height:1px;background:#c9a84c1f;margin:0 16px 12px}.cp-stat-row{display:flex;align-items:center;gap:10px;padding:0 16px 10px}.cp-stat-label{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text-dim);width:22px;flex-shrink:0}.cp-bar-wrap{flex:1;height:10px;background:#ffffff12;border-radius:5px;overflow:hidden}.cp-bar-fill{height:100%;border-radius:5px;transition:width .3s ease}.cp-bar-hp{background:linear-gradient(90deg,#b02020,#e04040)}.cp-bar-mp{background:linear-gradient(90deg,#1840a0,#3070d0)}.cp-stat-val{font-size:11px;color:#dcd2b4cc;min-width:72px;text-align:right;font-variant-numeric:tabular-nums;font-family:monospace}.cp-hint{font-size:10px;color:var(--text-dim);text-align:center;padding:8px 16px 14px;letter-spacing:.5px}.ground-item-label{font-size:11px;font-weight:700;color:#f0e060;text-shadow:0 0 6px rgba(0,0,0,.9),0 1px 3px rgba(0,0,0,1);white-space:nowrap;pointer-events:none;user-select:none;background:#0000008c;padding:1px 5px;border-radius:3px}#inv-btn{background:#060914bf;border:1px solid rgba(201,168,76,.25);border-radius:7px;color:#c8b98cb3;font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:6px 10px;cursor:pointer;backdrop-filter:blur(8px);transition:border-color .2s,color .2s,background .2s}#inv-btn:hover,#inv-btn.active{border-color:var(--gold);color:var(--gold-light);background:#c9a84c14}#inv-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;width:340px;background:#060914f5;border:1px solid rgba(201,168,76,.35);border-radius:10px;flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;color:var(--text);box-shadow:0 20px 60px #000c;backdrop-filter:blur(20px);padding-bottom:14px}.inv-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid rgba(201,168,76,.15)}.inv-title{font-size:11px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold)}.inv-close{background:transparent;border:1px solid rgba(201,168,76,.25);border-radius:4px;color:var(--text-dim);font-size:11px;padding:2px 8px;cursor:pointer;transition:all .15s}.inv-close:hover{border-color:var(--gold);color:var(--gold-light)}.inv-section-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);padding:10px 14px 6px;display:flex;justify-content:space-between}.inv-count{color:var(--text-dim);font-weight:400}.inv-equip-row{display:flex;gap:8px;padding:0 14px 10px}.inv-equip-slot{flex:1;display:flex;flex-direction:column;gap:4px;cursor:pointer}.inv-equip-label{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim)}.inv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:0 14px}.inv-slot{aspect-ratio:1;background:#ffffff08;border:1px solid rgba(201,168,76,.15);border-radius:5px;cursor:pointer;transition:border-color .15s,background .15s;overflow:hidden}.inv-slot:hover:not(.inv-slot-empty){border-color:#c9a84c80;background:#c9a84c0d}.inv-slot-empty{cursor:default}.inv-item{display:flex;align-items:center;gap:6px;padding:5px 7px;border:1px solid transparent;border-radius:5px;background:#ffffff08;height:100%;box-sizing:border-box}.inv-item-icon{width:28px;height:28px;border-radius:4px;border:1px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}.inv-item-gem{width:10px;height:10px;border-radius:2px;opacity:.9}.inv-item-info{flex:1;min-width:0}.inv-item-name{font-size:10px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-item-stat{font-size:9px;color:#80d080;margin-top:1px}.inv-item-amount{font-size:10px;font-weight:700;color:var(--gold)}.npc-label{font-family:Segoe UI,system-ui,sans-serif;font-size:12px;font-weight:700;color:#f0d040;text-shadow:0 0 6px #000,1px 1px 0 #000;white-space:nowrap;pointer-events:none;background:#00000059;padding:1px 5px;border-radius:3px}#shop-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:300;width:560px;max-height:80vh;background:#080c18f7;border:1px solid rgba(201,168,76,.45);border-radius:10px;flex-direction:column;font-family:Segoe UI,system-ui,sans-serif;overflow:hidden;box-shadow:0 8px 40px #000000b3}.shop-header{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid rgba(201,168,76,.2);gap:8px}.shop-title{font-size:15px;font-weight:700;color:#c9a84c;flex:1}.shop-gold{font-size:13px;color:gold;font-weight:700}.shop-close{background:none;border:none;color:#a09878;font-size:16px;cursor:pointer;padding:2px 6px;border-radius:4px}.shop-close:hover{color:#c9a84c}.shop-body{display:flex;gap:0;flex:1;overflow:hidden}.shop-col{flex:1;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid rgba(201,168,76,.12)}.shop-col:last-child{border-right:none}.shop-col-label{padding:6px 12px;font-size:11px;font-weight:700;color:#c9a84c99;text-transform:uppercase;letter-spacing:1px;background:#c9a84c0a;border-bottom:1px solid rgba(201,168,76,.1)}.shop-list{overflow-y:auto;flex:1;padding:4px 0;scrollbar-width:thin;scrollbar-color:rgba(201,168,76,.3) transparent}.shop-row{display:flex;align-items:center;gap:8px;padding:6px 12px;transition:background .1s}.shop-row:hover{background:#c9a84c0f}.shop-item-gem{width:14px;height:14px;border-radius:3px;flex-shrink:0}.shop-item-info{flex:1;min-width:0}.shop-item-name{font-size:12.5px;color:#d8ceb8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-item-stat{font-size:11px;color:#80c080}.shop-price{font-size:12px;color:gold;font-weight:700;white-space:nowrap}.shop-btn{font-size:11px;font-weight:700;padding:3px 9px;background:#c9a84c26;border:1px solid rgba(201,168,76,.4);color:#c9a84c;border-radius:4px;cursor:pointer;white-space:nowrap}.shop-btn:hover{background:#c9a84c4d}.shop-btn-disabled{opacity:.35;cursor:not-allowed}.shop-empty{padding:12px;font-size:12px;color:#b4aa8c66;font-style:italic}.shop-error{background:#c832322e;border-bottom:1px solid rgba(200,50,50,.4);color:#ff8080;font-size:12px;padding:7px 14px;text-align:center}
