@import url(https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap);:root{--brand-purple:#403ec9;--brand-purple-dark:#2f2da8;--brand-purple-light:#6b69e0;--brand-purple-faint:#eef;--bg:#f5f4f8;--bg-card:#fff;--bg-sidebar:#1a1935;--bg-sidebar-hover:#252449;--bg-sidebar-active:#403ec9;--text-primary:#0f0e2a;--text-secondary:#6b6b8a;--text-muted:#9898b5;--text-on-brand:#fff;--border:#e4e3ef;--border-strong:#c8c7e0;--success:#16a34a;--success-bg:#dcfce7;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#2563eb;--info-bg:#dbeafe;--sidebar-width:240px;--topbar-height:60px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0f0e2a0f,0 1px 2px #0f0e2a0a;--shadow-md:0 4px 12px #0f0e2a14,0 2px 4px #0f0e2a0a;--shadow-lg:0 10px 30px #0f0e2a1f,0 4px 8px #0f0e2a0f;--transition:150ms cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:14px}body{background:#f5f4f8;background:var(--bg);color:#0f0e2a;color:var(--text-primary);font-family:DM Sans,sans-serif;line-height:1.6;min-height:100vh}h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.35rem;letter-spacing:-.01em}h2,h3{font-weight:600}h3{font-size:1.1rem}h4{font-size:.95rem;font-weight:600}a{color:#403ec9;color:var(--brand-purple);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#c8c7e0;background:var(--border-strong);border-radius:99px}.app-shell{display:flex;min-height:100vh}.sidebar{background:#1a1935;background:var(--bg-sidebar);bottom:0;flex-direction:column;left:0;overflow:hidden;position:fixed;top:0;transition:width .15s cubic-bezier(.4,0,.2,1);transition:width var(--transition);width:240px;width:var(--sidebar-width);z-index:100}.main-content,.sidebar{display:flex;min-height:100vh}.main-content{flex:1 1;flex-direction:column;margin-left:240px;margin-left:var(--sidebar-width)}.topbar{align-items:center;background:#fff;background:var(--bg-card);border-bottom:1px solid #e4e3ef;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #0f0e2a0f,0 1px 2px #0f0e2a0a;box-shadow:var(--shadow-sm);display:flex;gap:16px;height:60px;height:var(--topbar-height);padding:0 24px;position:sticky;top:0;z-index:50}.page-body{flex:1 1;overflow-y:auto;padding:28px 28px 48px}.sidebar-logo{border-bottom:1px solid #ffffff0f;padding:20px 18px 16px}.sidebar-logo img,.sidebar-logo svg{height:32px;width:auto}.sidebar-section-label{color:#ffffff4d;font-size:.68rem;font-weight:600;letter-spacing:.08em;padding:18px 18px 6px;text-transform:uppercase}.nav-item{align-items:center;border-radius:0;color:#fff9;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:9px 18px;position:relative;text-decoration:none;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.nav-item:hover{background:#252449;background:var(--bg-sidebar-hover);color:#ffffffe6;text-decoration:none}.nav-item.active{background:#403ec9;background:var(--bg-sidebar-active);color:#fff}.nav-item.active:before{background:#fff;border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nav-item .nav-icon{flex-shrink:0;height:18px;opacity:.8;width:18px}.nav-item.active .nav-icon{opacity:1}.nav-badge{background:#dc2626;background:var(--danger);border-radius:99px;color:#fff;font-size:.65rem;font-weight:700;margin-left:auto;min-width:18px;padding:1px 6px;text-align:center}.sidebar-footer{border-top:1px solid #ffffff0f;margin-top:auto;padding:12px 0}.card{background:#fff;background:var(--bg-card);border:1px solid #e4e3ef;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0f0e2a0f,0 1px 2px #0f0e2a0a;box-shadow:var(--shadow-sm)}.card-header{align-items:center;display:flex;justify-content:space-between;padding:18px 20px 0}.card-body{padding:20px}.card-body.no-pad{padding:0}.kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.kpi-card{background:#fff;background:var(--bg-card);border:1px solid #e4e3ef;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0f0e2a0f,0 1px 2px #0f0e2a0a;box-shadow:var(--shadow-sm);overflow:hidden;padding:20px;position:relative;transition:box-shadow .15s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1);transition:box-shadow var(--transition),transform var(--transition)}.kpi-card:hover{box-shadow:0 4px 12px #0f0e2a14,0 2px 4px #0f0e2a0a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card:after{background:#403ec9;background:var(--accent-color,var(--brand-purple));border-radius:16px 16px 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.kpi-icon{align-items:center;background:#eef;background:var(--icon-bg,var(--brand-purple-faint));border-radius:10px;border-radius:var(--radius-md);color:#403ec9;color:var(--icon-color,var(--brand-purple));display:flex;height:40px;justify-content:center;margin-bottom:14px;width:40px}.kpi-label{color:#6b6b8a;color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.kpi-value{color:#0f0e2a;color:var(--text-primary);font-size:1.65rem;font-weight:700;letter-spacing:-.03em;line-height:1.1;margin:4px 0}.kpi-sub{align-items:center;color:#9898b5;color:var(--text-muted);display:flex;font-size:.75rem;gap:4px}.kpi-change{border-radius:99px;font-size:.75rem;font-weight:600;padding:2px 6px}.kpi-change.up{background:#dcfce7;background:var(--success-bg);color:#16a34a;color:var(--success)}.kpi-change.down{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:.875rem;width:100%}thead tr{border-bottom:2px solid #e4e3ef;border-bottom:2px solid var(--border)}thead th{color:#6b6b8a;color:var(--text-secondary);font-size:.72rem;font-weight:600;letter-spacing:.06em;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}tbody tr{border-bottom:1px solid #e4e3ef;border-bottom:1px solid var(--border);transition:background .15s cubic-bezier(.4,0,.2,1);transition:background var(--transition)}tbody tr:hover{background:#eef;background:var(--brand-purple-faint)}tbody tr:last-child{border-bottom:none}tbody td{color:#0f0e2a;color:var(--text-primary);padding:11px 14px}.badge{align-items:center;border-radius:99px;display:inline-flex;font-size:.72rem;font-weight:600;gap:4px;letter-spacing:.02em;padding:3px 8px}.badge-a{background:#dcfce7;color:#15803d}.badge-b{background:#dbeafe;color:#1d4ed8}.badge-c{background:#f5f5f5;color:#525252}.badge-success{background:#dcfce7;background:var(--success-bg);color:#16a34a;color:var(--success)}.badge-warning{background:#fef3c7;background:var(--warning-bg);color:#d97706;color:var(--warning)}.badge-danger{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.badge-info{background:#dbeafe;background:var(--info-bg);color:#2563eb;color:var(--info)}.badge-purple{background:#eef;background:var(--brand-purple-faint);color:#403ec9;color:var(--brand-purple)}.badge-pending{background:#fef9c3;color:#854d0e}.btn{align-items:center;border:1px solid #0000;border-radius:10px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:7px;padding:8px 16px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition);white-space:nowrap}.btn-primary{background:#403ec9;background:var(--brand-purple);border-color:#403ec9;border-color:var(--brand-purple);color:#fff}.btn-primary:hover{background:#2f2da8;background:var(--brand-purple-dark);border-color:#2f2da8;border-color:var(--brand-purple-dark)}.btn-secondary{background:#fff;background:var(--bg-card);border-color:#c8c7e0;border-color:var(--border-strong);color:#0f0e2a;color:var(--text-primary)}.btn-secondary:hover{background:#f5f4f8;background:var(--bg)}.btn-ghost{background:#0000;border-color:#0000;color:#6b6b8a;color:var(--text-secondary)}.btn-ghost:hover{background:#f5f4f8;background:var(--bg);color:#0f0e2a;color:var(--text-primary)}.btn-danger{background:#dc2626;background:var(--danger);border-color:#dc2626;border-color:var(--danger);color:#fff}.btn-sm{border-radius:6px;border-radius:var(--radius-sm);font-size:.8rem;padding:5px 11px}.btn-lg{font-size:1rem;padding:11px 22px}.btn:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:16px}.form-label{color:#6b6b8a;color:var(--text-secondary);display:block;font-size:.8rem;font-weight:600;letter-spacing:.02em;margin-bottom:6px}.form-control{background:#fff;background:var(--bg-card);border:1px solid #c8c7e0;border:1px solid var(--border-strong);border-radius:10px;border-radius:var(--radius-md);color:#0f0e2a;color:var(--text-primary);font-family:inherit;font-size:.875rem;outline:none;padding:9px 13px;transition:border-color .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1);transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-control:focus{border-color:#403ec9;border-color:var(--brand-purple);box-shadow:0 0 0 3px #403ec91f}.form-control::placeholder{color:#9898b5;color:var(--text-muted)}select.form-control{cursor:pointer}.search-wrap{position:relative}.search-wrap .search-icon{color:#9898b5;color:var(--text-muted);left:11px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-wrap input{padding-left:34px}.progress-bar{background:#e4e3ef;background:var(--border);border-radius:99px;height:6px;overflow:hidden}.progress-bar-fill{background:#403ec9;background:var(--brand-purple);border-radius:99px;height:100%;transition:width .4s ease}.progress-bar-fill.success{background:#16a34a;background:var(--success)}.progress-bar-fill.warning{background:#d97706;background:var(--warning)}.progress-bar-fill.danger{background:#dc2626;background:var(--danger)}.login-page{background:#f5f4f8;background:var(--bg)}.login-left,.login-page{display:flex;min-height:100vh}.login-left{align-items:center;background:#1a1935;background:var(--bg-sidebar);flex-direction:column;justify-content:center;overflow:hidden;padding:48px;position:relative;width:420px}.login-left:before{background:#403ec9;background:var(--brand-purple);height:400px;left:-100px;opacity:.15;top:-150px;width:400px}.login-left:after,.login-left:before{border-radius:50%;content:"";position:absolute}.login-left:after{background:#6b69e0;background:var(--brand-purple-light);bottom:-100px;height:300px;opacity:.12;right:-80px;width:300px}.login-right{align-items:center;display:flex;flex:1 1;justify-content:center;padding:48px}.login-box{max-width:400px;width:100%}.page-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.page-title{font-size:1.45rem;font-weight:700;letter-spacing:-.02em}.page-subtitle{color:#6b6b8a;color:var(--text-secondary);font-size:.875rem;margin-top:2px}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.tabs{border-bottom:2px solid #e4e3ef;border-bottom:2px solid var(--border);display:flex;margin-bottom:20px}.tab-btn{background:none;border:none;border-bottom:2px solid #0000;color:#6b6b8a;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-bottom:-2px;padding:10px 18px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all var(--transition)}.tab-btn:hover{color:#0f0e2a;color:var(--text-primary)}.tab-btn.active{border-bottom-color:#403ec9;border-bottom-color:var(--brand-purple);color:#403ec9;color:var(--brand-purple)}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f0e2a80;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{animation:slideUp .2s ease;background:#fff;background:var(--bg-card);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 10px 30px #0f0e2a1f,0 4px 8px #0f0e2a0f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:22px 24px 0}.modal-body{padding:20px 24px 24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.empty-state{color:#9898b5;color:var(--text-muted);padding:60px 20px;text-align:center}.empty-state svg{margin-bottom:12px;opacity:.4}.empty-state h3{color:#6b6b8a;color:var(--text-secondary);font-size:1rem;margin-bottom:6px}.spinner{animation:spin .6s linear infinite;border:2px solid #e4e3ef;border-top-color:#403ec9;border:2px solid var(--border);border-radius:50%;border-top-color:var(--brand-purple);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.sidebar{width:0}.main-content{margin-left:0}.login-left{display:none}.kpi-grid{grid-template-columns:1fr 1fr}.page-body{padding:16px}}
/*# sourceMappingURL=main.1fdd9249.css.map*/