*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}body{font-family:Segoe UI,Microsoft YaHei,system-ui,sans-serif;font-size:14px;color:#1a1a2e;background:#f4f6fa;-webkit-font-smoothing:antialiased}.btn{display:inline-flex;align-items:center;gap:6px;padding:0 14px;height:34px;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,color .12s,transform .08s;font-family:inherit}.btn:hover{background:#f9fafb;border-color:#9ca3af}.btn:active{transform:scale(.98)}.btn.primary{background:#2563eb;color:#fff;border-color:#2563eb}.btn.primary:hover{background:#1d4ed8;border-color:#1d4ed8}.btn.danger{background:#fff;color:#dc2626;border-color:#fca5a5}.btn.danger:hover{background:#fef2f2;border-color:#dc2626}.btn.success{background:#fff;color:#16a34a;border-color:#86efac}.btn.success:hover{background:#f0fdf4;border-color:#16a34a}.btn.sm{height:28px;padding:0 10px;font-size:12px}.btn:disabled{opacity:.45;cursor:not-allowed}.input{height:36px;padding:0 12px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-family:inherit;color:#111827;background:#fff;outline:none;transition:border-color .12s,box-shadow .12s}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1f}.input::placeholder{color:#9ca3af}textarea.input{padding:8px 12px;height:auto;line-height:1.55}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#1e40af,#2563eb)}.login-card{width:380px;background:#fff;border-radius:14px;padding:40px 36px;box-shadow:0 20px 60px #00000040}.login-card .brand{text-align:center;margin-bottom:32px}.login-card .brand-icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#60a5fa);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px;color:#fff;font-weight:700;box-shadow:0 8px 20px #2563eb59}.login-card h1{font-size:22px;font-weight:700;color:#111827;margin:0 0 4px}.login-card .sub{font-size:13px;color:#6b7280}.login-card label{display:block;font-size:12px;font-weight:600;color:#374151;margin-bottom:5px}.login-card .field{margin-bottom:18px}.login-card .field .input{width:100%}.login-err{color:#dc2626;font-size:12.5px;margin-top:-10px;margin-bottom:12px}.layout{display:flex;min-height:100vh}.sidebar{width:230px;flex-shrink:0;background:linear-gradient(180deg,#1a2540,#1e2b4a);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-brand{padding:22px 22px 18px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar-brand h2{margin:0;font-size:16px;font-weight:700;color:#fff;letter-spacing:.02em}.sidebar-brand span{font-size:11px;color:#ffffff6b}.sidebar-nav{padding:14px 10px;flex:1;overflow-y:auto}.nav-group{padding:12px 12px 6px;font-size:10.5px;font-weight:700;letter-spacing:.12em;color:#ffffff59;text-transform:uppercase}.nav-group:first-child{padding-top:0}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;color:#ffffff9e;font-size:13.5px;font-weight:500;cursor:pointer;margin-bottom:2px;transition:background .12s,color .12s;border:0;background:transparent;width:100%;text-align:left;font-family:inherit}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:linear-gradient(90deg,#2563eb8c,#2563eb59);color:#fff;box-shadow:inset 3px 0 #60a5fa}.nav-item>span:first-child{font-size:14.5px;width:18px;text-align:center}.sidebar-foot{padding:14px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:12px;color:#fff6}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{padding:14px 30px 12px;background:#fff;border-bottom:1px solid #e7ebf2;flex-shrink:0}.topbar h1{margin:0;font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.01em}.topbar .sub{margin:3px 0 0;font-size:12.5px;color:#6b7280}.page-body{flex:1;padding:22px 30px;overflow:auto;max-width:1600px}.stat-grid{display:grid;gap:14px;margin-bottom:22px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.stat-card{background:#fff;border-radius:10px;padding:18px 22px;border:1px solid #e7ebf2;box-shadow:0 1px 2px #00000008;transition:box-shadow .15s,transform .15s,border-color .15s}.stat-card:hover{box-shadow:0 4px 14px #0000000f;border-color:#cbd5e1}.stat-card .num{font-size:28px;font-weight:700;color:#0f172a;line-height:1.1;font-variant-numeric:tabular-nums}.stat-card .label{font-size:12.5px;color:#6b7280;margin-top:4px}.stat-card .trend{font-size:12px;color:#16a34a;margin-top:2px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.toolbar .input{width:280px;max-width:100%}.table-wrap{background:#fff;border-radius:10px;border:1px solid #e7ebf2;box-shadow:0 1px 2px #00000008;overflow:hidden}.table-wrap>h3{padding:14px 18px;margin:0;font-size:14px;font-weight:600;color:#111827;border-bottom:1px solid #f1f5f9}table{width:100%;border-collapse:collapse}thead{position:sticky;top:0;z-index:2}th{text-align:left;padding:11px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;background:#f8fafc;border-bottom:1px solid #e7ebf2;white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid #f1f5f9;color:#1f2937;vertical-align:middle;font-size:13px}tbody tr:last-child td{border-bottom:0}tbody tr{transition:background .08s}tbody tr:hover td{background:#f8fafc}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge.active{background:#dcfce7;color:#15803d}.badge.banned{background:#fee2e2;color:#b91c1c}.badge.free{background:#f3f4f6;color:#4b5563}.badge.pro{background:#dbeafe;color:#1d4ed8}.empty{text-align:center;padding:64px 20px;color:#94a3b8}.empty p{margin:8px 0 0;font-size:13.5px}.empty:before{content:"📭";display:block;font-size:42px;margin-bottom:10px;opacity:.5}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 16px;border-top:1px solid #f1f5f9;font-size:13px;color:#6b7280}.page-btn{width:30px;height:30px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.12s;font-family:inherit;color:#374151}.page-btn:hover{border-color:#2563eb;color:#2563eb}.page-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.page-btn:disabled{opacity:.35;cursor:not-allowed}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:14px;padding:26px 28px;width:440px;max-width:calc(100vw - 40px);box-shadow:0 24px 60px #0f172a4d;animation:popIn .18s ease-out}@keyframes popIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal h3{margin:0 0 10px;font-size:16.5px;font-weight:700;color:#0f172a}.modal p{margin:0 0 18px;font-size:13.5px;color:#4b5563;line-height:1.6}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding-top:14px}
