@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}@media (width<=768px){h1{font-size:28px}h2{font-size:20px}body{font-size:14px}#root{border-inline:none;width:100%;padding:0}}table th,.data-table th,.cfs-table th,.viewing-table th,.charges-table th,.job-table th{color:#fff!important;background-color:#3b82f6!important;border-bottom:none!important;font-weight:600!important}.loader-spinner,.loading-spinner{color:#3b82f6!important;flex-direction:column!important;justify-content:center!important;align-items:center!important;gap:16px!important;padding:40px!important;font-weight:600!important;display:flex!important}.loader-spinner svg{color:#3b82f6!important;border:none!important;width:40px!important;height:40px!important}.pagination,.standard-pagination{color:#475569!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;justify-content:space-between!important;align-items:center!important;margin-top:20px!important;padding:12px 16px!important;font-size:14px!important;display:flex!important}.pagination button,.secondary-btn{cursor:pointer!important;color:#1e293b!important;background:#fff!important;border:1px solid #cbd5e1!important;border-radius:6px!important;padding:8px 16px!important;font-weight:600!important;transition:all .2s!important}.pagination button:hover:not(:disabled),.secondary-btn:hover:not(:disabled){background:#f1f5f9!important;border-color:#94a3b8!important}.pagination button:disabled,.secondary-btn:disabled{opacity:.5!important;cursor:not-allowed!important;background:#f8fafc!important}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}body{color:#0f172a;background-color:#f8fafc;margin:0}.app-container{background-color:#f1f5f9;height:100vh;margin-left:-70px;margin-right:-60px;display:flex;overflow:hidden}.form-row-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.sidebar{width:220px;min-width:unset;background-color:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;max-width:260px;transition:width .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.org-avatar-collapsed{color:#fff;cursor:pointer;background-color:#3b82f6;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;margin:0 auto;font-size:12px;font-weight:600;display:flex}.sidebar-collapsed .org-user-box{justify-content:center;display:flex;padding:7px 0!important}.sidebar-collapsed .logout-btn{border-radius:50%;justify-content:center;width:90px;margin:0 auto;padding:10px}.sidebar-nav li,.nav-section-title{font-size:12px}.sidebar-collapsed .org-user-box{display:none}.sidebar-collapsed .sidebar{width:70px}.sidebar-collapsed .top-logo span{display:none}.sidebar-collapsed .top-logo{justify-content:center;padding:16px 0}.sidebar-footer{border-top:1px solid #f1f5f9;flex-direction:column;gap:4px;padding:12px 8px;display:flex}.footer-icon-row{cursor:pointer;border-radius:6px;align-items:center;gap:12px;padding:8px 12px;transition:background-color .2s;display:flex}.footer-icon-row:hover{background-color:#fef2f2}.footer-user-row{cursor:pointer;border-radius:6px;align-items:center;gap:10px;padding:4px 6px;transition:background-color .2s;display:flex}.footer-user-row:hover{border:"2px solid black";background-color:#f1f5f9}.user-initials-circle{color:#fff;background-color:#f97316;border-radius:50%;justify-content:center;align-items:center;width:27px;min-width:32px;height:27px;font-size:12px;font-weight:700;display:flex}.sidebar-collapsed .footer-icon-row,.sidebar-collapsed .footer-user-row{justify-content:center;padding:10px 0}.logout-btn{color:#ef4444;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:10px;width:80%;padding:8px 12px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.top-logo{align-items:center;gap:8px;width:100%;padding:16px;display:flex}.sidebar-collapsed .brand-title,.sidebar-collapsed .user-info .user-details,.sidebar-collapsed .nav-label{display:none}.sidebar-collapsed .nav-section-title{visibility:hidden}.sidebar-collapsed .user-info{justify-content:center;padding:12px 0}.sidebar-collapsed .sidebar-header{justify-content:center;padding:16px 0}.sidebar-collapsed .brand-section{display:none}.collapse-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;flex-direction:column;gap:4px;padding:8px;display:flex}.collapse-btn:hover{background-color:#f1f5f9}.hamburger{background-color:#64748b;width:13px;height:2px}.sidebar-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.brand-section{align-items:center;gap:10px;display:flex}.brand-logo{object-fit:contain;height:28px}.fallback-logo{background-color:#eff6ff;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.brand-title{color:#0f172a;font-size:1.1rem;font-weight:700}.user-info{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;padding:16px;display:flex}.avatar{color:#fff;background-color:#3b82f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:600;display:flex}.user-details{flex-direction:column;display:flex;overflow:hidden}.user-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.user-role{color:#1d4ed8;white-space:nowrap;text-overflow:ellipsis;background:#eff6ff;border-radius:4px;margin-top:2px;padding:2px 6px;font-size:.75rem;display:inline-block;overflow:hidden}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.sidebar-nav ul{flex-direction:column;gap:4px;list-style:none;display:flex}.sidebar-nav li{color:#475569;cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:12px;padding:8px 12px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.sidebar-collapsed .sidebar-nav li{justify-content:center;padding:18px}.sidebar-nav li:hover{color:#0f172a;background-color:#f1f5f9}.sidebar-nav li.active{color:#2563eb;background-color:#eff6ff}.sidebar-nav li.active svg{color:#2563eb}.nav-section-title{color:#94a3b8;text-align:left;letter-spacing:.05em;text-transform:uppercase;margin:16px 0 8px 12px;font-size:.7rem;font-weight:700}.sidebar-footer{border-top:1px solid #f1f5f9;padding:16px}.logout-btn{color:#ef4444;cursor:pointer;white-space:nowrap;background-color:#fef2f2;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:.85rem;font-weight:500;transition:background-color .2s;display:flex}.sidebar-collapsed .logout-btn{justify-content:center;padding:18px}.main-content{background-color:#f8fafc;flex-direction:column;flex:1;display:flex;overflow:hidden}.top-header{background-color:#fff;border-bottom:1px solid #e2e8f0;align-items:center;height:60px;padding:0 24px;display:flex}.top-header h1{color:#0f172a;font-size:1.2rem;font-weight:600}.content-area{flex:1;padding:24px;overflow-y:auto}.dashboard-welcome h2{color:#0f172a;letter-spacing:-.5px;margin-bottom:8px;font-size:1.5rem}.subtitle{color:#64748b;margin-bottom:10px;font-size:1rem}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.module-card{cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;align-items:flex-start;gap:16px;padding:24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #0000000d}.module-card:hover{border-color:#bae6fd;transform:translateY(-4px);box-shadow:0 12px 24px -8px #0000001a}.card-icon{color:#3b82f6;background-color:#eff6ff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.module-card h3{color:#1e293b;font-size:1.15rem;font-weight:600}.btn-outline{color:#3b82f6;cursor:pointer;background-color:#0000;border:1px solid #bfdbfe;border-radius:8px;width:100%;margin-top:auto;padding:8px 16px;font-weight:600;transition:all .2s}.module-card:hover .btn-outline{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.placeholder-module{text-align:center;color:#64748b;background:#fff;border:1px dashed #cbd5e1;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:64px 32px;display:flex}.placeholder-module h3{color:#1e293b;font-size:1.5rem}.data-upload-container{background:#fff;border:1px solid #e2e8f0;border-radius:16px;max-width:800px;margin:0 auto;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.stepper{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:15px 5px;display:flex}.step{flex-direction:column;flex:1;align-items:center;gap:8px;display:flex;position:relative}.step-circle{color:#64748b;z-index:2;background-color:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-weight:600;transition:all .3s;display:flex}.step-label{color:#64748b;text-align:center;font-size:.6rem;font-weight:500}.step-line{z-index:1;background-color:#e2e8f0;width:100%;height:2px;position:absolute;top:16px;left:50%}.step.active .step-circle{color:#fff;background-color:#3b82f6;box-shadow:0 0 0 4px #eff6ff}.step.active .step-label{color:#1e293b;font-weight:600}.step.active .step-line{background-color:#3b82f6}.step-content{min-height:350px;padding:40px}.upload-area{text-align:center;background-color:#f8fafc;border:2px dashed #cbd5e1;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:18px 24px;transition:border-color .2s;display:flex}.upload-area:hover{border-color:#3b82f6}.upload-area h3{color:#1e293b;margin-top:16px;font-size:.6rem}.upload-area p{color:#64748b;margin-bottom:24px}.hidden-input{display:none}.upload-btn{color:#3b82f6;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s;box-shadow:0 1px 2px #0000000d}.upload-btn:hover{background-color:#f1f5f9;border-color:#94a3b8}.file-list{text-align:left;width:100%;max-width:400px;margin-top:24px;list-style:none}.file-list li{color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:6px;align-items:center;gap:8px;margin-bottom:8px;padding:12px;font-size:.6rem;display:flex}.config-form{flex-direction:column;gap:20px;max-width:400px;margin:0 auto;display:flex}.form-group{text-align:left;flex-direction:column;gap:6px;display:flex}.form-group label{color:#334155;text-align:left;font-size:.85rem;font-weight:600}.form-group select{color:#1e293b;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;padding:10px;font-size:.95rem;transition:border-color .2s}.disabled-select{cursor:not-allowed;color:#64748b!important;background-color:#f1f5f9!important;border-color:#e2e8f0!important}.frozen-badge{color:#475569;text-transform:uppercase;letter-spacing:.5px;background-color:#e2e8f0;border-radius:4px;margin-left:8px;padding:2px 6px;font-size:.65rem}.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #eff6ff}.review-area{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:32px}.review-area h3{color:#1e293b;margin-bottom:24px;font-size:1.25rem}.review-area p{color:#475569;margin-bottom:12px;font-size:1rem}.review-area strong{color:#1e293b;min-width:150px;display:inline-block}.action-box{color:#1e40af;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;align-items:center;gap:16px;margin-top:32px;padding:24px;display:flex}.action-box p{color:#1e40af;margin:0;font-weight:500}.step-actions{background-color:#f8fafc;border-top:1px solid #e2e8f0;justify-content:space-between;padding:24px 40px;display:flex}.btn-secondary{color:#475569;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s}.btn-secondary:hover:not(:disabled){background-color:#f1f5f9}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s;box-shadow:0 4px 6px -1px #3b82f633}.btn-primary:hover:not(:disabled){background-color:#2563eb;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;background-color:#94a3b8}.btn-success{color:#fff;cursor:pointer;background-color:#10b981;border:none;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s;box-shadow:0 4px 6px -1px #10b98133}.btn-success:hover{background-color:#059669}.extracting-indicator{color:#3b82f6;justify-content:center;align-items:center;gap:12px;margin-top:24px;font-weight:500;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:1s linear infinite spin}.results-area{flex-direction:column;gap:0;display:flex}.result-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d}.result-card h4{color:#1e293b;border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding-bottom:8px;font-size:1.1rem}.json-preview{display:none}.dynamic-form{flex-direction:column;gap:24px;display:flex}.mobile-menu-btn{display:none}@media (width<=768px){.mobile-menu-btn{cursor:pointer;color:#475569;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;display:flex}.mobile-menu-btn:hover{background-color:#f1f5f9}}.form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;display:grid}.form-input{color:#1e293b;background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;width:100%;padding:10px 12px;font-size:.95rem;transition:all .2s}.form-input:focus{background-color:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #eff6ff}.success-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:64px 32px;display:flex}.success-state h3{color:#1e293b;margin-top:16px;font-size:1.5rem}.success-state p{color:#64748b;margin-bottom:24px}.container-details-section{border-top:1px dashed #cbd5e1;margin-top:24px;padding-top:24px}.container-details-section h5{color:#334155;align-items:center;gap:8px;margin-bottom:16px;font-size:1.1rem;display:flex}.container-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:6px;padding:16px}.container-card h6{color:#0ea5e9;margin-bottom:12px;font-size:.95rem}.seals-grid{border-top:1px solid #e2e8f0;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:12px;padding-top:12px;display:grid}.hidden{display:none!important}.error-text{color:#ef4444;font-weight:500}@media (width<=768px){.app-container{flex-direction:column;margin-left:0;margin-right:0}.sidebar{z-index:1000;height:100vh;transition:transform .3s;position:fixed;transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 15px #0000001a}.main-content{width:100%;min-width:100vw}.form-row-grid,.modules-grid{grid-template-columns:1fr!important}.top-header{padding:0 12px}.content-area{padding:12px}.data-upload-container{border-radius:8px;width:100%}.stepper{flex-direction:column;align-items:flex-start;gap:10px;padding:15px}.step{flex-direction:row;justify-content:flex-start;align-items:center;gap:12px;width:100%}.step-line{display:none}.step-content{min-height:auto;padding:20px}.config-form{width:100%}.step-actions{flex-direction:column;gap:10px;padding:20px}.step-actions button{width:100%}}.jobsheet-container{background-color:#f8fafc;flex-direction:column;gap:15px;min-height:calc(100vh - 100px);padding:15px;display:flex}.jobsheet-header{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;padding:15px;display:flex;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.jobsheet-header h2{color:#1e293b;align-items:center;gap:5px;margin:0;font-size:20px;display:flex}.tabs-container{gap:10px;display:flex}.tab-btn{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:all .3s;display:flex}.tab-btn.active{color:#fff;background:#3b82f6;box-shadow:0 4px 12px #3b82f64d}.data-table-container{background:#fff;border-radius:12px;padding:20px;overflow-x:auto;box-shadow:0 4px 6px -1px #0000001a}.data-table{border-collapse:collapse;width:90%;font-size:12px}.data-table th,.data-table td{text-align:left;white-space:nowrap;border-bottom:1px solid #e2e8f0;padding:12px 16px}.data-table th{color:#475569;background-color:#f8fafc;font-weight:600;position:sticky;top:0}.data-table tr:hover{background-color:#f1f5f9}.action-btn{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:4px;padding:4px;transition:all .2s}.action-btn.edit:hover{color:#3b82f6;background:#eff6ff}.action-btn.delete:hover{color:#ef4444;background:#fef2f2}.source-badge{border-radius:12px;padding:4px 8px;font-size:12px;font-weight:600}.source-db{color:#166534;background-color:#dcfce7}.source-n8n{color:#854d0e;background-color:#fef9c3}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:20px;display:grid}.metric-card{background:#fff;border-left:4px solid #3b82f6;border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex;box-shadow:0 4px 6px -1px #0000001a}.metric-card.conex{border-left-color:#3b82f6}.metric-card.polaris{border-left-color:#8b5cf6}.metric-card.empty{border-left-color:#10b981}.metric-card.loaded{border-left-color:#f59e0b}.metric-title{color:#64748b;text-transform:uppercase;font-size:14px;font-weight:600}.metric-value{color:#1e293b;font-size:32px;font-weight:700}.bulk-migrate-header{color:#1e3a8a;background:#eff6ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:20px;padding:16px}.bulk-controls{background:#fff;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;display:flex;box-shadow:0 2px 4px -2px #0000001a}.primary-btn{color:#fff;cursor:pointer;background-color:#3b82f6;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:background-color .2s;display:flex}.primary-btn:hover:not(:disabled){background-color:#2563eb}.primary-btn:disabled{cursor:not-allowed;background-color:#94a3b8}.status-badge{border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.status-locked{color:#475569;background-color:#f1f5f9}.status-pending{color:#1e40af;background-color:#dbeafe}.loading-spinner{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:40px;display:flex}.spinner{border:4px solid #0000001a;border-left-color:#3b82f6;border-radius:50%;width:36px;height:36px;animation:1s infinite spin}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:130%;max-width:2000px;max-height:97vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-header h3{color:#1e293b;margin:0}.close-btn:hover{color:#0f172a}.modal-body{grid-template-columns:repeat(3,1fr);gap:20px;padding:20px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#475569;font-size:14px;font-weight:600}.form-group input{border:1px solid #cbd5e1;border-radius:6px;padding:10px;font-size:14px}.form-group input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.secondary-btn:hover{background:#f8fafc}@media (width<=768px){.jobsheet-container{padding:10px}.jobsheet-header{flex-direction:column;align-items:stretch;gap:10px}.tabs-container{flex-wrap:wrap}.tab-btn{text-align:center;flex:1;justify-content:center}.data-table-container{-webkit-overflow-scrolling:touch;padding:10px;overflow-x:auto}.data-table{white-space:nowrap}.modal-body{grid-template-columns:1fr}.modal-content{width:95%;max-width:95%;padding:10px}.metrics-grid{grid-template-columns:1fr}.bulk-controls{flex-direction:column;align-items:stretch;gap:10px}.bulk-controls>div{flex-direction:column;gap:10px;display:flex}}.cfs-container{background-color:#f8fafc;min-height:calc(100vh - 80px);padding:20px}.loader-spinner{color:#10b981;justify-content:center;align-items:center;gap:10px;padding:40px;font-weight:600;display:flex}.loader-spinner svg{animation:1s linear infinite spin}.tabs{border-bottom:1px solid #e2e8f0;gap:10px;margin-bottom:24px;padding-bottom:10px;display:flex}.tab-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:10px 24px;font-weight:600;transition:all .2s}.tab-btn:hover{color:#1e293b;background:#f1f5f9}.tab-btn.active{color:#fff;background:#10b981;border-color:#10b981;box-shadow:0 4px 6px -1px #10b98133}.tab-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000d}.booking-selector{align-items:center;gap:16px;margin-bottom:24px;display:flex}.booking-selector label{color:#1e293b;font-weight:600}.booking-selector select,.filter-bar input{border:1px solid #cbd5e1;border-radius:6px;max-width:250px;padding:8px 16px;font-size:14px}.filter-bar{background:#f8fafc;border-radius:8px;align-items:center;gap:12px;margin-bottom:24px;padding:16px;display:flex}.cfs-table{border-collapse:collapse;border:1px solid #e2e8f0;border-radius:8px;width:100%;margin-bottom:24px;overflow:hidden}.cfs-table th{text-align:left;color:#475569;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 16px;font-size:12px;font-weight:600}.cfs-table td{color:#1e293b;border-bottom:1px solid #e2e8f0;padding:12px 16px;font-size:10px}.cfs-table tbody tr:hover{background:#f1f5f9}.inline-input{border:1px solid #cbd5e1;border-radius:4px;width:150px;padding:6px 12px}.badge.db{color:#0369a1;background:#e0f2fe}.badge.n8n{color:#b45309;background:#fef3c7}.charge-form-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:32px;padding:24px}.info-alert{color:#1d4ed8;background:#eff6ff;border-radius:8px;margin-bottom:24px;padding:12px 16px;font-size:14px}.cfs-form .form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px;display:grid}.form-group input,.form-group select,.form-group textarea{border:1px solid #cbd5e1;border-radius:6px;width:100%;padding:8px 12px}.form-group input:disabled{cursor:not-allowed;background:#e2e8f0}.add-vehicle-btn{color:#2563eb;cursor:pointer;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;align-items:center;gap:6px;padding:0 12px;font-weight:600;display:flex}.charge-amounts-grid{background:#fff;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:24px;padding:20px;display:grid}.charge-col h4{color:#0f172a;border-bottom:2px solid #e2e8f0;margin-top:0;margin-bottom:16px;padding-bottom:8px}.cost-col h4{border-bottom-color:#ef4444}.income-col h4{border-bottom-color:#10b981}.primary-btn{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;width:100%;padding:12px 24px;font-size:16px;font-weight:600}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:500px;max-width:90%;padding:24px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.close-btn{cursor:pointer;color:#64748b;background:0 0;border:none}.data-view th{color:#fff;background:#1e293b;border:none}.data-view .amount{color:#10b981;font-weight:700}.action-btn.download{color:#d97706;background:#fef3c7;border-radius:6px;padding:8px;display:inline-flex}.action-btn.edit{color:#4f46e5;cursor:pointer;background:#e0e7ff;border:none;border-radius:6px;margin-right:8px;padding:8px;display:inline-flex}.action-btn.delete{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:6px;margin-right:8px;padding:8px;display:inline-flex}.pagination{justify-content:flex-end;align-items:center;gap:16px;margin-top:20px;display:flex}.pagination button{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:6px 12px}@media (width<=768px){.cfs-container{padding:10px}.charge-amounts-grid{grid-template-columns:1fr;gap:16px}.tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:5px;overflow-x:auto}.tab-btn{padding:8px 12px;font-size:12px}.filter-bar,.booking-selector{flex-direction:column;align-items:stretch}.booking-selector select,.filter-bar input{max-width:100%}.cfs-table{white-space:nowrap;display:block;overflow-x:auto}.cfs-form .form-row{grid-template-columns:1fr}.modal-content{width:95%;margin:10px;padding:15px}.tab-content{padding:12px}}.master-container{background-color:#f8fafc;flex-direction:column;min-height:calc(100vh - 60px);padding:24px;display:flex}.master-header{justify-content:space-between;align-items:flex-end;margin-bottom:20px;display:flex}.master-header h2{color:#0f172a;margin:0 0 4px;font-size:24px}.master-header p{color:#64748b;margin:0;font-size:14px}.master-actions{align-items:center;gap:16px;display:flex}.search-bar{background:#fff;border:1px solid #cbd5e1;border-radius:8px;align-items:center;width:400px;padding:0 12px;display:flex}.search-bar input{border:none;outline:none;width:100%;padding:10px;font-size:14px}.search-bar svg{color:#64748b}.stats-strip{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.stat-badge{border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:inline-flex}.stat-badge.blue{color:#334155;background:#f0f4f8}.stat-badge.green{color:#27500a;background:#eaf3de}.stat-badge.orange{color:#633806;background:#faeeda}.stat-badge.selected{color:#085041;background:#e1f5ee}.bulk-actions-bar{background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.action-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.action-btn:hover{color:#0f172a;background:#f1f5f9}.save-btn{align-items:center;gap:6px;margin-left:auto;display:flex}.save-btn:disabled{opacity:.6;cursor:not-allowed}.table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-grow:1;max-height:60vh;overflow:auto;box-shadow:0 4px 6px -1px #0000000d}.master-table{border-collapse:separate;border-spacing:0;white-space:nowrap;width:100%;font-size:12px}.master-table th,.master-table td{border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:8px 12px}.master-table thead{z-index:10;position:sticky;top:0}.master-table th{color:#fff;text-align:left;background-color:#1e293b;font-weight:600}.master-table .fin-header{text-align:center}.master-table .fin-header.cost{background-color:#334155}.master-table .fin-header.income{background-color:#0f172a}.master-table .fin-header.check{background-color:#475569;width:40px}.master-table .ready-col{text-align:center;background-color:#047857!important}.master-table .cost-val{color:#b91c1c;text-align:right;background-color:#fef2f2}.master-table .income-val{color:#15803d;text-align:right;background-color:#f0fdf4}.master-table .check-val{text-align:center;background-color:#f8fafc}.master-table tbody tr:hover td{background-color:#f1f5f9}.master-table tbody tr.selected-row td{background-color:#e0f2fe}.sticky-col{background:inherit;z-index:5;position:sticky;left:0}.master-table thead th.sticky-col{z-index:15;background-color:#1e293b}.master-table tbody tr:hover td.sticky-col{background-color:#f1f5f9}.master-table tbody tr.selected-row td.sticky-col{background-color:#e0f2fe}.checkbox-col{text-align:center;width:40px}.pagination{background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;gap:16px;margin-top:20px;padding:10px;display:flex}.pagination button{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:8px 16px;font-weight:500;transition:all .2s}.pagination button:hover:not(:disabled){background:#f1f5f9;border-color:#94a3b8}.pagination button:disabled{opacity:.5;cursor:not-allowed}.loading-state,.empty-state{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;display:flex}.filter-group{align-items:center;gap:4px;margin-right:20px;display:flex}.filter-group label{color:#475569;font-size:12px;font-weight:600}.filter-select{color:#1e293b;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;outline:none;padding:6px 1px;font-size:12px;transition:border-color .2s}.filter-select:focus{border-color:#3b82f6}@media (width<=768px){.master-container,.offloading-voucher-container{padding:10px}.master-header{flex-direction:column;align-items:stretch;gap:10px}.master-actions{flex-direction:column;align-items:stretch}.search-bar{width:100%}.date-filters{flex-direction:row;justify-content:space-between;align-items:center}.bulk-actions-bar{flex-direction:column;align-items:stretch;gap:10px}.filter-group{flex-direction:column;align-items:flex-start;width:100%}.filter-select{width:100%}.table-wrapper{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.master-table{white-space:nowrap}}.charges-container{background:#f8fafc;min-height:100vh;padding:24px}.charges-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.header-left h2{color:#1e293b;margin:0;font-size:24px;font-weight:700}.header-left p{color:#64748b;margin:4px 0 0}.header-right{align-items:center;gap:16px;display:flex}.search-box{background:#fff;border:1px solid #e2e8f0;border-radius:10px;align-items:center;width:300px;padding:0 12px;display:flex;position:relative;box-shadow:0 1px 2px #0000000d}.search-icon{color:#94a3b8}.search-box input{border:none;outline:none;width:100%;padding:10px;font-size:14px}.add-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:background .2s;display:flex}.add-btn:hover{background:#1d4ed8}.table-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.table-wrapper{overflow-x:auto}.charges-table{border-collapse:collapse;text-align:left;width:100%}.charges-table th{color:#475569;text-transform:uppercase;letter-spacing:.025em;background:#f1f5f9;border-bottom:1px solid #e2e8f0;padding:14px 20px;font-size:13px;font-weight:600}.charges-table td{color:#334155;border-bottom:1px solid #f1f5f9;padding:16px 20px;font-size:14px}.fw-bold{font-weight:600}.text-red{color:#ef4444;font-weight:600}.text-green{color:#10b981;font-weight:600}.badge{border-radius:20px;padding:4px 10px;font-size:12px;font-weight:600}.badge.Import{color:#166534;background:#dcfce7}.badge.Export{color:#991b1b;background:#fee2e2}.actions-cell{gap:8px;display:flex}.icon-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.icon-btn.edit{color:#2563eb;background:#eff6ff}.icon-btn.edit:hover{background:#dbeafe}.icon-btn.history{color:#16a34a;background:#f0fdf4}.icon-btn.history:hover{background:#dcfce7}.icon-btn.delete{color:#dc2626;background:#fef2f2}.icon-btn.delete:hover{background:#fee2e2}.pagination-bar{background:#fff;border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pagination-info{color:#64748b;font-size:14px}.pagination-controls{align-items:center;gap:16px;display:flex}.page-btn{cursor:pointer;color:#64748b;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-current{color:#1e293b;font-size:14px;font-weight:600}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:20px;width:500px;max-width:95vw;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content.wide{width:800px}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:#1e293b;margin:0;font-size:18px}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none}.form-grid{grid-template-columns:1fr 1fr;gap:16px;padding:24px;display:grid}.form-group.full-width{grid-column:span 2}.form-group label{color:#475569;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:10px;font-size:14px}.form-group input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:12px;padding:20px 24px;display:flex}.secondary-btn{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;padding:10px 20px;font-weight:600}.primary-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;display:flex}.history-list{max-height:400px;padding:24px;overflow-y:auto}.history-table{border-collapse:collapse;width:100%}.history-table th{text-align:left;color:#64748b;border-bottom:2px solid #e2e8f0;padding:10px;font-size:12px}.history-table td{border-bottom:1px solid #f1f5f9;padding:12px 10px;font-size:13px}@media (width<=768px){.charges-container{padding:10px}.charges-header{flex-direction:column;align-items:stretch;gap:10px}.header-right{flex-direction:column;align-items:stretch}.search-box{width:100%}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.table-wrapper{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.charges-table{white-space:nowrap}}.invoice-container{background:#f8fafc;min-height:100vh;padding:24px}.invoice-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.invoice-tabs{background:#fff;border-radius:12px;gap:8px;width:fit-content;margin-bottom:24px;padding:8px;display:flex;box-shadow:0 1px 3px #0000001a}.invoice-tab-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:all .2s;display:flex}.invoice-tab-btn.active{color:#3b82f6;background:#eff6ff}.invoice-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px -1px #0000001a}.billing-controls{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;padding:20px;display:grid}.billing-group{flex-direction:column;gap:8px;display:flex}.billing-group label{color:#475569;font-size:13px;font-weight:600}.billing-group select,.billing-group input{border:1px solid #cbd5e1;border-radius:6px;outline:none;padding:10px;font-size:14px}.billing-summary{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:32px;padding:24px}.summary-table{border-collapse:collapse;width:100%;margin-top:16px}.summary-table th,.summary-table td{text-align:left;border:1px solid #e2e8f0;padding:12px;font-size:14px}.summary-table th{color:#475569;background:#f8fafc}.summary-table select,.summary-table input{border:1px solid #cbd5e1;border-radius:4px;width:100%;padding:6px}.total-row{background:#f1f5f9;font-weight:700}.badge-source{text-transform:uppercase;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:700}.badge-source.db{color:#166534;background:#dcfce7}.badge-source.n8n{color:#854d0e;background:#fef9c3}.badge-source.direct{color:#1e40af;background:#dbeafe}.action-bar{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-save{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 24px;font-weight:600;display:flex}.btn-export{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;align-items:center;gap:8px;padding:10px 24px;font-weight:600;display:flex}.loading-overlay{justify-content:center;align-items:center;padding:40px;display:flex}@media (width<=768px){.invoice-container{padding:10px}.invoice-header{flex-direction:column;align-items:stretch;gap:10px}.invoice-tabs{flex-wrap:wrap;justify-content:center;width:100%}.billing-controls{grid-template-columns:1fr;gap:10px}.action-bar{flex-direction:column;align-items:stretch;gap:10px}.invoice-content{-webkit-overflow-scrolling:touch;padding:10px;overflow-x:auto}.summary-table{white-space:nowrap}}.fmlm-container{color:#1e293b;max-width:1400px;margin:0 auto;padding:24px;font-family:IBM Plex Sans,Segoe UI,sans-serif}.fmlm-header{margin-bottom:24px}.fmlm-title{align-items:center;gap:10px;margin-bottom:6px;display:flex}.fmlm-title h2{color:#0f172a;margin:0;font-size:1.5rem;font-weight:700}.fmlm-header p{color:#64748b;margin:0;font-size:.9rem}.fmlm-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:24px;padding:24px;box-shadow:0 1px 4px #0000000f}.fmlm-card h3{color:#334155;margin:0 0 16px;font-size:1rem;font-weight:600}.fmlm-date-inputs{flex-wrap:wrap;gap:20px;margin-bottom:20px;display:flex}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:#475569;text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;font-weight:600}.input-group input[type=date]{color:#1e293b;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;outline:none;padding:8px 12px;font-size:.9rem;transition:border-color .2s}.input-group input[type=date]:focus{background:#fff;border-color:#3b82f6}.fmlm-actions{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:7px;padding:9px 18px;font-size:.875rem;font-weight:600;transition:background .2s,opacity .2s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{color:#334155;background:#f1f5f9;border:1px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#e2e8f0}.btn-info{color:#5b21b6;background:#ede9fe;border:1px solid #c4b5fd}.btn-info:hover:not(:disabled){background:#ddd6fe}.download-actions{gap:8px;display:flex}.btn-download{border-radius:7px;padding:7px 14px;font-size:.82rem}.btn-excel{color:#166534;background:#dcfce7;border:1px solid #bbf7d0}.btn-excel:hover{background:#bbf7d0}.btn-csv{color:#854d0e;background:#fef9c3;border:1px solid #fde68a}.btn-csv:hover{background:#fde68a}.alert{border-radius:8px;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 16px;font-size:.875rem;display:flex}.alert-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.alert strong{margin-bottom:2px;display:block}.fmlm-preview-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.preview-tabs{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:0 8px;display:flex}.preview-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:12px 18px;font-size:.875rem;font-weight:600;transition:color .2s,border-color .2s;display:inline-flex}.preview-tab:hover{color:#3b82f6}.preview-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-badge{color:#0369a1;background:#e0f2fe;border-radius:99px;padding:2px 7px;font-size:.72rem;font-weight:700}.preview-tab.active .tab-badge{color:#1d4ed8;background:#dbeafe}.preview-header{border-bottom:1px solid #f1f5f9;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.preview-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.badge{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:99px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-block}.badge-green{color:#166534;background:#dcfce7;border-color:#bbf7d0}.text-muted{color:#94a3b8;font-size:.8rem}.table-responsive{max-height:520px;overflow:auto}.fmlm-table{border-collapse:collapse;width:100%;font-size:.82rem}.fmlm-table thead{z-index:1;position:sticky;top:0}.fmlm-table th{color:#475569;text-align:left;white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;background:#f8fafc;border-bottom:2px solid #e2e8f0;padding:10px 14px;font-size:.78rem;font-weight:700}.fmlm-table td{color:#334155;white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:9px 14px}.fmlm-table tbody tr:hover td{background:#f8fafc}.fmlm-table tbody tr:last-child td{border-bottom:none}.spin{animation:.7s linear infinite spin}
