*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1a3c5c;--navy-dark:#0f2a45;--navy-light:#2a5070;--blue:#1a6faa;--blue-light:#e8f4fd;--green:#2e7d32;--green-light:#e8f5e9;--amber:#e65100;--amber-light:#fff3e0;--red:#c62828;--red-light:#ffebee;--gray:#546e7a;--gray-light:#f5f7f9;--border:#dde3ea;--text:#1a2332;--text-muted:#5f6b7a;--white:#fff;--shadow:0 1px 4px #00000014;--shadow-md:0 2px 12px #0000001f;--radius:4px;--radius-md:6px;--sidebar-width:220px;--topbar-height:56px}body{background:#f5f7f9;background:var(--gray-light);color:#1a2332;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}a{color:#1a6faa;color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}button,input,select,textarea{font-family:inherit;font-size:14px}.app-layout{display:flex;min-height:100vh}.sidebar{background:#1a3c5c;background:var(--navy);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;top:0;width:220px;width:var(--sidebar-width);z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #2a5070;border-bottom:1px solid var(--navy-light);display:flex;gap:10px;padding:16px}.sidebar-logo-icon{align-items:center;background:#1a6faa;background:var(--blue);border-radius:4px;border-radius:var(--radius);color:#fff;display:flex;font-size:16px;height:32px;justify-content:center;width:32px}.sidebar-logo-text{color:#fff;font-size:15px;font-weight:600}.sidebar-logo-sub{color:#ffffff80;font-size:11px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:8px 0}.nav-section-label{color:#ffffff59;font-size:10px;font-weight:600;letter-spacing:.08em;padding:12px 16px 4px;text-transform:uppercase}.nav-item{align-items:center;border-left:3px solid #0000;color:#ffffffb3;display:flex;font-size:13px;gap:10px;padding:9px 16px;transition:background .15s,color .15s}.nav-item:hover{background:#ffffff14;color:#fff;text-decoration:none}.nav-item.active{background:#ffffff1f;border-left-color:#5ba4cf;color:#fff}.nav-item-icon{font-size:16px;opacity:.8}.nav-badge{background:#c62828;background:var(--red);border-radius:99px;color:#fff;font-size:10px;font-weight:700;margin-left:auto;padding:1px 6px}.sidebar-footer{border-top:1px solid #2a5070;border-top:1px solid var(--navy-light);padding:12px 16px}.user-card{align-items:center;border-radius:4px;border-radius:var(--radius);cursor:pointer;display:flex;gap:10px;padding:8px;transition:background .15s}.user-card:hover{background:#ffffff14}.user-avatar{align-items:center;background:#1a6faa;background:var(--blue);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.user-name{color:#fff;font-size:13px;font-weight:500}.user-role{color:#ffffff80;font-size:11px;text-transform:capitalize}.main-area{display:flex;flex:1 1;flex-direction:column;margin-left:220px;margin-left:var(--sidebar-width);min-height:100vh}.topbar{align-items:center;background:#fff;background:var(--white);border-bottom:1px solid #dde3ea;border-bottom:1px solid var(--border);display:flex;gap:12px;height:56px;height:var(--topbar-height);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar-title{color:#1a2332;color:var(--text);flex:1 1;font-size:16px;font-weight:600}.topbar-search{align-items:center;background:#f5f7f9;background:var(--gray-light);border:1px solid #dde3ea;border:1px solid var(--border);border-radius:4px;border-radius:var(--radius);display:flex;gap:8px;padding:6px 12px;width:260px}.topbar-search input{background:none;border:none;color:#1a2332;color:var(--text);font-size:13px;outline:none;width:100%}.topbar-search .icon{color:#5f6b7a;color:var(--text-muted);font-size:15px}.page-content{flex:1 1;padding:24px}.card{background:#fff;background:var(--white);border:1px solid #dde3ea;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-md);box-shadow:0 1px 4px #00000014;box-shadow:var(--shadow)}.card-header{align-items:center;border-bottom:1px solid #dde3ea;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 18px}.card-title{color:#1a2332;color:var(--text);font-size:14px;font-weight:600}.card-body{padding:18px}.metrics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:20px}.metric-card{background:#fff;background:var(--white);border:1px solid #dde3ea;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-md);box-shadow:0 1px 4px #00000014;box-shadow:var(--shadow);padding:16px}.metric-label{color:#5f6b7a;color:var(--text-muted);font-size:12px;margin-bottom:6px}.metric-value{color:#1a2332;color:var(--text);font-size:26px;font-weight:700;line-height:1}.metric-sub{color:#5f6b7a;color:var(--text-muted);font-size:12px;margin-top:5px}.metric-up{color:#2e7d32;color:var(--green)}.metric-down{color:#c62828;color:var(--red)}.metric-warn{color:#e65100;color:var(--amber)}.table-wrap{overflow-x:auto}table.data-table{border-collapse:collapse;width:100%}.data-table thead tr{background:#1a3c5c;background:var(--navy)}.data-table thead th{border-right:1px solid #2a5070;border-right:1px solid var(--navy-light);color:#fff;font-size:12px;font-weight:600;padding:10px 14px;text-align:left;white-space:nowrap}.data-table thead th:last-child{border-right:none}.data-table thead th.center{text-align:center}.data-table tbody tr{border-bottom:1px solid #dde3ea;border-bottom:1px solid var(--border);transition:background .1s}.data-table tbody tr:hover{background:#f0f6fc}.data-table tbody td{color:#1a2332;color:var(--text);font-size:13px;padding:9px 14px;vertical-align:middle}.data-table tbody td.center{text-align:center}.data-table tfoot tr{background:#1a3c5c;background:var(--navy);border-top:2px solid #0f2a45;border-top:2px solid var(--navy-dark)}.data-table tfoot td{color:#fff;font-size:13px;font-weight:700;padding:10px 14px}.data-table tfoot td.center{text-align:center}.badge{border-radius:99px;display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;white-space:nowrap}.badge-green{background:#e8f5e9;background:var(--green-light);color:#2e7d32;color:var(--green)}.badge-amber{background:#fff3e0;background:var(--amber-light);color:#e65100;color:var(--amber)}.badge-red{background:#ffebee;background:var(--red-light);color:#c62828;color:var(--red)}.badge-blue{background:#e8f4fd;background:var(--blue-light);color:#1a6faa;color:var(--blue)}.badge-gray{background:#eceff1;color:#546e7a;color:var(--gray)}.badge-navy{background:#1a3c5c;background:var(--navy);color:#fff}.num-green{color:#2e7d32;color:var(--green)}.num-amber,.num-green{cursor:pointer;font-weight:600;text-decoration:underline}.num-amber{color:#c80}.num-red{color:#c62828;color:var(--red);font-weight:600}.num-red,.num-total{cursor:pointer;text-decoration:underline}.num-total{font-weight:700}.btn{align-items:center;border:1px solid #0000;border-radius:4px;border-radius:var(--radius);display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:7px 14px;transition:opacity .15s,background .15s}.btn:hover{opacity:.88}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#1a3c5c;background:var(--navy);border-color:#1a3c5c;border-color:var(--navy);color:#fff}.btn-blue{background:#1a6faa;background:var(--blue);border-color:#1a6faa;border-color:var(--blue);color:#fff}.btn-outline{background:#fff;border-color:#dde3ea;border-color:var(--border);color:#1a2332;color:var(--text)}.btn-outline:hover{background:#f5f7f9;background:var(--gray-light)}.btn-danger{background:#c62828;background:var(--red);border-color:#c62828;border-color:var(--red);color:#fff}.btn-sm{font-size:12px;padding:4px 10px}.btn-icon{padding:6px 8px}.form-group{margin-bottom:16px}.form-label{color:#1a2332;color:var(--text);display:block;font-size:13px;font-weight:500;margin-bottom:5px}.form-label .required{color:#c62828;color:var(--red);margin-left:3px}.form-control{background:#fff;border:1px solid #dde3ea;border:1px solid var(--border);border-radius:4px;border-radius:var(--radius);color:#1a2332;color:var(--text);font-size:13px;outline:none;padding:8px 12px;transition:border-color .15s;width:100%}.form-control:focus{border-color:#1a6faa;border-color:var(--blue);box-shadow:0 0 0 2px #1a6faa26}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-row-3{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr 1fr}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:#fff;border-radius:6px;border-radius:var(--radius-md);box-shadow:0 2px 12px #0000001f;box-shadow:var(--shadow-md);display:flex;flex-direction:column;max-height:90vh;max-width:700px;width:100%}.modal-header{align-items:center;background:#1a3c5c;background:var(--navy);border-bottom:1px solid #dde3ea;border-bottom:1px solid var(--border);border-radius:6px 6px 0 0;border-radius:var(--radius-md) var(--radius-md) 0 0;display:flex;justify-content:space-between;padding:16px 20px}.modal-title{color:#fff;font-size:16px;font-weight:600}.modal-close{background:none;border:none;color:#ffffffb3;font-size:20px;padding:0 4px}.modal-close:hover{color:#fff}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.modal-footer{border-top:1px solid #dde3ea;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding:14px 20px}.login-page{align-items:center;background:#1a3c5c;background:var(--navy);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:6px;border-radius:var(--radius-md);box-shadow:0 2px 12px #0000001f;box-shadow:var(--shadow-md);max-width:400px;padding:40px;width:100%}.login-logo{margin-bottom:28px;text-align:center}.login-logo-icon{align-items:center;background:#1a3c5c;background:var(--navy);border-radius:6px;border-radius:var(--radius-md);color:#fff;display:inline-flex;font-size:24px;height:48px;justify-content:center;margin-bottom:10px;width:48px}.login-logo-text{color:#1a3c5c;color:var(--navy);font-size:20px;font-weight:700}.login-logo-sub{color:#5f6b7a;color:var(--text-muted);font-size:13px}.alert{border-radius:4px;border-radius:var(--radius);font-size:13px;margin-bottom:14px;padding:10px 14px}.alert-error{background:#ffebee;background:var(--red-light);border:1px solid #ffcdd2;color:#c62828;color:var(--red)}.alert-success{background:#e8f5e9;background:var(--green-light);border:1px solid #c8e6c9;color:#2e7d32;color:var(--green)}.alert-warning{background:#fff3e0;background:var(--amber-light);border:1px solid #ffe0b2;color:#e65100;color:var(--amber)}.spinner{animation:spin .7s linear infinite;border:2px solid #dde3ea;border-top-color:#1a6faa;border:2px solid var(--border);border-radius:50%;border-top-color:var(--blue);display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen{align-items:center;background:#f5f7f9;background:var(--gray-light);display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:100vh}.empty-state,.loading-screen{color:#5f6b7a;color:var(--text-muted)}.empty-state{padding:48px 20px;text-align:center}.empty-state-icon{font-size:40px;margin-bottom:12px;opacity:.4}.empty-state-title{color:#1a2332;color:var(--text);font-size:16px;font-weight:600;margin-bottom:6px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.page-title{color:#1a2332;color:var(--text);font-size:20px;font-weight:700}.page-sub{color:#5f6b7a;color:var(--text-muted);font-size:13px;margin-top:2px}.two-col{grid-gap:16px;grid-template-columns:1fr 300px}.three-col,.two-col{display:grid;gap:16px}.three-col{grid-gap:16px;grid-template-columns:1fr 1fr 1fr}.tag-row{display:flex;flex-wrap:wrap;gap:6px}.divider{border:none;border-top:1px solid #dde3ea;border-top:1px solid var(--border);margin:16px 0}.text-muted{color:#5f6b7a;color:var(--text-muted)}.text-sm{font-size:12px}.text-right{text-align:right}.fw-600{font-weight:600}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-16{margin-bottom:16px}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-8{gap:8px}.gap-12{gap:12px}
/*# sourceMappingURL=main.7c8cd55f.css.map*/