*{box-sizing:border-box}body{margin:0;min-width:1120px;background:#f4f7fb;color:#1e2430;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.58}input,select{height:38px;min-width:0;padding:0 12px;border:1px solid #d8e0ec;border-radius:6px;background:#fff;color:#1e2430;outline:none}input:focus,select:focus{border-color:#2f6df6;box-shadow:0 0 0 3px #2f6df61f}h1,h2,h3,p{margin:0;letter-spacing:0}.eyebrow{margin-bottom:8px;color:#6b7486;font-size:13px;font-weight:700}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px;background:linear-gradient(135deg,#e8f0ffeb,#f8fafc 48%,#eaf9f3),#f5f7fb}.login-shell{width:min(1120px,100%);min-height:660px;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(390px,.92fr);overflow:hidden;border:1px solid rgb(255 255 255 / 78%);border-radius:8px;background:#ffffffd1;box-shadow:0 28px 80px #24314d24}.brand-panel{display:flex;flex-direction:column;justify-content:space-between;padding:34px;color:#fff;background:linear-gradient(145deg,#266df6f5,#158078),#2f6df6}.brand-topline,.sidebar-brand,.login-heading,.signal-grid article,.session-box{display:flex;align-items:center}.brand-topline{gap:14px}.brand-topline div,.sidebar-brand div{display:flex;flex-direction:column;gap:4px}.brand-topline strong{font-size:18px}.brand-topline span:not(.brand-mark){color:#ffffffbd;font-size:13px}.brand-mark{width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;flex:none;border-radius:8px;color:#2f6df6;background:#fff;font-weight:800;box-shadow:0 12px 26px #0a1f442e}.brand-mark.small{width:38px;height:38px;color:#fff;background:#2f6df6;box-shadow:none}.brand-copy{max-width:610px}.brand-copy .eyebrow{color:#ffffffb8}.brand-copy h1{max-width:560px;font-size:40px;line-height:1.15;font-weight:800}.brand-copy p:last-child{max-width:560px;margin-top:20px;color:#ffffffc7;font-size:16px;line-height:1.8}.signal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.signal-grid article{min-height:104px;flex-direction:column;justify-content:center;gap:8px;border:1px solid rgb(255 255 255 / 18%);border-radius:8px;background:#ffffff1f}.signal-grid span{color:#ffffffa8;font-size:12px}.signal-grid strong{font-size:16px}.login-card{display:flex;flex-direction:column;justify-content:center;gap:18px;padding:58px;background:linear-gradient(180deg,#fff,#fbfcff)}.login-heading{justify-content:space-between;gap:20px;margin-bottom:8px}.login-heading h2{font-size:30px}.login-heading>span{flex:none;padding:7px 10px;border-radius:999px;background:#ecfdf3;color:#087443;font-size:12px;font-weight:700}.login-card label{display:flex;flex-direction:column;gap:8px;color:#536071;font-size:14px}.login-card input{height:44px}.login-card button,.actions button,.filters button,.pagination button,.session-box button{min-height:38px;border:0;border-radius:6px;background:#2f6df6;color:#fff;font-weight:700}.login-card button{height:46px;margin-top:4px}.login-note{color:#7a8496;font-size:13px;line-height:1.7}.shell{display:grid;grid-template-columns:250px 1fr;min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:26px;padding:24px;background:#fff;border-right:1px solid #e2e8f0}.sidebar-brand{gap:12px;padding-bottom:14px;border-bottom:1px solid #edf1f6}.sidebar h1{font-size:17px}.sidebar p,.session-box span{color:#6b7486;font-size:12px}nav{display:flex;flex-direction:column;gap:8px}nav button{min-height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;border:0;border-radius:6px;background:transparent;color:#445064;text-align:left;font-weight:700}nav button span{width:30px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:#edf2f8;color:#6b7486;font-size:11px}nav button.active{background:#eef5ff;color:#1d4ed8}nav button.active span{background:#2f6df6;color:#fff}.session-box{flex-direction:column;align-items:stretch;gap:8px;margin-top:auto;padding:14px;border:1px solid #e5ebf3;border-radius:8px;background:#f8fafc}.session-box strong{color:#1e2430;font-size:16px}.session-box button{background:#e8edf5;color:#3f4a5f}.content{min-width:0;padding:30px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:22px}.topbar h2{font-size:28px}.actions,.filters,.pagination{display:flex;align-items:center;gap:10px}.actions button,.filters button,.pagination button{padding:0 16px}.filters .ghost{background:#edf2f8;color:#445064}.error{margin:0 0 18px;padding:12px 14px;border-radius:6px;background:#fff1f1;color:#b42318;font-size:14px}.error.compact{margin:0}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.metric,.panel,.toolbar,.chart-panel{border:1px solid #e2e8f0;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1e293b0d}.metric{display:flex;flex-direction:column;gap:10px;padding:22px}.metric span{color:#687084;font-size:14px}.metric strong{color:#2f6df6;font-size:34px}.chart-panel{display:flex;flex-direction:column;gap:18px;min-height:260px;padding:20px}.chart-panel.wide{grid-column:span 2}.chart-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.chart-head h3{font-size:17px}.chart-head span{color:#687084;font-size:13px}.line-bars{display:flex;flex-direction:column;gap:13px}.line-row{display:grid;grid-template-columns:54px 1fr 56px;align-items:center;gap:12px;color:#687084;font-size:13px}.line-row strong{color:#1e2430;font-size:13px;text-align:right}.line-track{height:12px;overflow:hidden;border-radius:999px;background:#edf2f8}.line-fill{height:100%;min-width:8px;border-radius:999px;background:#2f6df6}.line-fill.task{background:#16a34a}.mini-bars{display:grid;grid-template-columns:repeat(7,1fr);align-items:end;gap:10px;height:180px}.mini-bar{display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;color:#687084;font-size:12px}.mini-track{display:flex;align-items:flex-end;width:100%;flex:1;overflow:hidden;border-radius:8px;background:#edf2f8}.mini-fill{width:100%;min-height:8px;border-radius:8px 8px 0 0;background:#2f6df6}.list-page{display:flex;flex-direction:column;gap:16px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px}.toolbar h3{font-size:18px}.toolbar p{margin-top:6px;color:#687084;font-size:14px}.filters{flex-wrap:wrap;justify-content:flex-end;max-width:760px}.filters input,.filters select{width:150px}.filters input[placeholder*=昵称]{width:220px}.panel{overflow:hidden}table{width:100%;border-collapse:collapse}th,td{max-width:280px;padding:14px 16px;border-bottom:1px solid #edf1f6;text-align:left;font-size:14px;vertical-align:middle}th{background:#f8fafc;color:#687084;font-weight:700}td{overflow-wrap:anywhere}.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;color:#526071;font-size:12px}.badge{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#eef5ff;color:#1d4ed8;font-size:12px;font-weight:700}.amount{color:#15803d;font-weight:800}.amount.negative{color:#b42318}.empty{margin:0;padding:28px;color:#687084}.pagination{justify-content:flex-end;color:#687084;font-size:14px}.pagination strong{color:#1e2430}.pagination button{background:#fff;color:#445064;border:1px solid #d8e0ec}
