.lang-switch[data-v-2bea159e]{background:var(--surface-2, #1a1a1a);color:var(--text-dim, #888);border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:3px 6px;font-size:12px;cursor:pointer}.lang-switch[data-v-2bea159e]:focus{outline:none;border-color:var(--gold, #c9a227)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0c11;--surface: #111520;--surface2: #181d2b;--border: #252b3b;--gold: #c9a227;--gold-dim: #8a6e1a;--accent: #e84545;--accent2: #8b1a1a;--text: #e8e8f0;--text-dim: #7a7f96;--text-muted:#4a4f62;--success: #2d8a5e;--danger: #c0392b;--info: #2980b9;--hp: #c0392b;--mp: #2471a3;--cp: #1e8449;--shadow: 0 4px 32px rgba(0,0,0,.7);--glow: 0 0 20px rgba(201,162,39,.15);--radius: 8px;--radius-lg: 14px;--font-title:"Cinzel", serif;--font-body: "Inter", sans-serif}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body)}#app{min-height:100vh}a{color:var(--gold);text-decoration:none}a:hover{color:var(--text)}.portal-layout{min-height:100vh;display:flex;flex-direction:column}.portal-nav{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:58px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.portal-nav .logo{font-family:var(--font-title);font-size:16px;font-weight:700;color:var(--gold);letter-spacing:2px}.portal-nav .nav-right{display:flex;align-items:center;gap:16px}.portal-main{flex:1;max-width:1100px;margin:0 auto;padding:32px 20px;width:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.card+.card{margin-top:20px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 20px;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-primary{background:var(--gold);color:#0a0c11}.btn-primary:hover{background:#ddb730}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#a93226}.btn-sm{padding:6px 14px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-full{width:100%}.form-group{margin-bottom:18px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}.form-input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:14px;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--gold)}.form-input.error{border-color:var(--danger)}.form-hint{font-size:11px;color:var(--text-dim);margin-top:4px}.form-error{font-size:12px;color:var(--danger);margin-top:4px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:radial-gradient(ellipse at 50% 0%,rgba(201,162,39,.08) 0%,transparent 60%);padding:20px}.auth-box{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 32px;box-shadow:var(--shadow),var(--glow)}.auth-logo{font-family:var(--font-title);font-size:22px;font-weight:700;color:var(--gold);text-align:center;margin-bottom:4px;letter-spacing:3px}.auth-subtitle{text-align:center;color:var(--text-dim);font-size:13px;margin-bottom:28px}.auth-divider{text-align:center;color:var(--text-muted);font-size:12px;margin:18px 0}.auth-footer{text-align:center;margin-top:20px;font-size:13px;color:var(--text-dim)}.alert{padding:12px 16px;border-radius:var(--radius);font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.alert-error{background:#c0392b26;border:1px solid rgba(192,57,43,.4);color:#e88}.alert-success{background:#2d8a5e26;border:1px solid rgba(45,138,94,.4);color:#7dc}.alert-info{background:#2980b926;border:1px solid rgba(41,128,185,.4);color:#8bf}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-gold{background:#c9a22733;color:var(--gold);border:1px solid var(--gold-dim)}.badge-danger{background:#c0392b33;color:#e88;border:1px solid rgba(192,57,43,.4)}.badge-success{background:#2d8a5e33;color:#7dc;border:1px solid rgba(45,138,94,.4)}.badge-dim{background:#7a7f961a;color:var(--text-dim);border:1px solid var(--border)}.badge-online{background:#2d8a5e33;color:#5dbd8a;border:1px solid rgba(45,138,94,.3)}.badge-offline{background:#4a4f6226;color:var(--text-muted);border:1px solid var(--border)}.stat-bar-wrap{margin:4px 0}.stat-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim);margin-bottom:3px}.stat-bar-track{height:6px;background:var(--bg);border-radius:99px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:99px;transition:width .4s}.stat-bar-hp .stat-bar-fill{background:var(--hp)}.stat-bar-mp .stat-bar-fill{background:var(--mp)}.stat-bar-cp .stat-bar-fill{background:var(--cp)}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 50%,var(--surface2) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border-radius:4px}.sk-line{height:14px;margin:8px 0}.sk-line.lg{height:22px}.sk-line.sm{height:10px}.sk-block{height:80px;border-radius:var(--radius);margin:12px 0}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.char-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.char-card:hover{border-color:var(--gold-dim);box-shadow:0 0 16px #c9a2271a;transform:translateY(-2px)}.char-card.dead{border-color:#c0392b4d;filter:grayscale(.4)}.char-card.dead:hover{border-color:#c0392b99}.char-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.class-icon{width:44px;height:44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.char-name{font-family:var(--font-title);font-size:15px;font-weight:600}.char-class{font-size:11px;color:var(--text-dim);margin-top:2px}.char-stats{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap}.char-stat{font-size:11px;color:var(--text-dim)}.char-stat strong{color:var(--text);font-size:12px}.dead-overlay{position:absolute;top:10px;right:10px;font-size:11px;font-weight:700;background:#c0392be6;color:#fff;padding:2px 8px;border-radius:99px;letter-spacing:1px}.equip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.equip-slot{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:11px}.equip-slot-name{color:var(--text-dim);margin-bottom:4px;text-transform:uppercase;font-size:10px;letter-spacing:.5px}.equip-slot-item{color:var(--gold);font-size:12px}.equip-slot-empty{color:var(--text-muted);font-style:italic}.section-title{font-family:var(--font-title);font-size:13px;font-weight:600;color:var(--gold);letter-spacing:2px;text-transform:uppercase;padding-bottom:10px;margin-bottom:16px;border-bottom:1px solid var(--border)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:60px}.sub-list{list-style:none}.sub-list li{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.sub-list li:last-child{border-bottom:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}@media (max-width: 640px){.auth-box{padding:28px 20px}.portal-main{padding:20px 14px}.char-grid{grid-template-columns:1fr}}
