*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5;color:#1e2d4e;background-color:#f8fafc;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#93c5fd;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#2563eb}:root{--color-primary: #2563EB;--color-primary-dark: #1D4ED8;--color-primary-light: #60A5FA;--color-primary-xlight: #DBEAFE;--color-primary-pale: #EFF6FF;--color-accent: #38BDF8;--color-accent-light: #BAE6FD;--color-navy: #1E3A5F;--color-navy-mid: #1E40AF;--color-background: #F8FAFC;--color-surface: #ffffff;--color-border: #BFDBFE;--color-border-light: #E8F0FE;--color-text-primary: #1E2D4E;--color-text-secondary: #4B6A8A;--color-text-muted: #8BA4BD;--color-danger: #EF4444;--color-danger-light: #FEF2F2;--color-warning: #F59E0B;--color-warning-light: #FFFBEB;--color-success: #10B981;--color-success-light: #ECFDF5;--color-info: #3B82F6;--color-info-light: #EFF6FF;--color-needs-review: #FFFBEB;--color-needs-review-border: #FDE68A;--shadow-sm: 0 1px 3px 0 rgba(37, 99, 235, .08), 0 1px 2px -1px rgba(37, 99, 235, .04);--shadow-md: 0 4px 8px -1px rgba(37, 99, 235, .1), 0 2px 4px -2px rgba(37, 99, 235, .06);--shadow-lg: 0 10px 20px -3px rgba(37, 99, 235, .12), 0 4px 6px -4px rgba(37, 99, 235, .06);--shadow-xl: 0 20px 30px -5px rgba(30, 58, 95, .15), 0 8px 10px -6px rgba(30, 58, 95, .08);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px}.app-header{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff;padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;box-shadow:0 4px 16px #1e3a5f4d;z-index:100;position:relative}.app-header h1{font-size:17px;font-weight:700;letter-spacing:-.2px}.app-content{flex:1;overflow:auto;padding:28px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-md);border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;letter-spacing:.1px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-color:transparent;box-shadow:0 2px 8px #2563eb59}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 16px #2563eb73;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #2563eb4d}.btn-secondary{background-color:#fff;color:var(--color-text-primary);border-color:var(--color-border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background-color:#eff6ff;border-color:var(--color-primary-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:transparent;box-shadow:0 2px 8px #ef44444d}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 14px #ef444466;transform:translateY(-1px)}.btn-ghost{background-color:transparent;color:var(--color-text-secondary);border-color:transparent;padding:4px 10px;box-shadow:none}.btn-ghost:hover:not(:disabled){background-color:#2563eb14;color:var(--color-primary)}.btn-sm{padding:5px 12px;font-size:13px}.btn-icon{padding:6px;background:none;border:none;cursor:pointer;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .15s}.btn-icon:hover{background-color:#2563eb1a;color:var(--color-primary)}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:16px}.form-label{font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-control{padding:9px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);background-color:#fff;color:var(--color-text-primary);font-size:14px;transition:border-color .2s,box-shadow .2s;width:100%}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb26}.form-control::placeholder{color:var(--color-text-muted)}.form-control:disabled{background-color:#f8fafb;color:var(--color-text-muted);border-color:var(--color-border-light)}.form-control-sm{padding:5px 9px;font-size:13px}.form-error{color:var(--color-danger);font-size:13px;margin-top:2px}.table-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto;overflow-y:auto;box-shadow:var(--shadow-sm)}table{width:100%;border-collapse:collapse;font-size:14px}thead{background:#fff;border-bottom:2px solid var(--color-border);position:sticky;top:0;z-index:3}thead th{padding:11px 14px;text-align:left;font-weight:700;font-size:12px;color:var(--color-primary-dark);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;background:#fff}tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .12s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background-color:#f8fafc}tbody td{padding:10px 14px;vertical-align:middle}tr.needs-review{background-color:var(--color-needs-review)}tr.needs-review:hover{background-color:#fef9c3}tr.selected-row{background-color:#dbeafe}tr.selected-row:hover{background-color:#bfdbfe}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-size:16px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.2px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap;letter-spacing:.2px}.badge-green{background-color:#d1fae5;color:#065f46}.badge-yellow{background-color:#fef3c7;color:#92400e}.badge-orange{background-color:#ffedd5;color:#9a3412}.badge-red{background-color:#fee2e2;color:#991b1b}.badge-blue{background-color:#dbeafe;color:#1e40af}.badge-gray{background-color:#f1f5f9;color:#475569}.badge-dark{background:linear-gradient(135deg,#1e3a5f,#2563eb);color:#fff}.tab-nav{display:flex;gap:2px;background-color:#fff;border-radius:var(--radius-lg);padding:4px;margin-bottom:28px;overflow-x:auto;border:1.5px solid var(--color-border);box-shadow:var(--shadow-sm)}.tab-btn{padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-md);margin-bottom:0;font-size:14px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;transition:all .2s ease}.tab-btn:hover{color:var(--color-primary);background-color:#ffffffb3}.tab-btn.active{background-color:#fff;color:var(--color-primary-dark);font-weight:700;box-shadow:0 2px 8px #2563eb26,var(--shadow-sm)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#1e3a5f80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 0 1px #2563eb14;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-lg{max-width:740px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--color-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-title{font-size:17px;font-weight:700;letter-spacing:-.2px;color:var(--color-text-primary)}.modal-body{padding:24px;flex:1;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 24px;border-top:1px solid var(--color-border);background-color:#fff;border-radius:0 0 var(--radius-xl) var(--radius-xl)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot-green{background-color:#10b981;box-shadow:0 0 0 2px #10b98133}.status-dot-yellow{background-color:#f59e0b;box-shadow:0 0 0 2px #f59e0b33}.status-dot-red{background-color:#ef4444;box-shadow:0 0 0 2px #ef444433}.status-dot-gray{background-color:#9ca3af;box-shadow:0 0 0 2px #9ca3af33}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-sm{font-size:13px}.font-bold{font-weight:700}.font-semibold{font-weight:600}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.p-16{padding:16px}.p-24{padding:24px}.no-wrap{white-space:nowrap}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state{text-align:center;padding:60px 24px;color:var(--color-text-muted)}.empty-state p{margin-top:8px;font-size:14px}.divider{border:none;border-top:1px solid var(--color-border);margin:16px 0}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:14px;margin-bottom:16px;font-weight:500}.alert-error{background-color:#fef2f2;color:#991b1b;border:1px solid #FECACA}.alert-success{background-color:#ecfdf5;color:#065f46;border:1px solid #A7F3D0}.alert-warning{background-color:#fffbeb;color:#92400e;border:1px solid #FDE68A}.amount-positive{color:#059669;font-weight:600}.amount-negative{color:#dc2626;font-weight:600}.filters-bar{display:flex;align-items:center;gap:8px;padding:10px 0;flex-wrap:wrap}.filter-chip{padding:5px 14px;border-radius:20px;border:1.5px solid var(--color-border);background:#fff;font-size:13px;font-weight:500;cursor:pointer;color:var(--color-text-secondary);transition:all .15s}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:#fff}.filter-chip.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-color:transparent;color:#fff;box-shadow:0 2px 6px #2563eb4d}.bulk-toolbar{display:flex;align-items:center;gap:8px;padding:10px 14px;background-color:#fff;border:1.5px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:8px;flex-wrap:wrap}.bulk-toolbar span{font-size:13px;font-weight:700;color:var(--color-primary-dark);margin-right:4px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#1e3a5f59;z-index:500;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer{position:fixed;right:0;top:0;bottom:0;width:400px;background-color:var(--color-surface);box-shadow:-8px 0 30px #1e3a5f26;z-index:501;display:flex;flex-direction:column;overflow:hidden;border-left:1px solid var(--color-border);border-radius:var(--radius-xl) 0 0 var(--radius-xl)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--color-border);background-color:#fff}.drawer-body{flex:1;overflow-y:auto;padding:20px}.spinner{display:inline-block;width:20px;height:20px;border:2.5px solid rgba(37,99,235,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .65s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:60px}.cell-edit input,.cell-edit select{width:100%;padding:4px 8px;border:1.5px solid var(--color-primary);border-radius:var(--radius-sm);font-size:14px;background:#fff;box-shadow:0 0 0 3px #2563eb1f}.cell-display{cursor:pointer;min-height:20px;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .15s}.cell-display:hover{border-color:var(--color-primary);background-color:#fff;color:var(--color-primary-dark)}@media (max-width: 768px){.app-content{padding:14px}.drawer{width:100%;border-radius:0}.modal{max-width:100%;border-radius:var(--radius-lg)}.tab-nav{border-radius:var(--radius-md)}}
