@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0a0f1e;--bg-surface:#111827;--bg-elevated:#1e293b;--bg-hover:#243147;--border:#1e293b;--border-light:#2d3748;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-2:#8b5cf6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#00e676;--sidebar-w:240px;--radius:12px;--radius-sm:7px;--shadow:0 4px 24px #00000059}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.6}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border-light);flex-direction:column;padding:20px 12px;display:flex;overflow-y:auto}.sidebar-logo{color:var(--text-primary);letter-spacing:-.3px;align-items:center;gap:10px;padding:6px 10px 20px;display:flex}.sidebar-brand{flex-direction:column;line-height:1.1;display:flex}.brand-main{font-size:18px;font-weight:700}.brand-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:10px;padding:9px 12px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item--active{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;box-shadow:0 2px 12px #6366f166}.sidebar-footer{border-top:1px solid var(--border-light);align-items:center;gap:8px;margin-top:12px;padding-top:16px;display:flex}.user-chip{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.user-avatar{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-info{min-width:0}.user-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);font-size:11px}.main-content{background:var(--bg-base);flex-direction:column;flex:1;display:flex;overflow-y:auto}.top-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-light);z-index:50;align-items:center;height:64px;padding:12px 32px;display:flex;position:sticky;top:0}.content-container{flex:1;padding:0;overflow-y:auto}.global-search-container{width:100%;max-width:500px;position:relative}.global-search-input-wrap{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:10px;align-items:center;gap:12px;padding:8px 16px;transition:all .2s;display:flex}.global-search-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.global-search-input-wrap input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:14px}.search-icon{color:var(--text-muted)}.clear-icon{color:var(--text-muted);cursor:pointer}.clear-icon:hover{color:var(--text-primary)}.search-results-dropdown{background:var(--bg-surface);border:1px solid var(--border-light);z-index:100;border-radius:12px;max-height:400px;padding:8px;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow-y:auto;box-shadow:0 12px 32px #0006}.search-section{padding:4px 0}.search-section-title{color:var(--text-muted);text-transform:uppercase;align-items:center;gap:6px;padding:8px 12px 4px;font-size:11px;font-weight:700;display:flex}.search-result-item{cursor:pointer;border-radius:8px;padding:10px 12px;transition:background .15s}.search-result-item:hover{background:var(--bg-hover)}.res-title{color:var(--text-primary);font-size:13px;font-weight:600}.res-sub{color:var(--text-muted);font-size:11px}.search-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:13px}.page{max-width:1400px;padding:28px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-primary);font-size:22px;font-weight:700}.page-header p{color:var(--text-secondary);margin-top:2px;font-size:13px}.page-loading{justify-content:center;align-items:center;height:60vh;display:flex}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);align-items:flex-start;gap:14px;padding:20px;transition:transform .15s,box-shadow .15s;display:flex}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.kpi-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;padding:9px;display:flex}.kpi-label{color:var(--text-muted);font-size:12px;font-weight:500}.kpi-value{margin-top:2px;font-size:20px;font-weight:700}.kpi-sub{color:var(--text-muted);margin-top:3px;font-size:11px}.charts-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:20px}.chart-card h2{color:var(--text-secondary);margin-bottom:16px;font-size:14px;font-weight:600}.quick-links{flex-wrap:wrap;gap:12px;display:flex}.quick-link{border-radius:var(--radius-sm);align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.quick-link.overdue{color:var(--danger);background:#ef44441f;border:1px solid #ef44444d}.quick-link.overdue:hover{background:#ef444433}.quick-link.pending{color:var(--warning);background:#f59e0b1f;border:1px solid #f59e0b4d}.quick-link.pending:hover{background:#f59e0b33}.filter-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.search-box{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);min-width:220px;color:var(--text-secondary);flex:1;align-items:center;gap:8px;padding:8px 12px;display:flex}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:13px}.select-wrap{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:6px;padding:8px 12px;display:flex}.select-wrap select,select{color:var(--text-primary);cursor:pointer;background:0 0;border:none;outline:none;font-size:13px}.toggle-label{cursor:pointer;color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.toggle-label input{accent-color:var(--accent)}.toggle-text{align-items:center;gap:4px;display:flex}.card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);padding:24px}.table-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:var(--bg-elevated)}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-light);padding:12px 16px;font-size:11px;font-weight:600}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:13px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.td-bold{color:var(--text-primary);font-weight:500}.td-amount{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.table-loading{justify-content:center;padding:48px;display:flex}.empty-row{text-align:center;color:var(--text-muted);padding:48px!important}.action-cell{align-items:center;gap:6px;display:flex}.badge{text-transform:capitalize;letter-spacing:.3px;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}.pagination{justify-content:center;align-items:center;gap:12px;padding-bottom:8px;display:flex}.pagination button{background:var(--bg-surface);border:1px solid var(--border-light);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;padding:6px 14px;font-size:13px;transition:all .15s}.pagination button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{color:var(--text-muted);font-size:13px}.link-action{color:var(--accent);font-size:13px;font-weight:500;text-decoration:none;transition:color .15s}.link-action:hover{color:var(--accent-2)}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.2px;border:none;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;transition:opacity .15s,transform .15s;display:inline-flex}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-full{justify-content:center;width:100%;padding:12px}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-ghost{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:all .15s;display:flex}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-hover)}.btn-logout{margin-left:auto}.btn-xs{cursor:pointer;border:none;border-radius:5px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .15s}.btn-xs.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.btn-xs.btn-success{color:var(--success);background:#10b98126;border:1px solid #10b9814d}.btn-xs.btn-success:hover{background:#10b98140}.btn-xs.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-xs.btn-danger:hover{background:#ef444440}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.form-group textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius);width:100%;max-width:520px;max-height:90vh;padding:28px;animation:.2s slideUp;overflow-y:auto}.modal h2{margin-bottom:20px;font-size:17px;font-weight:700}.modal-form{flex-direction:column;gap:16px;display:flex}.modal-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.login-page{background:radial-gradient(ellipse at 30% 40%, #6366f126 0%, transparent 60%), radial-gradient(ellipse at 70% 80%, #8b5cf61a 0%, transparent 60%), var(--bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:20px;width:100%;max-width:420px;padding:44px 40px;animation:.25s slideUp;box-shadow:0 20px 64px #00000080}.login-logo{align-items:center;gap:10px;margin-bottom:24px;font-size:20px;font-weight:700;display:flex}.login-card h1{margin-bottom:6px;font-size:22px;font-weight:700}.login-sub{color:var(--text-secondary);margin-bottom:28px;font-size:14px}.login-form{flex-direction:column;gap:16px;display:flex}.login-hint{text-align:center;color:var(--text-muted);margin-top:16px;font-size:12px}.import-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.import-form{flex-direction:column;gap:16px;display:flex}.file-drop-zone{border:2px dashed var(--border-light);border-radius:var(--radius);text-align:center;cursor:pointer;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:40px 24px;transition:all .2s;display:flex}.file-drop-zone:hover{border-color:var(--accent);color:var(--accent);background:#6366f10d}.file-drop-zone p{font-size:13px}.job-header{align-items:center;gap:10px;margin-bottom:16px;font-size:15px;font-weight:600;display:flex}.job-metrics{grid-template-columns:1fr 1fr;gap:10px 20px;display:grid}.job-metrics div{flex-direction:column;display:flex}.job-metrics span{color:var(--text-muted);font-size:11px}.job-metrics strong{font-size:15px}.error-log{background:#ef444414;border-radius:8px;margin-top:16px;padding:12px}.error-log p{color:var(--danger);margin-bottom:6px;font-size:12px;font-weight:600}.error-log pre{color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;font-size:11px}.import-guide h2{margin-bottom:16px}.guide-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.guide-grid h3{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:600}.guide-grid code{background:var(--bg-elevated);color:var(--accent);border-radius:6px;padding:8px 12px;font-size:12px;line-height:1.8;display:block}.spinner{border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=900px){.charts-grid,.import-grid,.guide-grid{grid-template-columns:1fr}}@media (width<=640px){.sidebar{display:none}.page{padding:16px}.form-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}}.react-datepicker-wrapper{width:100%}.date-picker-input{background:var(--bg-elevated)!important;border:1px solid var(--border-light)!important;border-radius:var(--radius-sm)!important;width:100%!important;color:var(--text-primary)!important;outline:none!important;padding:9px 12px!important;font-family:inherit!important;font-size:13px!important;transition:border-color .15s!important}.date-picker-input:focus{border-color:var(--accent)!important;box-shadow:0 0 0 3px #6366f126!important}.react-datepicker{background-color:var(--bg-elevated)!important;border-color:var(--border-light)!important;color:var(--text-primary)!important;font-family:inherit!important}.react-datepicker__header{background-color:var(--bg-hover)!important;border-bottom-color:var(--border-light)!important}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:var(--text-primary)!important}.react-datepicker__day:hover{background-color:var(--accent)!important}.react-datepicker__day--selected{background-color:var(--accent)!important;color:#fff!important}.react-datepicker__day--keyboard-selected{background-color:#6366f180!important}.react-datepicker-popper{z-index:9999!important}
