:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;color:#17202a;background:#eef3f8;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{width:min(1440px,calc(100vw - 40px));margin:0 auto;padding:28px 0 48px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:20px}h1,h2,p{margin:0}h1{font-size:clamp(28px,4vw,42px);line-height:1.12}h2{font-size:20px}.eyebrow{margin-bottom:8px;color:#2f6f73;font-size:13px;font-weight:800;letter-spacing:0;text-transform:uppercase}.muted{color:#657384}.login-shell{min-height:calc(100vh - 56px);display:grid;place-items:center}.login-card{width:min(460px,100%);display:grid;gap:22px;padding:32px;background:#fff;border:1px solid #dce4ed;border-radius:8px;box-shadow:0 20px 60px #212d3d1f}.control-band,.panel,.info-card{background:#fff;border:1px solid #dce4ed;border-radius:8px;box-shadow:0 12px 40px #212d3d14}.control-band{display:grid;grid-template-columns:minmax(260px,1fr) minmax(160px,190px) auto auto auto;gap:14px;align-items:end;padding:18px;margin-bottom:14px}label{display:grid;gap:7px;font-size:13px;font-weight:700;color:#425166}.readonly-field{min-height:42px;display:grid;gap:7px;color:#425166;font-size:13px;font-weight:700}.readonly-field strong{min-height:42px;display:flex;align-items:center;overflow:hidden;padding:10px 12px;color:#17202a;background:#f1f5f9;border:1px solid #d8e1eb;border-radius:7px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}input{width:100%;min-height:42px;padding:10px 12px;color:#17202a;background:#f8fafc;border:1px solid #cfd8e4;border-radius:7px;outline:none}input:focus{border-color:#2f8f83;box-shadow:0 0 0 3px #2f8f8324}.primary-btn,.ghost-btn{min-height:42px;padding:0 16px;border-radius:7px;font-weight:800;white-space:nowrap}.primary-btn{color:#fff;background:#216f69;border:1px solid #216f69}.primary-btn:hover{background:#185c58}.ghost-btn{color:#24364d;background:#fff;border:1px solid #cfd8e4}.ghost-btn:hover{background:#f4f7fa}.success-box,.error-box{margin:14px 0;padding:12px 14px;border-radius:8px;font-weight:700}.success-box{color:#135f3f;background:#e8f7ef;border:1px solid #bde8d0}.error-box{color:#8b2430;background:#fff0f2;border:1px solid #f2bdc5}.grid{display:grid;gap:16px}.overview-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin:18px 0}.report-grid{grid-template-columns:minmax(0,2fr) minmax(260px,1fr);margin:18px 0}.info-card{padding:20px;min-height:132px}.info-card span{display:block;color:#657384;font-weight:800}.info-card strong{display:block;margin:12px 0 6px;font-size:clamp(24px,3vw,34px);line-height:1}.info-card p{color:#657384;font-size:14px}.panel{padding:18px;margin-top:18px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:16px}.search-row{display:grid;grid-template-columns:minmax(180px,260px) auto;gap:10px}.table-wrap{width:100%;overflow-x:auto;border:1px solid #e1e8f0;border-radius:8px}table{width:100%;min-width:760px;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid #e9eef4;text-align:left;white-space:nowrap}th{color:#536274;background:#f7fafc;font-size:13px}tbody tr:last-child td{border-bottom:0}.warn-row td{background:#fff9ec}.pager{display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:14px;color:#536274}.chart-panel{min-height:420px}.bar-chart{display:grid;gap:16px}.bar-row{display:grid;gap:7px}.bar-label{display:flex;justify-content:space-between;gap:14px;color:#2b3b4f}.bar-label span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{height:14px;background:#e7edf4;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,#2f8f83,#5c77c6);border-radius:inherit}.status-list{display:grid;gap:12px}.status-line{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid #e9eef4}.status-line:last-child{border-bottom:0}.status-line span{color:#657384}.empty-state,.center-panel{min-height:180px;display:grid;place-items:center;color:#657384;background:#f8fafc;border:1px dashed #cfd8e4;border-radius:8px;text-align:center;padding:20px}@media(max-width:980px){.app-shell{width:min(100vw - 24px,760px);padding-top:18px}.topbar,.panel-header{align-items:stretch;flex-direction:column}.control-band,.overview-grid,.report-grid{grid-template-columns:1fr}.search-row{grid-template-columns:1fr auto}.pager{justify-content:space-between}}@media(max-width:560px){.search-row,.pager{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.login-card{padding:24px}}
