*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,"Microsoft YaHei",sans-serif}
body{background:#f0f2f5;color:#000000d9;font-size:14px;-webkit-font-smoothing:antialiased}
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1677ff 0%,#001529 100%)}
.loginbox{background:#fff;padding:40px 40px 32px;border-radius:14px;box-shadow:0 12px 48px #00000038;width:360px}
.loginbox h1{font-size:21px;margin-bottom:4px;text-align:center}
.loginbox .sub{font-size:13px;color:#00000059;text-align:center;margin-bottom:24px}
.loginbox input{width:100%;padding:11px 13px;border:1px solid #d9d9d9;border-radius:8px;margin-bottom:14px;font-size:14px;transition:border-color .2s,box-shadow .2s}
.loginbox input:focus{outline:0;border-color:#1677ff;box-shadow:0 0 0 2px #1677ff22}
.err{color:#ff4d4f;font-size:13px;margin-bottom:10px;min-height:18px}
.app{display:none;min-height:100vh}
.app.on{display:flex}
.sider{width:224px;background:#001529;color:#fff;flex:none;position:fixed;top:0;bottom:0;left:0;overflow-y:auto}
.logo{height:60px;display:flex;align-items:center;gap:10px;padding:0 22px;font-size:16px;font-weight:600;border-bottom:1px solid #ffffff14;background:#00112b}
.role{font-size:11px;color:#ffffff59;padding:16px 22px 6px;letter-spacing:1px}
.menu a{display:flex;align-items:center;margin:2px 12px;padding:10px 14px;color:#ffffffa6;text-decoration:none;font-size:14px;cursor:pointer;border-radius:8px;transition:background .18s,color .18s,box-shadow .18s}
.menu a.on{background:#1677ff;color:#fff;box-shadow:0 2px 8px #1677ff66}
.menu a:hover:not(.on){color:#fff;background:#ffffff14}
.main{flex:1;margin-left:224px;display:flex;flex-direction:column}
.top{height:56px;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:0 1px 4px #00152914;position:sticky;top:0;z-index:9}
.top .who{font-size:13px;color:#00000073}
.body{padding:22px 24px;overflow:auto}
.h1{font-size:18px;font-weight:600;margin:0}
.intro{background:linear-gradient(90deg,#e6f4ff,#f3f8ff);border:1px solid #bae0ff;border-left:4px solid #1677ff;border-radius:8px;padding:11px 16px;margin-bottom:16px;font-size:13px;color:#00000099;line-height:1.75}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.card{background:#fff;border-radius:10px;padding:18px 20px;box-shadow:0 1px 2px #00152914;border-top:3px solid #1677ff;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00152921}
.card .n{font-size:28px;font-weight:700;margin-top:6px;color:#001529}
.card .l{font-size:13px;color:#00000073}
.card .up{color:#52c41a;font-size:12px}.card .dn{color:#ff4d4f;font-size:12px}
.card:nth-child(2){border-top-color:#52c41a}.card:nth-child(3){border-top-color:#722ed1}.card:nth-child(4){border-top-color:#fa8c16}
.panel{background:#fff;border-radius:10px;padding:18px 22px;margin-bottom:16px;box-shadow:0 1px 2px #00152914}
.panel h3{font-size:15px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;padding-left:10px;border-left:3px solid #1677ff}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:#00000073;font-weight:500;padding:10px 12px;background:#fafafa;border-bottom:1px solid #f0f0f0}
td{padding:11px 12px;border-bottom:1px solid #f0f0f0}
tbody tr:hover td,table tr:hover td{background:#fafcff}
.tag{font-size:12px;padding:1px 8px;border-radius:4px;white-space:nowrap}
.t-ok{background:#f6ffed;color:#52c41a}.t-warn{background:#fff7e6;color:#d48806}.t-dead{background:#fff1f0;color:#ff4d4f}.t-blue{background:#e6f4ff;color:#1677ff}
.btn{background:#1677ff;color:#fff;border:0;border-radius:7px;padding:7px 15px;font-size:13px;cursor:pointer;transition:background .18s,box-shadow .18s}
.btn:hover{background:#0958d9;box-shadow:0 2px 8px #1677ff4d}
.btn.block{width:100%;padding:11px}
.btn.gray{background:#fff;color:#00000073;border:1px solid #d9d9d9}
.btn.gray:hover{background:#fafafa;color:#000000a6;box-shadow:none}
.btn:disabled{opacity:.5;cursor:not-allowed}
.in{padding:7px 11px;border:1px solid #d9d9d9;border-radius:7px;font-size:13px;width:160px;transition:border-color .2s,box-shadow .2s}
.in:focus{outline:0;border-color:#1677ff;box-shadow:0 0 0 2px #1677ff22}
.row{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.tabbar{display:flex;gap:4px;margin-bottom:16px;flex-wrap:wrap}
.tabbar a{padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer;background:#fff;color:#00000073;text-decoration:none}
.tabbar a.on{background:#1677ff;color:#fff}
.note{font-size:12px;color:#00000073;margin-top:10px;line-height:1.75}
.mask{display:none;position:fixed;inset:0;background:#00000066;z-index:100;align-items:center;justify-content:center}
.mask.on{display:flex}
.modal{background:#fff;border-radius:10px;width:420px;max-width:92vw;box-shadow:0 8px 40px #00152933;overflow:hidden}
.modal h3{font-size:16px;font-weight:600;padding:18px 22px;border-bottom:1px solid #f0f0f0}
.modal .mbody{padding:18px 22px;max-height:60vh;overflow:auto}
.fld{margin-bottom:14px}
.fld label{display:block;font-size:13px;color:#00000073;margin-bottom:6px}
.fld input,.fld select{width:100%;padding:9px 11px;border:1px solid #d9d9d9;border-radius:6px;font-size:14px}
.mwarn{font-size:13px;color:#d48806;background:#fff7e6;border:1px solid #ffe7ba;border-radius:6px;padding:9px 12px;margin-bottom:14px}
.mfoot{padding:14px 22px;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end;gap:10px}
.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);background:#fff;border-radius:8px;padding:11px 18px;font-size:13px;box-shadow:0 4px 20px #00152933;z-index:200;display:none;border-left:3px solid #52c41a}
.toast.err{border-left-color:#ff4d4f}
.toast.on{display:block}
