:root{--bg: #f4f6fb;--panel: #ffffff;--ink: #16202c;--muted: #6b7787;--line: #e4e9f1;--brand: #1f7a5a;--brand-soft: #e7f4ee;--blue: #2563eb;--blue-soft: #e8f0fe;--amber: #d98a0b;--amber-soft: #fdf3e2;--red: #d23b3b;--red-soft: #fdeaea;--green: #1f9d57;--sidebar: #15202b;--radius: 12px;--shadow: 0 1px 2px rgba(20,32,44,.06), 0 4px 16px rgba(20,32,44,.05)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}a{color:inherit}button{font-family:inherit;cursor:pointer}.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);color:#cfd8e3;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sb-brand{padding:20px 18px 14px;font-weight:800;font-size:17px;color:#fff;display:flex;align-items:center;gap:9px;letter-spacing:.2px}.sb-brand .dot{width:26px;height:26px;border-radius:7px;background:var(--brand);display:grid;place-items:center;font-size:15px}.sb-kind{padding:0 18px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#8696a8}.sb-nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px;flex:1;overflow-y:auto}.sb-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:#b6c2d0;text-decoration:none;font-weight:600;font-size:13.5px;transition:background .12s,color .12s}.sb-link:hover{background:#ffffff0f;color:#fff}.sb-link.active{background:var(--brand);color:#fff}.sb-link .ic{width:18px;text-align:center;font-size:15px}.sb-foot{padding:12px;border-top:1px solid rgba(255,255,255,.08)}.sb-user{font-size:12.5px;color:#9fb0c0;padding:4px 8px 10px}.sb-user b{color:#e8eef4;display:block;font-size:13px}.sb-logout{width:100%;background:#ffffff12;color:#d7e0ea;border:none;padding:9px;border-radius:8px;font-weight:600}.sb-logout:hover{background:#ffffff21}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--line);background:var(--panel);position:sticky;top:0;z-index:5}.topbar h1{font-size:19px;margin:0;font-weight:800}.topbar .sub{font-size:12.5px;color:var(--muted);margin-top:1px}.demo-pill{background:var(--amber-soft);color:var(--amber);font-weight:700;font-size:11.5px;padding:4px 10px;border-radius:20px;border:1px solid #f0d9a8}.content{padding:24px 28px;max-width:1180px;width:100%}.grid{display:grid;gap:16px}.cols-4{grid-template-columns:repeat(4,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-2{grid-template-columns:repeat(2,1fr)}@media(max-width:980px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3,.cols-2{grid-template-columns:1fr}}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:18px}.stat .s-lbl{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.stat .s-val{font-size:30px;font-weight:800;line-height:1.1;margin-top:6px}.stat .s-sub{font-size:12px;color:var(--muted);margin-top:4px}.section-h{display:flex;align-items:center;justify-content:space-between;margin:26px 0 12px}.section-h h2{font-size:15.5px;margin:0;font-weight:800}.table-wrap{overflow-x:auto}table.dt{width:100%;border-collapse:collapse;font-size:13.5px}table.dt th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:10px 14px;border-bottom:1px solid var(--line);font-weight:700;white-space:nowrap}table.dt td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top}table.dt tr:last-child td{border-bottom:none}table.dt tbody tr:hover{background:#fafbfe}.t-title{font-weight:700}.t-sub{color:var(--muted);font-size:12px;margin-top:2px;max-width:460px}.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:700;white-space:nowrap}.pill.gray{background:#eef1f6;color:#5a6776}.pill.green{background:var(--brand-soft);color:var(--brand)}.pill.blue{background:var(--blue-soft);color:var(--blue)}.pill.amber{background:var(--amber-soft);color:var(--amber)}.pill.red{background:var(--red-soft);color:var(--red)}.btn{display:inline-flex;align-items:center;gap:7px;justify-content:center;background:var(--brand);color:#fff;border:none;padding:9px 15px;border-radius:9px;font-weight:700;font-size:13.5px}.btn:hover{filter:brightness(1.05)}.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:7px}.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}.btn.ghost:hover{background:#f7f9fc}.btn.blue{background:var(--blue)}.btn.danger{background:#fff;color:var(--red);border:1px solid #f0c9c9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.field{margin-bottom:13px}.field label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin-bottom:5px}.input,.textarea,select.input{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit;background:#fff;color:var(--ink)}.textarea{min-height:90px;resize:vertical}.input:focus,.textarea:focus,select.input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.toolbar .input{width:auto;min-width:220px}.chip{border:1px solid var(--line);background:#fff;color:var(--muted);padding:6px 12px;border-radius:20px;font-size:12.5px;font-weight:600}.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}.bar{height:8px;background:#eef1f6;border-radius:6px;overflow:hidden}.bar>span{display:block;height:100%;background:var(--brand);border-radius:6px}.barrow{margin-bottom:12px}.barrow .lbl{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:4px}.muted{color:var(--muted)}.empty{text-align:center;color:var(--muted);padding:36px 16px}.note{background:var(--blue-soft);border:1px solid #cfe0fb;color:#1b4fa8;border-radius:10px;padding:12px 14px;font-size:13px}.note.warn{background:var(--amber-soft);border-color:#f0d9a8;color:#8a5d05}.note.ok{background:var(--brand-soft);border-color:#bfe4d2;color:#15613f}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;font-size:13.5px;box-shadow:var(--shadow);z-index:100}.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(1200px 600px at 50% -10%,#e7f4ee,var(--bg));padding:20px}.login-card{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:28px}.login-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px;margin-bottom:4px}.login-brand .dot{width:32px;height:32px;border-radius:9px;background:var(--brand);color:#fff;display:grid;place-items:center}.login-sub{color:var(--muted);font-size:13px;margin-bottom:20px}.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:18px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#14202c73;display:grid;place-items:center;z-index:50;padding:20px}.modal{background:#fff;border-radius:14px;width:100%;max-width:440px;box-shadow:var(--shadow)}.modal-head{padding:16px 20px;border-bottom:1px solid var(--line);font-weight:800;display:flex;justify-content:space-between;align-items:center}.modal-body{padding:20px}.x-btn{background:none;border:none;font-size:20px;color:var(--muted);line-height:1}
