.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);font-family:Noto Sans SC,PingFang SC,sans-serif}.login-card{background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:48px 40px;width:380px;box-shadow:0 25px 50px #0006}.login-logo{text-align:center;margin-bottom:36px}.login-icon{font-size:40px;display:block;margin-bottom:12px;line-height:1;color:#a78bfa}.login-logo h1{color:#fff;font-size:22px;font-weight:700;margin:0 0 4px;letter-spacing:1px}.login-sub{color:#fff6;font-size:12px;margin:0;letter-spacing:2px;text-transform:uppercase}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#fff9;font-size:13px;font-weight:500}.form-group input{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:12px 16px;color:#fff;font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus{border-color:#7c6ff7;background:rgba(124,111,247,.1)}.form-group input::placeholder{color:#ffffff40}.login-error{background:rgba(255,80,80,.15);border:1px solid rgba(255,80,80,.3);border-radius:8px;padding:10px 14px;color:#ff6b6b;font-size:13px;text-align:center}.login-btn{background:linear-gradient(135deg,#7c6ff7,#a855f7);border:none;border-radius:10px;padding:14px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;margin-top:4px;letter-spacing:1px}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Noto Sans SC,PingFang SC,-apple-system,sans-serif;background:#0d0d14;color:#e0e0f0}.layout{display:flex;min-height:100vh}.sidebar{width:220px;min-height:100vh;background:#111120;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;transition:width .25s ease;position:fixed;top:0;left:0;bottom:0;z-index:100}.layout.collapsed .sidebar{width:64px}.sidebar-header{display:flex;align-items:center;gap:10px;padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.06);min-height:64px}.sidebar-logo{font-size:22px;flex-shrink:0}.sidebar-title{font-size:16px;font-weight:700;color:#fff;flex:1;white-space:nowrap;overflow:hidden;letter-spacing:.5px}.collapse-btn{background:none;border:none;color:#ffffff4d;cursor:pointer;font-size:18px;padding:4px;border-radius:4px;transition:color .2s;flex-shrink:0}.collapse-btn:hover{color:#fff}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;text-decoration:none;color:#ffffff80;font-size:14px;font-weight:500;transition:all .18s;white-space:nowrap;overflow:hidden}.nav-item:hover{background:rgba(124,111,247,.15);color:#ffffffd9}.nav-item.active{background:linear-gradient(135deg,rgba(124,111,247,.3),rgba(168,85,247,.2));color:#c4b5fd;border:1px solid rgba(124,111,247,.3)}.nav-icon{font-size:18px;flex-shrink:0}.nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar-footer{padding:12px 8px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:8px}.admin-info{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px;background:rgba(255,255,255,.04);overflow:hidden}.admin-avatar{width:32px;height:32px;background:linear-gradient(135deg,#7c6ff7,#a855f7);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.admin-meta{display:flex;flex-direction:column;overflow:hidden}.admin-name{font-size:13px;color:#fff;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-role{font-size:11px;color:#ffffff59;text-transform:uppercase;letter-spacing:.5px}.logout-btn{background:rgba(255,80,80,.1);border:1px solid rgba(255,80,80,.2);border-radius:8px;padding:8px 12px;color:#ff6b6b;font-size:13px;cursor:pointer;transition:all .18s;text-align:left;white-space:nowrap;overflow:hidden}.logout-btn:hover{background:rgba(255,80,80,.2)}.main-content{flex:1;margin-left:220px;padding:28px 32px;min-height:100vh;transition:margin-left .25s ease}.layout.collapsed .main-content{margin-left:64px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.page-title{font-size:22px;font-weight:700;color:#fff;letter-spacing:.3px}.card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:20px 24px;margin-bottom:20px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;padding:10px 14px;color:#fff6;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.08);white-space:nowrap}td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.05);color:#fffc;vertical-align:middle}tr:hover td{background:rgba(255,255,255,.02)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500}.badge-green{background:rgba(52,211,153,.15);color:#34d399}.badge-red{background:rgba(248,113,113,.15);color:#f87171}.badge-gray{background:rgba(255,255,255,.08);color:#fff6}.badge-purple{background:rgba(167,139,250,.15);color:#a78bfa}.badge-blue{background:rgba(96,165,250,.15);color:#60a5fa}.badge-yellow{background:rgba(251,191,36,.15);color:#fbbf24}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#7c6ff7,#a855f7);color:#fff}.btn-primary:hover{opacity:.88}.btn-danger{background:rgba(248,113,113,.15);color:#f87171;border:1px solid rgba(248,113,113,.25)}.btn-danger:hover{background:rgba(248,113,113,.25)}.btn-ghost{background:rgba(255,255,255,.06);color:#ffffffb3;border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.input,.select,.textarea{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:9px 13px;color:#fff;font-size:14px;outline:none;width:100%;transition:border-color .18s}.input:focus,.select:focus,.textarea:focus{border-color:#7c6ff7}.input::placeholder,.textarea::placeholder{color:#fff3}.select option{background:#1a1a2e}.textarea{resize:vertical;min-height:100px}.pagination{display:flex;align-items:center;gap:8px;margin-top:20px;justify-content:flex-end}.pagination button{padding:6px 12px;border-radius:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff9;font-size:13px;cursor:pointer}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination button.active{background:rgba(124,111,247,.3);color:#c4b5fd}.page-info{color:#ffffff4d;font-size:13px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:20px}.stat-label{font-size:12px;color:#fff6;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:28px;font-weight:700;color:#fff}.stat-value.purple{color:#a78bfa}.stat-value.green{color:#34d399}.stat-value.red{color:#f87171}.stat-value.blue{color:#60a5fa}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#16162a;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-title{font-size:18px;font-weight:700;color:#fff;margin-bottom:20px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-label{font-size:13px;color:#ffffff80}.loading-wrap,.empty-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#ffffff40;font-size:14px;gap:12px}.loading-wrap .spinner{width:32px;height:32px;border:3px solid rgba(124,111,247,.2);border-top-color:#7c6ff7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;align-items:center}.filter-bar .input,.filter-bar .select{max-width:200px;width:auto}
