:root{--navy-950:#0b1f3a;--navy-900:#0e2543;--navy-850:#102a4e;--navy-800:#143160;--navy-700:#1b3c70;--navy-active:#1d3f73;--primary:#14305c;--primary-600:#1b3c70;--primary-hover:#1c4480;--ink:#16243d;--slate:#475569;--slate-light:#64748b;--muted:#94a3b8;--bg:#f4f6fa;--card:#fff;--line:#e7ebf2;--line-soft:#eef1f6;--blue:#2563eb;--blue-soft:#e8eefc;--green:#16a34a;--green-soft:#e6f6ec;--amber:#d97706;--amber-soft:#fdf0dd;--red:#dc2626;--red-soft:#fbe7e7;--purple:#7c3aed;--purple-soft:#efeafc;--teal:#0d9488;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 2px #10264c0f;--shadow:0 2px 10px #10264c0f;--shadow-lg:0 12px 40px #0d204429;--sidebar-w:264px;--sidebar-collapsed:76px;--topbar-h:68px;--font:"Public Sans", system-ui, -apple-system, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdd6e4 padding-box content-box;border:2px solid #0000;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#b3bfd2 padding-box content-box}.app{height:100vh;display:flex;overflow:hidden}.main{flex-direction:column;flex:1;min-width:0;display:flex}.content{flex:1;padding:26px 30px 60px;overflow-y:auto}.content-2col{align-items:flex-start;gap:22px;display:flex}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg, var(--navy-900) 0%, var(--navy-950) 100%);color:#c7d3e6;flex-direction:column;flex-shrink:0;transition:width .22s;display:flex;position:relative}.sidebar.collapsed{width:var(--sidebar-collapsed)}.brand{align-items:center;gap:12px;padding:20px 20px 18px;display:flex}.brand-logo{flex-shrink:0;place-items:center;width:42px;height:42px;display:grid}.brand-text{white-space:nowrap;flex-direction:column;line-height:1.1;display:flex;overflow:hidden}.brand-text .name{color:#fff;letter-spacing:.3px;font-size:18px;font-weight:800}.brand-text .sub{color:#7e93b4;letter-spacing:.2px;margin-top:2px;font-size:10.5px;font-weight:500}.sidebar.collapsed .brand-text{display:none}.nav{flex:1;padding:8px 14px;overflow-y:auto}.nav::-webkit-scrollbar{width:0}.nav-item{color:#aebbd2;cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:13px;margin-bottom:3px;padding:11px 14px;font-size:14.5px;font-weight:500;transition:background .15s,color .15s;display:flex;position:relative}.nav-item svg{stroke-width:1.9px;flex-shrink:0;width:19px;height:19px}.nav-item:hover{color:#e6edf7;background:#ffffff0f}.nav-item.active{background:var(--navy-active);color:#fff;font-weight:600}.nav-item.active:before{content:"";background:#fff;border-radius:0 3px 3px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-14px}.nav-sub{padding-left:30px}.nav-sub .nav-item{padding:8px 14px;font-size:13.5px}.sidebar.collapsed .nav-item span,.sidebar.collapsed .nav-sub{display:none}.sidebar.collapsed .nav-item{justify-content:center}.nav-caret{margin-left:auto;transition:transform .2s}.nav-caret.open{transform:rotate(180deg)}.collapse-btn{color:#8398bd;cursor:pointer;border-top:1px solid #ffffff12;align-items:center;gap:12px;padding:16px 22px;font-size:14px;font-weight:500;display:flex}.collapse-btn:hover{color:#cdd9ec}.collapse-btn svg{width:19px;height:19px}.sidebar.collapsed .collapse-btn span{display:none}.sidebar.collapsed .collapse-btn{justify-content:center}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--line);background:#fff;flex-shrink:0;align-items:center;gap:18px;padding:0 26px;display:flex}.topbar .menu-btn{color:var(--ink);background:0 0;border:none;border-radius:8px;place-items:center;padding:6px;display:grid}.topbar .menu-btn:hover{background:var(--bg)}.topbar .menu-btn svg{width:22px;height:22px}.topbar .page-title{color:var(--ink);font-size:21px;font-weight:700}.topbar .spacer{flex:1}.search{border:1px solid var(--line);width:320px;color:var(--muted);background:#fff;border-radius:10px;align-items:center;gap:9px;padding:9px 13px;display:flex}.search svg{width:17px;height:17px}.search input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:14px}.search .kbd{color:var(--muted);border:1px solid var(--line);border-radius:5px;padding:2px 6px;font-size:11px;font-weight:600}.topbar-bell{color:var(--slate);cursor:pointer;border-radius:8px;place-items:center;padding:6px;display:grid;position:relative}.topbar-bell:hover{background:var(--bg)}.topbar-bell svg{width:21px;height:21px}.topbar-bell .dot{background:var(--red);color:#fff;border:2px solid #fff;border-radius:9px;place-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:grid;position:absolute;top:2px;right:2px}.topbar-divider{background:var(--line);width:1px;height:34px}.user-chip{cursor:pointer;align-items:center;gap:10px;display:flex}.user-avatar{background:var(--navy-800);color:#fff;border-radius:50%;place-items:center;width:38px;height:38px;font-size:13px;font-weight:700;display:grid}.user-meta{line-height:1.2}.user-meta .nm{color:var(--ink);font-size:14px;font-weight:700}.user-meta .rl{color:var(--slate-light);font-size:12px}.user-chip>svg{width:16px;height:16px;color:var(--muted)}.crumb{color:var(--slate-light);align-items:center;gap:8px;margin-bottom:20px;font-size:13.5px;display:flex}.crumb svg{width:15px;height:15px}.crumb .sep{color:var(--muted)}.crumb .cur{color:var(--primary);font-weight:600}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:22px 24px}.card-title{color:var(--ink);font-size:17px;font-weight:700}.card-head{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.link{color:var(--blue);cursor:pointer;font-size:13.5px;font-weight:600}.link:hover{text-decoration:underline}.btn{white-space:nowrap;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:11px 18px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn svg{width:17px;height:17px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-dark{background:var(--navy-900);color:#fff}.btn-dark:hover{background:var(--navy-800)}.btn-outline{color:var(--ink);border-color:var(--line);background:#fff}.btn-outline:hover{background:var(--bg);border-color:#d4dbe6}.btn-ghost{color:var(--slate);background:0 0}.btn-ghost:hover{background:var(--bg)}.btn-sm{border-radius:8px;padding:8px 13px;font-size:13px}.btn-block{width:100%}.field{margin-bottom:18px}.field label{color:var(--ink);margin-bottom:7px;font-size:13px;font-weight:600;display:block}.req{color:var(--red);margin-left:2px}.input,.select,.textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:10px;outline:none;padding:11px 13px;font-size:14px;transition:border .15s,box-shadow .15s}.input::placeholder,.textarea::placeholder{color:var(--muted)}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #14305c1a}.input-icon{position:relative}.input-icon svg{width:17px;height:17px;color:var(--muted);position:absolute;top:50%;left:13px;transform:translateY(-50%)}.input-icon .input{padding-left:40px}.input-icon .eye{cursor:pointer;position:absolute;top:50%;left:auto;right:13px;transform:translateY(-50%)}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.textarea{resize:vertical;min-height:78px}.searchbox{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;display:flex}.searchbox svg{width:17px;height:17px}.searchbox input{color:var(--ink);background:0 0;border:none;outline:none;flex:1;font-size:14px}.filter-chip{border:1px solid var(--line);color:var(--slate);background:#fff;border-radius:10px;align-items:center;gap:8px;padding:9px 13px;font-size:13.5px;display:inline-flex}.filter-chip svg{width:16px;height:16px}.filter-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toggle{cursor:pointer;background:#cbd5e1;border:none;border-radius:14px;flex-shrink:0;width:42px;height:24px;transition:background .18s;position:relative}.toggle:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:left .18s;position:absolute;top:3px;left:3px;box-shadow:0 1px 2px #0003}.toggle.on{background:var(--green)}.toggle.on:after{left:21px}.table-wrap{overflow-x:auto}table.tbl{border-collapse:collapse;width:100%;font-size:13.5px}table.tbl thead th{text-align:left;color:var(--slate-light);border-bottom:1px solid var(--line);white-space:nowrap;background:#fff;padding:13px 16px;font-size:12.5px;font-weight:600}table.tbl tbody td{border-bottom:1px solid var(--line-soft);color:var(--slate);white-space:nowrap;padding:15px 16px}table.tbl tbody tr:last-child td{border-bottom:none}table.tbl tbody tr:hover{background:#fafbfd}.pcode,.strong{color:var(--ink);font-weight:600}.sort-ic{vertical-align:middle;color:var(--muted);margin-left:4px;display:inline-flex}.sort-ic svg{width:13px;height:13px}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:4px 11px;font-size:12px;font-weight:600;line-height:1.4;display:inline-flex}.badge.green{background:var(--green-soft);color:#15803d}.badge.amber{background:var(--amber-soft);color:#b45309}.badge.red{background:var(--red-soft);color:#b91c1c}.badge.blue{background:var(--blue-soft);color:#1d4ed8}.badge.gray{color:#64748b;background:#eef1f6}.badge.purple{background:var(--purple-soft);color:#6d28d9}.badge.orange{color:#c2410c;background:#fdecdc}.pager{align-items:center;gap:6px;display:flex}.pager button{border:1px solid var(--line);min-width:34px;height:34px;color:var(--slate);background:#fff;border-radius:8px;place-items:center;font-size:13.5px;font-weight:600;display:grid}.pager button:hover{background:var(--bg)}.pager button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pager button svg{width:16px;height:16px}.pager .dots{color:var(--muted);padding:0 4px}.tbl-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 24px;display:flex}.count{color:var(--slate-light);font-size:13.5px}.panel{border:1px solid var(--line);border-radius:var(--radius);width:420px;box-shadow:var(--shadow);max-height:calc(100vh - var(--topbar-h) - 86px);background:#fff;flex-direction:column;flex-shrink:0;align-self:stretch;display:flex;position:sticky;top:0}.panel-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:20px 22px;display:flex}.panel-head .pt{color:var(--ink);font-size:17px;font-weight:700}.panel-body{flex:1;padding:20px 22px;overflow-y:auto}.panel-foot{border-top:1px solid var(--line);gap:12px;padding:16px 22px;display:flex}.icon-btn{color:var(--slate-light);cursor:pointer;background:0 0;border:none;border-radius:7px;place-items:center;padding:5px;display:grid}.icon-btn:hover{background:var(--bg);color:var(--ink)}.icon-btn svg{width:18px;height:18px}.stat-grid{grid-template-columns:repeat(4,1fr);gap:18px;display:grid}.stat{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;padding:20px}.stat-top{align-items:flex-start;gap:14px;display:flex}.stat-ic{border-radius:12px;flex-shrink:0;place-items:center;width:48px;height:48px;display:grid}.stat-ic svg{width:24px;height:24px}.stat .lbl{color:var(--slate-light);font-size:13.5px;font-weight:600}.stat .val{color:var(--ink);letter-spacing:-.5px;margin-top:2px;font-size:27px;font-weight:800}.stat .delta{color:var(--slate-light);margin-top:10px;font-size:12.5px}.stat .delta .up{color:var(--green);font-weight:700}.stat .delta .dn{color:var(--red);font-weight:700}.ic-blue{background:var(--blue-soft);color:var(--blue)}.ic-green{background:var(--green-soft);color:var(--green)}.ic-purple{background:var(--purple-soft);color:var(--purple)}.ic-orange{color:#ea7317;background:#fdecdc}.ic-red{background:var(--red-soft);color:var(--red)}.alert-banner{border-radius:var(--radius);background:#fff7ec;border:1px solid #fbe3c0;align-items:center;gap:16px;padding:18px 22px;display:flex}.alert-banner .ab-ic{width:42px;height:42px;color:var(--amber);border-radius:11px;flex-shrink:0;place-items:center;display:grid}.alert-banner .ab-ic svg{width:24px;height:24px}.alert-banner .ab-title{color:#b45309;font-size:15px;font-weight:700}.alert-banner .ab-sub{color:#92652a;margin-top:2px;font-size:13.5px}.tracker{justify-content:space-between;align-items:flex-start;gap:6px;display:flex}.tracker .step{text-align:center;flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.tracker .step .dot{width:40px;height:40px;color:var(--muted);z-index:1;background:#eef1f6;border-radius:50%;place-items:center;display:grid}.tracker .step .dot svg{width:19px;height:19px}.tracker .step.done .dot{background:var(--blue);color:#fff}.tracker .step.cur .dot{background:var(--blue);color:#fff;box-shadow:0 0 0 4px var(--blue-soft)}.tracker .step .lbl{color:var(--slate-light);margin-top:8px;font-size:12px;font-weight:600}.tracker .step.done .lbl,.tracker .step.cur .lbl{color:var(--ink)}.tracker .step:after{content:"";z-index:0;background:#e3e8f0;width:100%;height:2px;position:absolute;top:20px;left:50%}.tracker .step.done:after{background:var(--blue)}.tracker .step:last-child:after{display:none}.vtimeline{padding-left:26px;position:relative}.vtimeline .ev{padding-bottom:22px;position:relative}.vtimeline .ev:last-child{padding-bottom:0}.vtimeline .ev:before{content:"";background:#fff;border:2px solid #cbd5e1;border-radius:50%;width:13px;height:13px;position:absolute;top:3px;left:-19px}.vtimeline .ev.done:before{border-color:var(--green);background:var(--green)}.vtimeline .ev.cur:before{border-color:var(--green);background:#fff}.vtimeline .ev:after{content:"";background:#e3e8f0;width:2px;position:absolute;top:16px;bottom:0;left:-13px}.vtimeline .ev:last-child:after{display:none}.vtimeline .ev.done:after{background:var(--green)}.vtimeline .ev .et{color:var(--ink);font-size:13.5px;font-weight:700}.vtimeline .ev.pending .et{color:var(--muted)}.vtimeline .ev .ed{color:var(--slate-light);margin-top:2px;font-size:12px}.dl{grid-template-columns:auto 1fr;gap:6px 14px;font-size:13.5px;display:grid}.dl dt{color:var(--slate-light)}.dl dd{color:var(--ink);margin:0;font-weight:500}.kv{flex-direction:column;gap:3px;display:flex}.kv .k{color:var(--slate-light);font-size:12px;font-weight:500}.kv .v{color:var(--ink);font-size:14px;font-weight:600}.minigrid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.minitile{border:1px solid var(--line);border-radius:10px;padding:13px}.minitile .mt-ic{border-radius:8px;place-items:center;width:30px;height:30px;margin-bottom:9px;display:grid}.minitile .mt-ic svg{width:16px;height:16px}.minitile .mt-lbl{color:var(--slate-light);font-size:11px}.minitile .mt-val{color:var(--ink);font-size:18px;font-weight:800}.minitile .mt-unit{color:var(--slate-light);font-size:11px;font-weight:600}.sec-label{color:var(--ink);margin:4px 0 14px;font-size:14px;font-weight:700}.tabs{border-bottom:1px solid var(--line);gap:26px;margin-bottom:18px;display:flex}.tab{color:var(--slate-light);cursor:pointer;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 0;font-size:14px;font-weight:600}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.overlay{z-index:60;background:#0f1c346b;place-items:center;display:grid;position:fixed;inset:0}.modal{text-align:center;width:380px;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;padding:30px;position:relative}.modal .m-ic{background:var(--amber-soft);width:64px;height:64px;color:var(--amber);border-radius:50%;place-items:center;margin:0 auto 16px;display:grid}.modal .m-ic svg{width:30px;height:30px}.modal .m-title{color:var(--ink);font-size:18px;font-weight:700}.modal .m-text{color:var(--slate-light);margin:8px 0 22px;font-size:13.5px;line-height:1.5}.modal .m-actions{gap:12px;display:flex}.modal .m-close{position:absolute;top:16px;right:16px}.bar-chart{align-items:flex-end;gap:8px;height:200px;padding:0 6px;display:flex}.bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:8px;height:100%;display:flex}.bar{background:var(--navy-800);border-radius:5px 5px 0 0;width:60%;max-width:54px;transition:height .6s}.bar-lbl{color:var(--slate-light);font-size:12px;font-weight:600}.chart-axis{color:var(--muted);text-align:right;flex-direction:column;justify-content:space-between;padding-bottom:24px;font-size:11px;display:flex}.sup-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.sup-card{border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;background:#fff;padding:18px;transition:all .15s}.sup-card:hover{box-shadow:var(--shadow);border-color:#c9d4e6}.sup-card.sel{border-color:var(--primary);box-shadow:0 0 0 2px #14305c1f}.sup-av{color:#fff;border-radius:10px;place-items:center;width:42px;height:42px;font-size:14px;font-weight:700;display:grid}.sup-row{color:var(--slate);align-items:center;gap:8px;margin-top:7px;font-size:12.5px;display:flex}.sup-row svg{width:14px;height:14px;color:var(--muted);flex-shrink:0}.report-grid{grid-template-columns:repeat(4,1fr);gap:18px;display:grid}.report-card{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;flex-direction:column;padding:20px;display:flex}.report-card .rc-ic{border-radius:12px;place-items:center;width:46px;height:46px;margin-bottom:14px;display:grid}.report-card .rc-ic svg{width:24px;height:24px}.report-card .rc-title{color:var(--ink);font-size:15.5px;font-weight:700}.report-card .rc-desc{color:var(--slate-light);min-height:52px;margin-top:5px;font-size:12.5px;line-height:1.45}.report-card .rc-list{color:var(--slate);flex-direction:column;gap:7px;margin:12px 0 16px;font-size:12.5px;display:flex}.report-card .rc-list .ri{align-items:center;gap:8px;display:flex}.report-card .rc-list .ri svg{width:14px;height:14px;color:var(--muted)}.flex{display:flex}.items-center{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-18{margin-bottom:18px}.text-red{color:var(--red);font-weight:700}.text-amber{color:var(--amber);font-weight:700}.text-green{color:var(--green);font-weight:700}.muted{color:var(--slate-light)}.right{text-align:right}.center{text-align:center}.nowrap{white-space:nowrap}.grow{flex:1}.login-stage{background:var(--bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.login-wrap{flex:1;place-items:center;padding:24px;display:grid;overflow:auto}.login-card{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:18px;width:480px;max-width:100%;padding:36px 52px 30px}.login-brand{text-align:center;margin-bottom:22px}.login-brand .lb-name{color:var(--navy-900);letter-spacing:1px;margin-top:12px;font-size:26px;font-weight:800}.login-brand .lb-sub{color:var(--slate-light);margin-top:3px;font-size:13.5px}.login-card h2{text-align:center;color:var(--ink);margin:6px 0 4px;font-size:23px;font-weight:800}.login-card .welcome-sub{text-align:center;color:var(--slate-light);margin-bottom:26px;font-size:14px}.login-foot{text-align:center;color:var(--muted);margin-top:22px;font-size:12.5px}.forgot{text-align:right;margin:-8px 0 20px}
