:root{--primary-color:#1e40af;--primary-light:#3b82f6;--primary-dark:#1e3a8a;--secondary-color:#64748b;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--bg-primary:#f3f4f6;--bg-secondary:#fff;--text-primary:#111827;--text-secondary:#6b7280;--border-color:#e5e7eb;--sidebar-width:250px;--sidebar-collapsed-width:60px;--header-height:60px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f3f4f6;background-color:var(--bg-primary);color:#111827;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.app-layout{display:flex;min-height:100vh}.sidebar{background:#1e40af;background:var(--primary-color);color:#fff;height:100vh;overflow-y:auto;position:fixed;transition:width .3s;width:250px;width:var(--sidebar-width)}.sidebar.collapsed{width:60px;width:var(--sidebar-collapsed-width)}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:20px}.sidebar-title{font-size:1.5rem;font-weight:700}.sidebar-toggle{background:none;border:none;color:#fff;cursor:pointer;padding:5px}.sidebar-nav{padding:10px 0}.sidebar-item{align-items:center;color:#fffc;cursor:pointer;display:flex;padding:12px 20px;text-decoration:none}.sidebar-item.active,.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-icon{font-size:1.2rem;margin-right:10px}.sidebar.collapsed .sidebar-label{display:none}.main-content{flex:1 1;margin-left:250px;margin-left:var(--sidebar-width);transition:margin-left .3s}.sidebar.collapsed~.main-content{margin-left:60px;margin-left:var(--sidebar-collapsed-width)}.header{align-items:center;background:#fff;background:var(--bg-secondary);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;height:60px;height:var(--header-height);justify-content:space-between;padding:0 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left h2{color:#111827;color:var(--text-primary);font-size:1.25rem}.header-right{align-items:center;display:flex;gap:20px}.system-clock{color:#6b7280;color:var(--text-secondary);font-size:.9rem}.user-menu{align-items:center;display:flex;gap:10px}.user-name{font-weight:500}.user-role{color:#6b7280;color:var(--text-secondary);font-size:.85rem}.logout-btn{background:#ef4444;background:var(--error-color);border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 16px}.logout-btn:hover{opacity:.9}.page-content{padding:20px}.page-header{margin-bottom:20px}.page-header h1{color:#111827;color:var(--text-primary);font-size:1.75rem;margin-bottom:5px}.page-header p{color:#6b7280;color:var(--text-secondary)}.dashboard-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.card{align-items:center;background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:15px;padding:20px}.card-icon{font-size:2rem}.card-content h3{color:#6b7280;color:var(--text-secondary);font-size:.85rem;margin-bottom:5px}.card-value{color:#111827;color:var(--text-primary);font-size:1.5rem;font-weight:700}.dashboard-ratios{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.ratio-card{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px}.ratio-card h4{color:#6b7280;color:var(--text-secondary);margin-bottom:10px}.ratio-value{color:#1e40af;color:var(--primary-color);font-size:2rem;font-weight:700;margin-bottom:10px}.ratio-bar{background:#f3f4f6;background:var(--bg-primary);border-radius:4px;height:8px;overflow:hidden}.ratio-fill{background:#3b82f6;background:var(--primary-light);height:100%;transition:width .3s}.ratio-note{color:#6b7280;color:var(--text-secondary);font-size:.85rem;margin-top:10px}.table-container{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:12px 16px;text-align:left}.data-table th{color:#6b7280;color:var(--text-secondary);font-weight:600}.data-table th,.data-table tr:hover{background:#f3f4f6;background:var(--bg-primary)}.status-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:4px 8px}.status-budgeted{background:#e0e7ff;color:#4f46e5}.status-committed{background:#fef3c7;color:#d97706}.status-invoicereceived{background:#dbeafe;color:#2563eb}.status-passedtofd{background:#fce7f3;color:#db2777}.status-active,.status-actualized{background:#d1fae5;color:#059669}.status-inactive,.status-locked{background:#fee2e2;color:#dc2626}.status-unlocked{background:#d1fae5;color:#059669}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.filter-input,.filter-select{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;min-width:200px;padding:10px 15px}.filter-input:focus,.filter-select:focus{border-color:#3b82f6;border-color:var(--primary-light);outline:none}.btn,button{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px}.action-btn{background:#3b82f6;background:var(--primary-light);color:#fff;font-size:.8rem;padding:6px 12px}.action-btn:hover,.submit-btn{background:#1e40af;background:var(--primary-color)}.submit-btn{color:#fff;width:100%}.submit-btn:hover{background:#1e3a8a;background:var(--primary-dark)}.form-group{margin-bottom:15px}.form-group label{color:#111827;color:var(--text-primary);display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select{border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;padding:10px 15px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;border-color:var(--primary-light);outline:none}.error-message{background:#fee2e2;color:#dc2626}.error-message,.success-message{border-radius:4px;margin-bottom:15px;padding:10px 15px}.success-message{background:#d1fae5;color:#059669}.login-container{align-items:center;background:linear-gradient(135deg,#1e40af,#1e3a8a);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#1e40af;color:var(--primary-color);font-size:2rem;margin-bottom:5px}.login-footer,.login-header p{color:#6b7280;color:var(--text-secondary)}.login-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px;text-align:center}.login-footer small{display:block;margin-top:5px}.demo-toggle{background:none;border:none;color:#1e40af;color:var(--primary-color);cursor:pointer;font-size:.9rem;padding:0;text-decoration:underline}.demo-toggle:hover{color:#1e3a8a;color:var(--primary-dark)}.demo-accounts{background:#f3f4f6;background:var(--bg-primary);border-radius:4px;margin-top:15px;padding:15px;text-align:left}.demo-note{font-size:.85rem;margin-bottom:10px}.demo-note code{background:#3b82f6;background:var(--primary-light);border-radius:3px;color:#fff;padding:2px 6px}.demo-list{list-style:none;margin:0;padding:0}.demo-list li{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:8px 0}.demo-list li:last-child{border-bottom:none}.demo-list button{background:none;border:none;color:#1e40af;color:var(--primary-color);cursor:pointer;font-size:.85rem;padding:0}.demo-list button:hover{text-decoration:underline}.demo-role{color:#6b7280;color:var(--text-secondary);font-size:.75rem}.login-btn{background:#1e40af;background:var(--primary-color);color:#fff;padding:12px;width:100%}.login-btn:hover{background:#1e3a8a;background:var(--primary-dark)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.profile-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.profile-card{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:20px}.profile-card h2{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-size:1.25rem;margin-bottom:20px;padding-bottom:10px}.info-row{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;padding:10px 0}.info-row label{color:#6b7280;color:var(--text-secondary);font-weight:500;width:120px}.pagination{align-items:center;display:flex;gap:15px;justify-content:center;margin-top:20px}.pagination button{background:#fff;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);padding:8px 16px}.pagination button:hover:not(:disabled){background:#f3f4f6;background:var(--bg-primary)}.pagination button:disabled{cursor:not-allowed;opacity:.5}.not-found-page{align-items:center;display:flex;justify-content:center;min-height:100vh}.not-found-content{text-align:center}.not-found-content h1{color:#1e40af;color:var(--primary-color);font-size:6rem;margin-bottom:10px}.not-found-content h2{margin-bottom:15px}.not-found-content p{color:#6b7280;color:var(--text-secondary);margin-bottom:20px}.home-link{color:#1e40af;color:var(--primary-color);font-weight:500;text-decoration:none}.loading,.loading-screen{align-items:center;color:#6b7280;color:var(--text-secondary);display:flex;justify-content:center;min-height:200px}.dashboard-section{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-top:20px;padding:20px}.dashboard-section h2{font-size:1.25rem;margin-bottom:15px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;padding:0;width:100%}.modal-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);justify-content:space-between;padding:20px}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{font-size:1.25rem;gap:8px}.close-btn{background:none;border:none;color:#6b7280;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:0}.close-btn:hover{color:#111827;color:var(--text-primary)}.modal-content form{padding:20px}.modal-actions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px}.cancel-btn{background:#f3f4f6;background:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#111827;color:var(--text-primary)}.cancel-btn:hover{background:#e5e7eb;background:var(--border-color)}.save-btn{background:#1e40af;background:var(--primary-color);color:#fff}.save-btn:hover{background:#1e3a8a;background:var(--primary-dark)}.data-table.sortable th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.data-table.sortable th.sortable:hover{background:#e5e7eb;background:var(--border-color)}.data-table td.numeric,.data-table th.numeric{text-align:right}.active-filters{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.active-filters>span:first-child{color:#6b7280;color:var(--text-secondary);font-size:.85rem}.filter-tag{align-items:center;background:#3b82f6;background:var(--primary-light);border-radius:20px;color:#fff;display:inline-flex;font-size:.8rem;gap:5px;padding:4px 10px}.filter-tag button{background:none;border:none;color:#fff;cursor:pointer;font-size:1rem;line-height:1;padding:0}.record-count{background:#f3f4f6;background:var(--bg-primary);border-radius:20px;color:#6b7280;color:var(--text-secondary);font-size:.85rem;padding:4px 12px}.actions-cell{white-space:nowrap}.edit-btn{background:#3b82f6!important;background:var(--primary-light)!important;margin-right:5px}.status-btn{background:#10b981!important;background:var(--success-color)!important}.filter-group{align-items:center;display:flex;gap:5px}.empty-cell,.loading-cell{color:#6b7280;color:var(--text-secondary);padding:40px!important;text-align:center!important}.status-badge{align-items:center;display:inline-flex;gap:4px}@media (max-width:768px){.sidebar{width:60px;width:var(--sidebar-collapsed-width)}.sidebar .sidebar-label{display:none}.main-content{margin-left:60px;margin-left:var(--sidebar-collapsed-width)}.dashboard-cards{grid-template-columns:1fr 1fr}.header-left h2{font-size:1rem}.modal-content{margin:10px;max-width:calc(100% - 20px)}.filter-bar{flex-direction:column}.filter-input,.filter-select{min-width:100%}}
/*# sourceMappingURL=main.a4389c51.css.map*/