:root{--bg-primary: #0a0e1a;--bg-secondary: #111827;--bg-card: #1a2235;--bg-card-hover: #1e2a3f;--bg-input: #0d1321;--bg-sidebar: #0d1117;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-primary: #6366f1;--accent-primary-hover: #818cf8;--accent-secondary: #f59e0b;--accent-success: #10b981;--accent-danger: #ef4444;--accent-info: #3b82f6;--border-color: #1e293b;--border-light: rgba(255,255,255,.06);--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-gold: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--shadow-glow: 0 0 20px rgba(99,102,241,.15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--transition: all .2s ease;--transition-slow: all .35s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%}a{color:var(--accent-primary);text-decoration:none;transition:var(--transition)}a:hover{color:var(--accent-primary-hover)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:260px;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border-color)}.sidebar-logo{display:flex;align-items:center;gap:12px}.sidebar-logo .logo-icon{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff}.sidebar-logo .logo-text{font-size:16px;font-weight:700;color:var(--text-primary)}.sidebar-logo .logo-sub{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.sidebar-nav{padding:12px 10px;flex:1}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:12px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);margin-bottom:2px}.nav-item:hover{background:#ffffff0a;color:var(--text-primary)}.nav-item.active{background:#6366f11f;color:var(--accent-primary)}.nav-item .nav-icon{font-size:18px;width:20px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color)}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff}.user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.user-role{font-size:11px;color:var(--text-muted)}.btn-logout{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:6px;border-radius:var(--radius-sm);transition:var(--transition)}.btn-logout:hover{color:var(--accent-danger);background:#ef44441a}.main-content{flex:1;overflow-y:auto;padding:28px 32px}.page-header{margin-bottom:28px}.page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.page-subtitle{font-size:14px;color:var(--text-secondary)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:var(--transition)}.card:hover{border-color:#6366f133}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:16px;font-weight:600}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;transition:var(--transition-slow);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card.purple:before{background:var(--gradient-primary)}.stat-card.gold:before{background:var(--gradient-gold)}.stat-card.green:before{background:var(--gradient-success)}.stat-card.blue:before{background:var(--gradient-info)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);border-color:#6366f14d}.stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px}.stat-value{font-size:28px;font-weight:800;color:var(--text-primary);line-height:1}.stat-icon{position:absolute;top:16px;right:16px;font-size:28px;opacity:.15}.table-container{overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0}thead th{background:var(--bg-secondary);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap;cursor:pointer;transition:var(--transition)}thead th:first-child{border-radius:var(--radius-md) 0 0 0}thead th:last-child{border-radius:0 var(--radius-md) 0 0}thead th:hover{color:var(--text-primary)}tbody tr{transition:var(--transition)}tbody tr:hover{background:#ffffff05}tbody td{padding:14px 16px;font-size:14px;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}tbody td.name{font-weight:600;color:var(--text-primary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:12px;font-weight:600;white-space:nowrap}.badge.level{background:#6366f126;color:#a5b4fc}.badge.gold-badge{background:#f59e0b26;color:#fbbf24}.badge.job,.badge.sent{background:#3b82f626;color:#93c5fd}.badge.received{background:#10b98126;color:#6ee7b7}.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:0 14px;transition:var(--transition);margin-bottom:20px}.search-bar:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.search-bar .search-icon{color:var(--text-muted);font-size:16px}.search-bar input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px;padding:12px 0;font-family:inherit}.search-bar input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn-ghost:hover{background:#ffffff0a;color:var(--text-primary);border-color:var(--text-muted)}.btn-sm{padding:6px 12px;font-size:12px}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px}.pagination button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);font-family:inherit}.pagination button:hover:not(:disabled){border-color:var(--accent-primary);color:var(--accent-primary)}.pagination button.active{background:var(--gradient-primary);border-color:transparent;color:#fff}.pagination button:disabled{opacity:.35;cursor:not-allowed}.pagination-info{font-size:13px;color:var(--text-muted);margin:0 12px}.tabs{display:flex;gap:4px;background:var(--bg-secondary);border-radius:var(--radius-md);padding:4px;margin-bottom:24px;overflow-x:auto}.tab{padding:10px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;background:transparent;font-family:inherit}.tab:hover{color:var(--text-primary);background:#ffffff0a}.tab.active{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.char-header{display:flex;align-items:center;gap:20px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);margin-bottom:24px;position:relative;overflow:hidden}.char-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary)}.char-avatar{width:64px;height:64px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;flex-shrink:0}.char-info h1{font-size:22px;font-weight:700;margin-bottom:4px}.char-meta{display:flex;gap:12px;flex-wrap:wrap}.char-meta-item{font-size:13px;color:var(--text-secondary)}.char-meta-item span{color:var(--text-primary);font-weight:600}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.detail-item{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:14px 16px}.detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px}.detail-value{font-size:18px;font-weight:700;color:var(--text-primary)}.detail-value.str{color:#ef4444}.detail-value.sta{color:#10b981}.detail-value.dex{color:#f59e0b}.detail-value.int{color:#6366f1}.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:6px}.inv-slot{width:52px;height:52px;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;position:relative;cursor:default;transition:var(--transition)}.inv-slot.has-item{border-color:#6366f14d;cursor:pointer}.inv-slot.has-item:hover{border-color:var(--accent-primary);transform:scale(1.08);z-index:2;box-shadow:var(--shadow-glow)}.inv-slot img{max-width:36px;max-height:36px;image-rendering:pixelated}.inv-slot .item-count{position:absolute;bottom:1px;right:3px;font-size:10px;font-weight:700;color:var(--accent-secondary)}.inv-slot .item-upgrade{position:absolute;top:1px;left:3px;font-size:9px;font-weight:700;color:#a5b4fc}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%);top:-100px;right:-100px}.login-page:after{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,.06) 0%,transparent 70%);bottom:-150px;left:-100px}.login-card{width:420px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-lg);position:relative;z-index:1}.login-card .login-logo{text-align:center;margin-bottom:32px}.login-card .login-logo .icon{width:56px;height:56px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;margin-bottom:12px}.login-card .login-logo h2{font-size:20px;font-weight:700}.login-card .login-logo p{font-size:13px;color:var(--text-muted);margin-top:4px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-group input{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:inherit;transition:var(--transition);outline:none}.form-group input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11f}.form-error{color:var(--accent-danger);font-size:13px;margin-top:8px}.login-btn{width:100%;padding:13px;margin-top:4px}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted);font-size:14px}.spinner{width:20px;height:20px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .7s linear infinite;margin-right:10px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state .empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}.empty-state p{font-size:14px}.tooltip-wrapper{position:relative}.tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:10px 14px;font-size:12px;color:var(--text-primary);white-space:nowrap;z-index:100;box-shadow:var(--shadow-lg);pointer-events:none}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);margin-bottom:16px;transition:var(--transition)}.back-link:hover{color:var(--accent-primary)}.trade-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:16px;margin-bottom:12px}.trade-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;color:var(--text-muted)}.trade-parties{display:grid;grid-template-columns:1fr 1fr;gap:16px}.trade-party h4{font-size:13px;font-weight:600;margin-bottom:6px}.trade-party.self h4{color:var(--accent-primary)}.trade-party.other h4{color:var(--accent-secondary)}@media(max-width:768px){.sidebar{display:none}.main-content{padding:16px}.stats-grid{grid-template-columns:1fr 1fr}.login-card{width:100%;margin:16px}}
