:root{--primary:#E50914;--primary-2:#FF2B3D;--primary-soft:#fde8ea;--primary-soft-2:#fbd5d8;--bg:#f0f2f5;--surface:#ffffff;--surface-2:#fafafa;--line:#eaecef;--line-2:#d9dde3;--text:#1d2129;--text-2:#4e5969;--dim:#86909c;--dim-2:#a9b0bd;--green:#00b42a;--green-soft:#e8ffea;--orange:#ff7d00;--orange-soft:#fff3e8;--blue:#165dff;--blue-soft:#e8f3ff;--gold:#ff9a2e;--r:8px;--r-sm:6px;--sh:0 1px 2px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.05);--sh-h:0 4px 16px rgba(0,0,0,.1);--sidebar-w:228px;--topbar-h:56px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#c9cdd4;border-radius:5px}::-webkit-scrollbar-track{background:transparent}.admin-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);flex:0 0 auto;background:var(--surface);border-right:1px solid var(--line);position:fixed;top:0;left:0;bottom:0;z-index:50;display:flex;flex-direction:column}.sb-logo{height:var(--topbar-h);display:flex;align-items:center;gap:10px;padding:0 18px;border-bottom:1px solid var(--line)}.sb-logo .mk{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:15px}.sb-logo b{font-size:16px;font-weight:800}.sb-logo span{font-size:11px;color:var(--dim);font-weight:600}.sb-nav{flex:1;overflow-y:auto;padding:10px 0 24px}.sb-group{padding:14px 18px 6px;font-size:11px;font-weight:700;color:var(--dim-2);letter-spacing:.5px}.sb-item{display:flex;align-items:center;gap:10px;padding:9px 18px;color:var(--text-2);font-size:13.5px;border-left:3px solid transparent;transition:.15s;cursor:pointer}.sb-item:hover{background:var(--surface-2);color:var(--text)}.sb-item .ic{width:18px;text-align:center;font-size:15px;flex:0 0 auto}.sb-item.on{background:var(--primary-soft);color:var(--primary);font-weight:700;border-left-color:var(--primary)}.sb-item .badge{margin-left:auto;background:var(--primary);color:#fff;font-size:10.5px;font-weight:700;padding:0 6px;height:16px;line-height:16px;border-radius:8px}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:40}.topbar .crumb{font-size:13px;color:var(--dim);display:flex;align-items:center;gap:7px}.topbar .crumb b{color:var(--text);font-weight:600}.topbar .spacer{flex:1}.topbar .tb-act{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-2);font-size:16px;cursor:pointer;position:relative}.topbar .tb-act:hover{background:var(--surface-2)}.topbar .tb-act .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--primary)}.topbar .user{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 6px;border-radius:20px;cursor:pointer}.topbar .user:hover{background:var(--surface-2)}.topbar .user .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px}.topbar .user b{font-size:13px;font-weight:600}.topbar .user span{font-size:11px;color:var(--dim);display:block;margin-top:-2px}.content{padding:22px 24px 40px;flex:1}.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px;flex-wrap:wrap}.page-head h1{font-size:20px;font-weight:800;margin:0}.page-head .desc{color:var(--dim);font-size:13px}.page-head .spacer{flex:1}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh)}.card-pad{padding:18px 20px}.card-h{display:flex;align-items:center;gap:10px;padding:15px 20px;border-bottom:1px solid var(--line)}.card-h h3{font-size:15px;font-weight:700;margin:0}.card-h .spacer{flex:1}.card-h .more{color:var(--dim);font-size:12.5px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;box-shadow:var(--sh);position:relative;overflow:hidden}.stat-card .lbl{color:var(--dim);font-size:13px;display:flex;align-items:center;gap:7px}.stat-card .lbl .ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px}.stat-card .num{font-size:28px;font-weight:800;margin:10px 0 4px;letter-spacing:-.5px}.stat-card .delta{font-size:12px;font-weight:600}.stat-card .delta.up{color:var(--green)}.stat-card .delta.down{color:var(--primary)}.stat-card .delta span{color:var(--dim);font-weight:400;margin-left:5px}.chart-bars{display:flex;align-items:flex-end;gap:10px;height:180px;padding:10px 4px 0}.chart-bars .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%;justify-content:flex-end}.chart-bars .bar{width:60%;max-width:30px;border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--primary-2),var(--primary));transition:.3s;position:relative}.chart-bars .bar.b2{background:linear-gradient(180deg,#ffd0d4,#ffa7ad)}.chart-bars .col:hover .bar{filter:brightness(1.08)}.chart-bars .lab{font-size:11.5px;color:var(--dim)}.legend{display:flex;gap:18px;font-size:12.5px;color:var(--dim)}.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:6px;vertical-align:middle}.donut-wrap{display:flex;align-items:center;gap:24px}.dist{list-style:none;margin:0;padding:0;flex:1}.dist li{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:13px}.dist li .dt{width:10px;height:10px;border-radius:3px;flex:0 0 auto}.dist li .nm{flex:1;color:var(--text-2)}.dist li .vl{font-weight:700}.dist li .pc{color:var(--dim);width:42px;text-align:right}.todo{list-style:none;margin:0;padding:0}.todo li{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}.todo li:last-child{border-bottom:none}.todo .ti{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 auto}.todo .tx{flex:1}.todo .tx b{font-size:13.5px}.todo .tx span{font-size:12px;color:var(--dim);display:block}.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.quick a{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:1px solid var(--line);border-radius:var(--r);background:var(--surface-2);font-size:13px;font-weight:600;color:var(--text-2);transition:.15s}.quick a:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft);transform:translateY(-2px)}.quick a .qi{font-size:22px}.seg-tabs{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:3px;gap:2px}.seg-tabs button{height:26px;padding:0 13px;border:none;background:transparent;color:var(--text-2);font-size:13px;font-weight:600;border-radius:5px;cursor:pointer}.seg-tabs button.on{background:var(--surface);color:var(--primary);box-shadow:var(--sh)}.role-grid{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start}.role-item{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line);cursor:pointer}.role-item:last-child{border-bottom:none}.role-item.on{background:var(--primary-soft);border-left:3px solid var(--primary)}.role-item .ri{flex:1}.role-item .ri b{font-size:14px}.role-item .ri span{font-size:12px;color:var(--dim);display:block}.perm-group{border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:14px;overflow:hidden}.perm-group .ph{background:var(--surface-2);padding:11px 16px;display:flex;align-items:center;gap:10px;font-weight:700;font-size:13.5px}.perm-group .pb{padding:12px 16px;display:flex;flex-wrap:wrap;gap:14px}.muted{color:var(--dim)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.mt{margin-top:18px}.mb{margin-bottom:18px}.cell-title{color:var(--text);font-weight:600;display:flex;align-items:center;gap:9px}.cell-title .thumb{width:46px;height:32px;border-radius:5px;background:linear-gradient(135deg,#e9ebef,#dfe2e8);flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#a9b0bd;font-size:13px}.cell-sub{color:var(--dim);font-size:12px;font-weight:400;margin-top:2px}@media (max-width:1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}}.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;background:radial-gradient(900px 480px at 15% 10%,rgba(229,9,20,.1),transparent 55%),#f0f2f5}.login{width:920px;max-width:94vw;background:var(--surface);border-radius:16px;box-shadow:0 18px 60px #0000001f;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;border:1px solid var(--line)}.login .hero{background:linear-gradient(150deg,#7a0c12,#e50914 55%,#ff2b3d);color:#fff;padding:48px 44px;position:relative;display:flex;flex-direction:column}.login .hero .mk{width:46px;height:46px;border-radius:12px;background:#ffffff2e;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:900}.login .hero h2{font-size:26px;font-weight:900;margin-top:24px;letter-spacing:-.5px}.login .hero p{opacity:.9;margin-top:12px;font-size:14px;line-height:1.8}.login .hero ul{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:13px;padding:0}.login .hero li{display:flex;align-items:center;gap:10px;font-size:13.5px;opacity:.95}.login .hero li .d{width:22px;height:22px;border-radius:7px;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:12px}.login .hero .ver{margin-top:auto;font-size:12px;opacity:.7}.login .form-side{padding:48px 46px;display:flex;flex-direction:column;justify-content:center}.login .form-side h1{font-size:23px;font-weight:800;margin:0}.login .form-side .sub{color:var(--dim);font-size:13.5px;margin:8px 0 28px}.login .tip{margin-top:18px;font-size:12px;color:var(--dim);text-align:center}@media (max-width:760px){.login{grid-template-columns:1fr}.login .hero{display:none}}
