body{-webkit-overflow-scrolling:touch;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}a,button,input,select,textarea{min-height:44px;min-width:44px}@media (max-width:768px){body{font-size:16px}.container{padding:1rem}.grid,.row{flex-direction:column}.card,.dashboard-card,.info-card{margin-bottom:1rem;width:100%!important}table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}}@media (min-width:769px) and (max-width:1024px){.container{padding:1.5rem}}@media (min-width:1025px){.container{margin:0 auto;max-width:1200px}}@media (display-mode:standalone){body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}:root{--primary-color:#6b8cae;--primary-hover:#5a7a9a;--primary-dark:#405d7a;--secondary-color:#8ba3b8;--background-dark:#1a1d23;--background-card:#23252b;--background-elevated:#2a2d35;--text-primary:#fff;--text-secondary:#d1d5db;--text-muted:#9ca3af;--border-color:#374151;--success-color:#10b981;--warning-color:#f59e0b;--error-color:#ef4444;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;background-color:#1a1d23;background-color:var(--background-dark);color:#fff;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.6;margin:0;padding:0}.container{min-width:0;padding:1.25rem}@media (min-width:768px){.container{padding:2rem}}@media (min-width:1024px){.container{padding:2.5rem}}h1,h2,h3,h4,h5,h6{color:#fff;color:var(--text-primary);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0 0 1rem}h1{margin-bottom:1.5rem}h2{font-size:clamp(1.5rem,3.5vw,2rem)}h3{font-size:clamp(1.25rem,3vw,1.5rem);font-weight:600}p{color:#d1d5db;color:var(--text-secondary);margin:0 0 1rem}input[type=date],input[type=email],input[type=number],input[type=password],input[type=tel],input[type=text],input[type=time],select,textarea{-webkit-appearance:none;appearance:none;background-color:#2a2d35;background-color:var(--background-elevated);border:2px solid #374151;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius-sm);box-shadow:inset 0 1px 3px #0000001a;color:#fff;color:var(--text-primary);font-family:inherit;font-size:1rem;line-height:1.5;min-height:48px;padding:.875rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}@media (max-width:768px){input[type=date],input[type=email],input[type=number],input[type=password],input[type=tel],input[type=text],input[type=time],select,textarea{font-size:16px;min-height:52px}}input:focus,select:focus,textarea:focus{background-color:#23252b;background-color:var(--background-card);border-color:#6b8cae;border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a,inset 0 1px 3px #0000001a;outline:none}input::placeholder{color:#9ca3af;color:var(--text-muted);opacity:.7}select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23D1D5DB' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:12px;cursor:pointer;padding-right:2.5rem}select option{background:#23252b;background:var(--background-card);color:#fff;color:var(--text-primary);font-size:1rem;min-height:48px;padding:.875rem}@media (max-width:768px){select option{font-size:16px;min-height:52px;padding:1rem}}input[type=file]{background-color:#2a2d35;background-color:var(--background-elevated);border:2px solid #374151;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius-sm);color:#fff;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:1rem;min-height:48px;padding:.875rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:100%}input[type=file]:focus,input[type=file]:hover{background-color:#23252b;background-color:var(--background-card);border-color:#6b8cae;border-color:var(--primary-color)}input[type=file]:focus{box-shadow:0 0 0 3px #6b8cae1a;outline:none}input[type=file]::-webkit-file-upload-button{background:#6b8cae;background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-weight:600;margin-right:1rem;padding:.5rem 1rem;-webkit-transition:all .2s cubic-bezier(.4,0,.2,1);transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-transition:all var(--transition-base);transition:all var(--transition-base)}input[type=file]::file-selector-button{background:#6b8cae;background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-weight:600;margin-right:1rem;padding:.5rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}input[type=file]::-webkit-file-upload-button:hover{background:#5a7a9a;background:var(--primary-hover)}input[type=file]::file-selector-button:hover{background:#5a7a9a;background:var(--primary-hover)}.btn,.btn-add,.btn-add-customer,.btn-cancel,.btn-close,.btn-create,.btn-danger,.btn-delete,.btn-edit,.btn-logout,.btn-primary,.btn-remove,.btn-save,.btn-secondary,.btn-upload,.btn-view,.btn-view-user,.modal-btn,a.btn-view,button{-webkit-tap-highlight-color:transparent;align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:1rem;font-weight:700;gap:.5rem;justify-content:center;letter-spacing:.05em;line-height:1.5;min-height:48px;min-width:48px;padding:.875rem 1.5rem;text-decoration:none;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn-view-user:hover,.btn:hover,a.btn-view:hover,button:hover{box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-view-user:active,.btn:active,a.btn-view:active,button:active{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(0)}.btn:disabled,button:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}.btn-add,.btn-add-customer,.btn-create,.btn-upload,button[type=submit]:not(.btn-cancel):not(.btn-delete):not(.btn-logout):not(.btn-close):not(.btn-danger){background:#10b981;background:var(--success-color);color:#fff}.btn-add-customer:hover,.btn-add:hover,.btn-create:hover,.btn-upload:hover,button[type=submit]:not(.btn-cancel):not(.btn-delete):not(.btn-logout):not(.btn-close):not(.btn-danger):hover{background:#059669;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.btn-add-customer:before,.btn-add:before{line-height:1}.btn-cancel,.btn-close,.btn-danger,.btn-delete,.btn-logout,.btn-remove,.modal-btn-danger,button.close-btn{background:#ef4444!important;background:var(--error-color)!important;color:#fff!important}.btn-cancel:hover,.btn-close:hover,.btn-danger:hover,.btn-delete:hover,.btn-logout:hover,.btn-remove:hover,.modal-btn-danger:hover,button.close-btn:hover{background:#dc2626!important;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.btn-edit,.btn-primary,.btn-save,.btn-view,.btn-view-user,.modal-btn-primary,a.btn-view,button.view{background:#6b8cae!important;background:var(--primary-color)!important;color:#fff!important}.btn-edit:hover,.btn-primary:hover,.btn-save:hover,.btn-view-user:hover,.btn-view:hover,.modal-btn-primary:hover,a.btn-view:hover,button.view:hover{background:#5a7a9a!important;background:var(--primary-hover)!important;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.btn-secondary,.modal-btn-secondary{background:#2a2d35;background:var(--background-elevated);border:2px solid #374151;border:2px solid var(--border-color);color:#fff;color:var(--text-primary)}.btn-secondary:hover,.modal-btn-secondary:hover{background:#374151;background:var(--border-color);border-color:#9ca3af;border-color:var(--text-muted)}@media (max-width:768px){.btn,.btn-add,.btn-add-customer,.btn-cancel,.btn-delete,.btn-edit,.btn-primary,.btn-save,.btn-view,.btn-view-user,.modal-btn,button,button[type=submit]{font-size:1.0625rem;min-height:52px;padding:1rem 1.25rem;width:100%}}.card{background:#23252b;background:var(--background-card);border:1px solid #374151;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base)}.card:hover{border-color:#6b8cae4d;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}@media (max-width:768px){.card{border-radius:8px;border-radius:var(--radius-sm);padding:1.25rem}}header{border-bottom:1px solid #374151;border-bottom:1px solid var(--border-color);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--text-primary);padding:1.5rem}footer,header{background:#23252b;background:var(--background-card);text-align:center}footer{border-top:1px solid #374151;border-top:1px solid var(--border-color);color:#9ca3af;color:var(--text-muted);font-size:.875rem;margin-top:auto;padding:1.25rem 1rem}form{gap:1.25rem}.form-group,form{display:flex;flex-direction:column}.form-group{gap:.5rem}label{font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.app-loading,label{color:#d1d5db;color:var(--text-secondary)}.app-loading{align-items:center;display:flex;font-size:1.125rem;justify-content:center;min-height:100vh}.fade-in{animation:fadeIn ease-out .3s cubic-bezier(.4,0,.2,1);animation:fadeIn var(--transition-slow) ease-out}html{scroll-behavior:smooth}:focus-visible{outline:2px solid #6b8cae;outline:2px solid var(--primary-color);outline-offset:2px}@media (max-width:768px){a,button,input[type=checkbox],input[type=radio],select{min-height:48px;min-width:48px}form{gap:1.5rem}body{font-size:16px}}@supports (padding:env(safe-area-inset-top)){body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}}.text-center{text-align:center}.text-muted{color:#9ca3af;color:var(--text-muted)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.btn-add,.btn-add-customer,button[type=submit]:not(.btn-cancel):not(.btn-delete):not(.btn-logout){background:#10b981;background:var(--success-color);box-shadow:0 4px 6px -1px #0000001a;box-shadow:var(--shadow-md);color:#fff;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.btn-add-customer:hover,.btn-add:hover{background:#059669;box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg)}.btn-edit,.btn-save{background:#6b8cae;background:var(--primary-color);color:#fff;font-weight:700}.btn-edit:hover,.btn-save:hover{background:#5a7a9a;background:var(--primary-hover)}.btn-cancel{background:#2a2d35;background:var(--background-elevated);border:2px solid #374151;border:2px solid var(--border-color);color:#fff;color:var(--text-primary);font-weight:700}.btn-cancel:hover{background:#374151;background:var(--border-color);border-color:#9ca3af;border-color:var(--text-muted)}.btn-delete,.btn-logout{background:#ef4444;background:var(--error-color);color:#fff;font-weight:700}.btn-delete:hover,.btn-logout:hover{background:#dc2626}.btn-view{background:#6b8cae;background:var(--primary-color);font-weight:600}.btn-view:hover{background:#5a7a9a;background:var(--primary-hover)}@media (max-width:768px){.btn-add,.btn-add-customer,.btn-cancel,.btn-delete,.btn-edit,.btn-save,.btn-view,button[type=submit]{font-size:1.0625rem;min-height:52px;padding:1rem 1.25rem;width:100%}}.btn-add,.btn-add-customer{overflow:hidden;position:relative}.btn-add-customer:before,.btn-add:before{content:"+";font-size:1.5rem;font-weight:700;margin-right:.25rem}.modal-btn{border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1)}@media (max-width:768px){.modal-btn{padding:1rem;width:100%}}.close-icon,.modal-close,button[aria-label=Close],button[aria-label=Sluiten]{align-items:center;background:#ef4444!important;background:var(--error-color)!important;border-radius:50%;color:#fff!important;display:flex;font-size:1.5rem;font-weight:700;height:40px;justify-content:center;line-height:1;min-height:40px;min-width:40px;padding:0;transform-origin:center center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all var(--transition-base);width:40px}.close-icon:hover,.modal-close:hover{background:#dc2626!important;transform:rotate(90deg) scale(1.1);transform-origin:center center}.no-margin{margin:0!important}.container,.full-width{box-sizing:border-box;width:100%}.container{margin:0 auto;max-width:1200px;padding:1rem}@media (min-width:768px){.container{padding:1.5rem}}@media (min-width:1024px){.container{padding:2rem}}.grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr}@media (min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.grid{gap:1.5rem}.grid-cols-3{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.grid{gap:2rem}.grid-cols-4{grid-template-columns:repeat(4,1fr)}}.customer-info-grid,.dashboard-row,.project-info-grid,.user-list-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr}@media (min-width:768px){.customer-info-grid,.project-info-grid,.user-list-grid{grid-template-columns:repeat(2,1fr)}.dashboard-row{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media (min-width:1024px){.customer-info-grid,.project-info-grid,.user-list-grid{gap:2rem}}.card,.customer-card,.dashboard-card,.info-card,.project-card,.user-card{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);box-sizing:border-box;padding:1.25rem;transition:all var(--transition-base);width:100%}.card:active,.dashboard-card:active,.project-card:active{transform:scale(.98)}@media (min-width:768px){.customer-card,.dashboard-card,.info-card,.project-card,.user-card{padding:1.5rem}}.table-container{-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm);margin:1rem 0;overflow-x:auto;width:100%}table{border-collapse:collapse;font-size:.875rem;width:100%}@media (max-width:768px){table{display:block;overflow-x:auto;white-space:nowrap}.document-table,.employee-table,.timesheet-table,table{font-size:.8125rem}.document-table td,.document-table th,.employee-table td,.employee-table th,.timesheet-table td,.timesheet-table th{min-width:80px;padding:.75rem .5rem}.hide-mobile{display:none}}th{background:var(--background-elevated);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:1rem .75rem;text-align:left}td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.875rem .75rem}tr:hover{background:var(--background-elevated)}@media (max-width:768px){button,input,select,textarea{font-size:16px;min-height:48px}.register-form__wrapper{flex-direction:column}.register-form__company_info,.register-form__personal_info{width:100%}.form-row{gap:1rem}.form-row,.nav-links{flex-direction:column}.nav-links{background:var(--background-card);box-shadow:var(--shadow-xl);left:0;max-height:calc(100vh - 60px);opacity:0;overflow-y:auto;padding:1.5rem 1rem;pointer-events:none;position:fixed;right:0;top:60px;transform:translateX(-100%);transition:transform var(--transition-slow),opacity var(--transition-slow);width:100%;z-index:1000}.nav-links.open{opacity:1;pointer-events:auto;transform:translateX(0)}.nav-links li{margin:0;width:100%}.nav-links li a,.nav-links li button{border-radius:var(--radius-sm);display:block;padding:1rem 1.25rem;transition:background var(--transition-base);width:100%}.nav-links li a:active{background:var(--background-elevated)}.hamburger{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:48px;justify-content:center;padding:0;width:48px;z-index:1001}.hamburger .bar{background:var(--text-primary);border-radius:2px;height:3px;margin:3px 0;transition:all var(--transition-base);width:24px}.dashboard-row{flex-direction:column;gap:1.25rem}.financial-overview-card{padding:1.5rem 1rem}.financial-overview-card h3{font-size:1.5rem}.totals-overview{gap:1rem;grid-template-columns:1fr}.recharts-wrapper{height:auto!important;width:100%!important}}@media (hover:none) and (pointer:coarse){.btn:active,a:active,button:active{opacity:.9;transform:scale(.95)}.card:active,.project-card:active{transform:scale(.98)}}@media (max-width:768px) and (orientation:landscape){.container{padding:1rem 2rem}.dashboard-row{grid-template-columns:repeat(2,1fr)}}@media (min-width:769px) and (max-width:1024px){.container{padding:1.5rem}h1{font-size:2rem}.dashboard-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){ol,ul{padding-left:1.25rem}.dashboard-card ul li{font-size:.9375rem;padding:.875rem .5rem}}iframe,img,video{border-radius:var(--radius-sm);height:auto;max-width:100%}@media (max-width:768px){.dialog,.modal{margin:1rem;max-height:calc(100vh - 2rem);max-width:100%;overflow-y:auto;width:calc(100% - 2rem)}.section,section{margin-bottom:2rem}h1{margin-bottom:1.25rem}h2{margin-bottom:1rem}h3{margin-bottom:.75rem}}.flex-mobile-col{display:flex}@media (max-width:768px){.flex-mobile-col{flex-direction:column}}.flex-tablet-col{display:flex}@media (max-width:1024px){.flex-tablet-col{flex-direction:column}}@media (max-width:768px){.archive-badge,.badge,.status-badge{font-size:.75rem;padding:.25rem .5rem}.sticky-mobile{background:var(--background-card);box-shadow:var(--shadow-md);padding:.75rem 1rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}}body{overscroll-behavior-y:contain}@supports (padding:env(safe-area-inset-bottom)){.container{padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right))}footer{padding-bottom:max(1.25rem,env(safe-area-inset-bottom))}.nav-links{padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}}.flash-message{align-items:center;animation:slideIn .3s ease-out;background:#2c2f3b;border-radius:8px;box-shadow:0 4px 10px #0000;color:#fff;display:flex;gap:10px;justify-content:space-between;max-width:400px;min-width:300px;padding:14px 20px;position:fixed;right:20px;top:20px;z-index:1000}.flash-message span{flex:1 1;font-size:.95rem}.flash-message .flash-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem;padding:0}.flash-success{border-left:5px solid #28a745}.flash-error{border-left:5px solid #dc3545}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-boundary{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.error-boundary__container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000;max-width:600px;padding:3rem;text-align:center}.error-boundary__title{color:#e53e3e;font-size:2rem;margin-bottom:1rem}.error-boundary__message{color:#4a5568;font-size:1.125rem;line-height:1.6;margin-bottom:2rem}.error-boundary__details{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin:2rem 0;padding:1rem;text-align:left}.error-boundary__details summary{color:#2d3748;cursor:pointer;font-weight:600;margin-bottom:.5rem}.error-boundary__stack{background:#2d3748;border-radius:4px;color:#f7fafc;font-family:Courier New,monospace;font-size:.875rem;margin-top:1rem;overflow-x:auto;padding:1rem}.error-boundary__actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.error-boundary__actions button{border-radius:6px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.error-boundary__actions .btn-primary{background:#667eea;border:none;color:#fff}.error-boundary__actions .btn-primary:hover{background:#5a67d8;transform:translateY(-2px)}.error-boundary__actions .btn-secondary{background:#fff;border:2px solid #667eea;color:#667eea}.error-boundary__actions .btn-secondary:hover{background:#f7fafc;transform:translateY(-2px)}.navigation{background-color:var(--background-card);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-md);padding:.75rem 1.25rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-container{justify-content:space-between;margin:auto;max-width:1200px}.nav-container,.nav-logo{align-items:center;display:flex}.nav-logo{z-index:1002}.nav-logo img{height:auto;transition:transform var(--transition-base);width:140px}.nav-logo:hover img{transform:scale(1.05)}@media (max-width:768px){.nav-logo img{width:120px}}.nav-links{align-items:center;display:flex;gap:.5rem;list-style:none;margin:0;padding:0}.nav-links li{position:relative}.nav-links li a,.nav-links li button{align-items:center;border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;font-size:.9375rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;text-decoration:none;transition:all var(--transition-base);white-space:nowrap}.nav-links li a:hover{background:var(--background-elevated);color:var(--text-primary)}.nav-links li a.active{background:var(--primary-color);color:var(--text-primary);font-weight:600}.nav-profile{margin-left:.5rem}.nav-profile img{border:2px solid var(--border-color);border-radius:50%;cursor:pointer;height:40px;object-fit:cover;transition:all var(--transition-base);width:40px}.nav-profile img:hover{border-color:var(--primary-color);transform:scale(1.05)}.btn-logout{background-color:var(--error-color)!important;border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-weight:600;padding:.625rem 1.25rem;transition:all var(--transition-base)}.btn-logout:hover{background-color:#dc2626!important;box-shadow:var(--shadow-md);transform:translateY(-1px)}.hamburger{align-items:center;background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;display:none;flex-direction:column;gap:6px;height:52px;justify-content:center;padding:0;position:relative;transition:all var(--transition-base);width:52px;z-index:1002}.hamburger:hover{background:var(--primary-color);border-color:var(--primary-color);transform:scale(1.05)}.hamburger:active{transform:scale(.98)}.hamburger .bar{background-color:var(--text-primary);border-radius:3px;display:block;height:3px;position:relative;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);width:28px}.hamburger .bar:first-child,.hamburger .bar:nth-child(2),.hamburger .bar:nth-child(3){top:0}.hamburger.open{background:var(--error-color);border-color:var(--error-color)}.hamburger.open .bar{background-color:#fff}.hamburger.open .bar:first-child{transform:translateY(15px) rotate(45deg)}.hamburger.open .bar:nth-child(2){opacity:0}.hamburger.open .bar:nth-child(3){transform:translateY(-15px) rotate(-45deg)}@media (max-width:768px){.navigation{padding:.75rem 1rem}.hamburger{display:flex}.nav-links{-webkit-overflow-scrolling:touch;align-items:stretch;background:var(--background-card);border:none;box-shadow:var(--shadow-xl);flex-direction:column;gap:.5rem;height:100vh;left:0;max-height:100vh;overflow-y:auto;padding:80px 1.5rem 2rem;position:fixed;right:0;top:0;transform:translateX(-100%);transition:transform .3s cubic-bezier(.68,-.55,.265,1.55);width:100%;z-index:1001}.nav-links.open{transform:translateX(0)}.nav-links li{width:100%}.nav-links li a,.nav-links li button{border:2px solid #0000;border-radius:var(--radius-md);font-size:1.0625rem;font-weight:600;justify-content:flex-start;padding:1rem 1.25rem;width:100%}.nav-links li a:hover{background:var(--background-elevated);border-color:var(--primary-color);transform:translateX(4px)}.nav-links li a.active{background:var(--primary-color);border-color:var(--primary-color);box-shadow:var(--shadow-md)}.nav-profile{border-bottom:2px solid var(--border-color);border-top:2px solid var(--border-color);display:flex;justify-content:center;margin-left:0;margin-top:1rem;padding:1rem 0}.nav-profile a{border:none!important;padding:0!important}.nav-profile img{border:3px solid var(--primary-color);height:80px;width:80px}.btn-logout{font-size:1.0625rem;margin-top:1rem;padding:1rem 1.25rem;width:100%}.nav-links.open:before{background:#0000;bottom:0;content:"";left:0;position:fixed;right:0;top:0;z-index:-1}}@media (hover:none){.nav-links li a:hover{background:none;color:var(--text-secondary)}.nav-links li a.active:hover{background:var(--primary-color);color:var(--text-primary)}}.login-container{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 120px);padding:1.5rem}@media (max-width:768px){.login-container{min-height:calc(100vh - 80px);padding:1rem}}.login-box{animation:fadeIn var(--transition-slow) ease-out;background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:420px;padding:2.5rem;text-align:center;width:100%}@media (max-width:768px){.login-box{border-radius:var(--radius-md);padding:2rem 1.5rem}}.login-logo{margin-bottom:2rem;transition:transform var(--transition-base);width:140px}.login-logo:hover{transform:scale(1.05)}@media (max-width:768px){.login-logo{margin-bottom:1.5rem;width:120px}}h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;letter-spacing:-.01em;margin-bottom:2rem}@media (max-width:768px){h2{font-size:1.5rem;margin-bottom:1.5rem}}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form input{background-color:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;min-height:48px;padding:1rem 1.25rem;transition:all var(--transition-base);width:100%}.login-form input:focus{background-color:var(--background-card);border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.login-form input::placeholder{color:var(--text-muted)}@media (max-width:768px){.login-form input{font-size:16px;padding:.875rem 1rem}}.btn-login{background-color:var(--primary-color);border:none;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:600;min-height:48px;padding:1rem 1.5rem;transition:all var(--transition-base);width:100%}.btn-login:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-login:active{transform:translateY(0)}.btn-login:disabled{cursor:not-allowed;opacity:.5;transform:none}.error-message{background:#ef444400;border-left:3px solid var(--error-color);border-radius:var(--radius-sm);margin-bottom:1rem;padding:.75rem 1rem;text-align:left}.register{color:var(--text-secondary);margin-top:1.5rem}.register a{color:var(--primary-color);font-size:.9375rem;font-weight:600;text-decoration:none;transition:color var(--transition-base)}.register a:hover{color:var(--primary-hover);text-decoration:underline}.forgot-password{font-size:.875rem;margin-bottom:.5rem;margin-top:-.5rem;text-align:right}.forgot-password a{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color var(--transition-base)}.forgot-password a:hover{color:var(--primary-hover);text-decoration:underline}.login-loading{align-items:center;color:var(--text-secondary);display:flex;gap:.5rem;justify-content:center}.success-message{background:#10b98100;border-left:3px solid var(--success-color);border-radius:var(--radius-sm);color:var(--success-color);font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem;text-align:left}.form-group-with-icon{position:relative}.form-group-with-icon input{padding-left:3rem}.form-icon{color:var(--text-muted);left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.login-divider{align-items:center;color:var(--text-muted);display:flex;font-size:.875rem;margin:1.5rem 0}.login-divider:after,.login-divider:before{border-bottom:1px solid var(--border-color);content:"";flex:1 1}.login-divider:before{margin-right:1rem}.login-divider:after{margin-left:1rem}@media (max-width:480px){.login-box{padding:1.5rem 1.25rem}h2{font-size:1.375rem}.login-form{gap:1rem}}.login-form{animation:slideUp .4s ease-out .1s both}.register-container{align-items:center;box-sizing:border-box;display:flex;justify-content:center;min-height:calc(100vh - 120px);padding:1.5rem;width:100%}@media (max-width:768px){.register-container{min-height:calc(100vh - 80px);padding:1rem .75rem}}.register-box{box-sizing:border-box;max-width:900px;width:100%}.enhanced-register-form,.register-form{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);box-sizing:border-box;max-width:100%;padding:2.5rem;width:100%}@media (max-width:768px){.enhanced-register-form,.register-form{border-radius:var(--radius-md);padding:1.5rem 1rem}}.register-form__title{color:var(--primary-color);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;margin-bottom:1.5rem;text-align:center}.register-form__wrapper{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}@media (max-width:768px){.register-form__wrapper{gap:1.25rem;grid-template-columns:1fr}}.register-form__card,.register-form__company_info,.register-form__personal_info{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-sizing:border-box;padding:1.5rem;width:100%}@media (max-width:768px){.register-form__card,.register-form__company_info,.register-form__personal_info{padding:1.25rem 1rem}}.register-form__card h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin-bottom:1.25rem;text-align:center}.register-form__field{box-sizing:border-box;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;width:100%}.register-form__field:last-child{margin-bottom:0}.register-form__field label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.register-form__field input{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-size:1rem;min-height:48px;padding:.875rem 1rem;transition:all var(--transition-base);width:100%}@media (max-width:768px){.register-form__field input{font-size:16px;padding:.875rem .75rem}}.register-form__field input:focus{background:var(--background-elevated);border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.register-form__field input::placeholder{color:var(--text-muted)}.enhanced-register-checkbox,.register-form__checkbox{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-sizing:border-box;margin:1.5rem 0;padding:1.25rem;width:100%}@media (max-width:768px){.enhanced-register-checkbox,.register-form__checkbox{margin:1.25rem 0;padding:1rem}}.enhanced-register-checkbox label,.register-form__checkbox label{align-items:flex-start;box-sizing:border-box;color:var(--text-secondary);cursor:pointer;display:flex;gap:.75rem;line-height:1.6;width:100%}.enhanced-register-checkbox input[type=checkbox],.register-form__checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;margin-top:.25rem;min-height:20px;min-width:20px}.enhanced-register-checkbox a,.register-form__checkbox a{color:var(--primary-color);font-weight:600;text-decoration:underline;word-break:break-word}.enhanced-register-checkbox a:hover,.register-form__checkbox a:hover{color:var(--primary-hover)}.register-form__actions{box-sizing:border-box;display:flex;justify-content:center;margin-top:1.5rem;width:100%}.register-form__actions button{background:var(--primary-color);border:none;border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:600;max-width:300px;padding:1rem 2rem;transition:all var(--transition-base);width:100%}@media (max-width:768px){.register-form__actions button{font-size:1.0625rem;max-width:100%}}.register-form__actions button:hover{background:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.register-form__actions button:active{transform:translateY(0)}.register-form__actions button:disabled{cursor:not-allowed;opacity:.6}.error-message{color:var(--error-color);font-size:.875rem;font-weight:500;margin-top:.25rem}.login-logo{display:block;height:auto;margin:0 auto 1.5rem;max-width:100%;width:180px}@media (max-width:768px){.login-logo{margin-bottom:1.25rem;width:150px}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.enhanced-register-form,.register-form{animation:slideUp .4s ease-out}.modal-overlay{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0000;bottom:0;display:flex;height:100vh;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;width:100vw;z-index:1000}.modal-content,.modal-overlay{box-sizing:border-box;overflow-y:auto}.modal-content{animation:fadeIn .2s ease-in-out;background-color:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);margin:auto;max-height:90vh;max-width:500px;padding:1.5rem;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);color:var(--text-primary);display:flex;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem}.modal-header h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0}.modal-close{align-items:center;background:var(--error-color)!important;border:none;border-radius:50%;color:#fff!important;cursor:pointer;display:flex;font-size:1.5rem;font-weight:700;height:40px;justify-content:center;line-height:1;min-height:40px;min-width:40px;padding:0;transform-origin:center center;transition:all var(--transition-base);width:40px}.modal-close:hover{background:#dc2626!important;transform:rotate(90deg) scale(1.1);transform-origin:center center}.modal-body{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.modal-footer{flex-wrap:wrap;gap:1rem;margin-top:1.5rem}@media (max-width:768px){.modal-footer{flex-direction:column-reverse;gap:.75rem}}.modal-footer,.modal-form-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.modal-footer button,.modal-form-actions button{min-width:120px}@media (max-width:768px){.modal-footer,.modal-form-actions{flex-direction:column-reverse;gap:.75rem}.modal-footer button,.modal-form-actions button{min-width:auto;width:100%}}.modal-btn{border-radius:var(--radius-sm);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:1rem;letter-spacing:.05em;min-height:48px;padding:.875rem 1.5rem;text-transform:uppercase;transition:all var(--transition-base)}.modal-btn-primary{background-color:var(--primary-color)!important;color:#fff!important}.modal-btn-primary:hover{background-color:var(--primary-hover)!important;box-shadow:var(--shadow-md);transform:translateY(-2px)}.modal-btn-secondary{background-color:var(--background-elevated);border:2px solid var(--border-color);color:var(--text-primary)}.modal-btn-secondary:hover{background-color:var(--border-color);border-color:var(--text-muted);transform:translateY(-2px)}.modal-btn-danger{background-color:var(--error-color)!important;color:#fff!important}.modal-btn-danger:hover{background-color:#dc2626!important;box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (max-width:600px){.modal-overlay{align-items:flex-start;justify-content:center;padding:8px}.modal-content{border-radius:var(--radius-sm);font-size:1rem;max-height:95vh;max-width:98vw;min-width:0;padding:1.25rem 1rem;width:100vw}.modal-header h3{font-size:1.1rem}.modal-body{font-size:1rem;margin-bottom:1.25rem}.modal-footer{flex-direction:column-reverse;gap:.75rem}.modal-btn{font-size:1rem;min-height:52px;padding:1rem;width:100%}.modal-close{font-size:1.5rem;height:36px;min-height:36px;min-width:36px;width:36px}}.back-button{align-items:center;background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);color:var(--text-primary);cursor:pointer;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:1rem;font-weight:700;gap:.75rem;letter-spacing:.05em;margin-bottom:1.5rem;padding:.875rem 1.5rem;text-transform:uppercase;transition:all var(--transition-base)}.back-button:hover{background:var(--primary-color);border-color:var(--primary-color);box-shadow:var(--shadow-md);color:#fff;transform:translateY(-2px)}.back-button:active{box-shadow:var(--shadow-sm);transform:translateY(0)}.back-button-arrow{font-size:1.5rem;font-weight:700;line-height:1;transition:transform var(--transition-base)}.back-button:hover .back-button-arrow{transform:translateX(-4px)}.back-button-text{line-height:1.5}@media (max-width:768px){.back-button{font-size:1.0625rem;justify-content:center;margin-bottom:1.25rem;padding:1rem 1.25rem;position:static;width:100%}.back-button-arrow{font-size:1.25rem}}.profile-form{color:#fff;font-family:Segoe UI,sans-serif;margin:auto;max-width:1200px;min-width:0;padding:20px}.profile-form__title{font-size:1.75rem;margin-bottom:1rem}.profile-form__card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:16px;box-shadow:0 4px 24px #2c3e5000;gap:2.5rem;margin-top:2.5rem;padding:2.5rem 2rem}.profile-form__section{display:flex;gap:2.5rem;margin-top:2.5rem}.profile-form__image-wrapper{align-items:center;display:flex;flex-direction:column;gap:.75rem;width:100%}.profile-form__image{border:3px solid #ddd;border-radius:100%;height:120px;object-fit:cover;width:120px}.profile-form__image--clickable{box-shadow:0 2px 12px #2c3e5000;cursor:pointer!important;transition:box-shadow .2s,transform .2s}.profile-form__image--clickable:hover{border-color:#7495b4;box-shadow:0 4px 24px #2c3e5000;transform:scale(1.04)}.profile-form__image-placeholder{align-items:center;background:#f1f1f1;border-radius:100%;color:#aaa;display:flex;font-size:.9rem;height:120px;justify-content:center;width:120px}.profile-form__image-hint{color:#bfc4d1;font-size:.95em;margin-top:.3em;opacity:.85;text-align:center}.profile-form__fields label{display:block;font-weight:600;margin-bottom:.25rem;margin-top:1rem}.profile-form__fields label.bold-label{font-weight:700}.profile-form__fields input{background:#2c2f3b;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;color:#fff;font-size:1rem;padding:12px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.profile-form__actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.profile-form__actions button{margin:.5rem 0}.wrapper{display:flex;flex-direction:row;gap:2rem;width:100%}@media (max-width:768px){.wrapper{flex-direction:column;gap:1.25rem}}h3{text-align:left}.profile-form__company_info,.profile-form__personal_info{background:#2c3e5000;border-radius:10px;box-shadow:0 2px 8px #0000;flex:1 1;margin-bottom:1.2rem;padding:1.2rem 1rem}.profile-form__company_info h3,.profile-form__personal_info h3{color:#7495b4;font-size:1.1rem;margin-bottom:.7rem}.profile-image-modal .modal-content{align-items:center;background:#0000;box-shadow:none;display:flex;justify-content:center;padding:0}.profile-image-modal__content{align-items:center;display:flex;justify-content:center;min-height:40vh;min-width:40vw}.profile-image-modal__img{background:#23252b;border:4px solid #fff;border-radius:16px;box-shadow:0 8px 32px #2c3e5000,0 2px 8px #2c3e5000;max-height:80vh;max-width:90vw;object-fit:contain;transition:box-shadow .2s}.documents-table{background:#23252b;border-radius:8px;max-width:100%;overflow:hidden;width:100%}.documents-table td,.documents-table th{border-bottom:1px solid #374959;padding:12px 10px}.documents-table th{background:#374959;color:#fff;font-weight:600}.documents-table tr:hover{background:linear-gradient(135deg,#23252b 80%,#2b3a49)}.documents-table td button{margin:.25rem}.toggle-upload-form-btn{margin:1rem 0}.document-icon{flex-shrink:0;font-size:2rem}.document-info h4,.document-info p{white-space:nowrap}.custom-loader-overlay{background:#23252b00;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:9999}.custom-loader-content,.custom-loader-overlay{align-items:center;display:flex;flex-direction:column;justify-content:center}.custom-loader-content{gap:2rem}.custom-loader-logo{animation:spin 1.2s linear infinite;filter:drop-shadow(0 2px 12px #23252b88);height:90px;width:90px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.custom-loader-message{color:#fff;font-size:1.25rem;font-weight:500;margin-top:.5rem;text-align:center;text-shadow:0 2px 8px #23252b99}.custom-loader-content.enhanced-loader{background:#282c3400;border-radius:1.5rem;box-shadow:0 8px 32px #23252b55,0 0 0 4px #23252b22;gap:2.5rem;min-height:220px;min-width:260px;padding:2.5rem 2.5rem 2rem;position:relative}.enhanced-spinner{align-items:center;display:flex;justify-content:center;margin-bottom:.5rem;position:relative}.enhanced-logo{filter:drop-shadow(0 2px 18px #00cfff88) drop-shadow(0 0 8px #fff2);z-index:2}.spinner-ring{animation:ring-spin 1.1s cubic-bezier(.6,.2,.4,.8) infinite;border-bottom:6px solid #00cfff33;border-radius:50%;border-top:6px solid #00cfff33;border-color:#00cfff #00cfff33 #fff0;border-style:solid;border-width:6px;box-shadow:0 0 24px #00cfff44;height:110px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:110px;z-index:1}@keyframes ring-spin{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.enhanced-message{color:#e0f7fa;font-size:1.3rem;font-weight:600;letter-spacing:.01em;text-shadow:0 2px 12px #00cfff55,0 1px 2px #23252b99}.construction-gear-spinner{margin-bottom:.5rem;min-height:120px}.construction-gear-spinner,.gear{align-items:center;display:flex;justify-content:center}.gear{animation:gear-spin 1.2s linear infinite;background:#f9a825;border-radius:50%;box-shadow:0 0 24px #f9a82555,0 2px 12px #23252b88;height:90px;position:relative;width:90px}.gear-inner{background:#23252b;border-radius:50%;box-shadow:0 0 0 6px #fff3,0 2px 8px #23252b99;height:38px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:38px}.gear-tooth{background:#fbc02d;border-radius:3px;box-shadow:0 2px 6px #23252b44;height:10px;position:absolute;width:18px}.gear-tooth.tooth-0{left:36px;top:-6px;transform:rotate(0deg)}.gear-tooth.tooth-1{left:68px;top:8px;transform:rotate(45deg)}.gear-tooth.tooth-2{left:80px;top:36px;transform:rotate(90deg)}.gear-tooth.tooth-3{left:68px;top:68px;transform:rotate(135deg)}.gear-tooth.tooth-4{left:36px;top:80px;transform:rotate(180deg)}.gear-tooth.tooth-5{left:8px;top:68px;transform:rotate(225deg)}.gear-tooth.tooth-6{left:-6px;top:36px;transform:rotate(270deg)}.gear-tooth.tooth-7{left:8px;top:8px;transform:rotate(315deg)}@keyframes gear-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.hammer-nail-loader{align-items:center;display:flex;justify-content:center;margin-bottom:.5rem;min-height:100px}.hammer-handle,.hammer-head{animation:hammer-swing 1s cubic-bezier(.7,.1,.3,.9) infinite;transform-origin:66px 38px}@keyframes hammer-swing{0%{transform:rotate(-25deg)}15%{transform:rotate(-25deg)}30%{transform:rotate(0deg)}45%{transform:rotate(-10deg)}60%{transform:rotate(0deg)}to{transform:rotate(-25deg)}}@media (max-width:600px){.custom-loader-logo{height:60px;width:60px}.custom-loader-message{font-size:1.05rem}.enhanced-loader{min-height:120px;min-width:160px;padding:1.2rem .5rem 1rem}.spinner-ring{border-width:4px;height:70px;width:70px}}.no-data-construction{flex-direction:column;min-height:220px;padding:36px}.no-data-construction,.no-data-construction__icon{align-items:center;display:flex;justify-content:center}.no-data-construction__icon{background:#2b3a49;border-radius:16px;box-shadow:0 2px 12px #23252b00;height:120px;margin-bottom:18px;width:120px}.no-data-construction__icon-text{color:#7495b4;font-size:80px;font-weight:700;line-height:1;-webkit-user-select:none;user-select:none}.no-data-construction__message{align-items:center;color:#7495b4;display:flex;font-size:22px;font-weight:600;justify-content:center;letter-spacing:.01em;line-height:1.4;margin:0 auto;max-width:420px;text-align:center}@media (max-width:768px){.no-data-construction{min-height:180px;padding:24px}.no-data-construction__icon{height:90px;margin-bottom:14px;width:90px}.no-data-construction__icon-text{font-size:60px}.no-data-construction__message{font-size:18px;max-width:100%}}.project-detail,.projects-container{color:var(--text-primary);margin:auto;max-width:1200px;min-width:0;padding:1.25rem}@media (min-width:768px){.project-detail,.projects-container{padding:2rem}}.project-detail-container{margin:auto;max-width:1200px;min-width:0;padding:1.25rem}@media (min-width:768px){.project-detail-container{padding:2rem}}.whatsapp-button{align-items:center;background:#25d366;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);color:#fff;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin:1.5rem 0;padding:.875rem 1.5rem;text-decoration:none;transition:all var(--transition-base)}.whatsapp-button:before{content:"📱";font-size:1.5rem}.whatsapp-button:hover{background:#1fb855;box-shadow:var(--shadow-md);transform:translateY(-2px)}.whatsapp-button:active{transform:translateY(0)}@media (max-width:768px){.whatsapp-button{margin:1.25rem 0;width:100%}}.bottom-margin{margin-bottom:2rem}.toggle-btn{background:var(--background-elevated)!important;border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 1.75rem;transition:all var(--transition-base)}.toggle-btn:first-child{margin-right:1.25rem}@media (max-width:768px){.toggle-btn{flex:1 1;font-size:.9375rem;padding:.875rem 1.25rem}.toggle-btn:first-child{margin-right:.75rem}}.toggle-btn.active{background:var(--primary-color)!important;border-color:var(--primary-color);box-shadow:var(--shadow-md);color:var(--text-primary)!important}.toggle-btn:hover:not(.active){background:var(--background-card)!important;border-color:var(--primary-color)}.project-info-grid.enhanced-mobile-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:1.5rem}@media (min-width:640px){.project-info-grid.enhanced-mobile-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.project-form{display:flex;flex-direction:column;gap:1.5rem}.project-form label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.add-employee-form{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1.25rem;margin-top:1rem;padding:1.5rem}@media (max-width:768px){.add-employee-form{padding:1.25rem}}.add-employee-form label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.375rem;text-transform:uppercase}.add-employee-form input,.add-employee-form select{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-size:1rem;min-height:48px;padding:.875rem 1rem;transition:all var(--transition-base);width:100%}@media (max-width:768px){.add-employee-form input,.add-employee-form select{font-size:16px}}.add-employee-form input:focus,.add-employee-form select:focus{background:var(--background-card);border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.employee-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}@media (max-width:768px){.employee-actions{flex-direction:column;gap:.75rem}}.employee-actions-inline{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}@media (max-width:768px){.employee-actions-inline{align-items:stretch;flex-direction:column;gap:.5rem;justify-content:center;width:100%}.employee-actions-inline button{width:100%}}.project-detail__documents_container,.project-detail__employees_container{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:1rem;margin-top:2rem;padding:1.5rem;transition:all var(--transition-base)}.project-detail__documents_container:hover,.project-detail__employees_container:hover{border-color:#6b8cae4d;box-shadow:var(--shadow-lg)}@media (max-width:768px){.project-detail__documents_container,.project-detail__employees_container{padding:1.25rem}}.project-detail__documents{padding:1rem 0}.project-detail__totals_container{background:linear-gradient(135deg,var(--background-card) 0,var(--background-elevated) 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-bottom:2rem;margin-top:2rem;padding:2rem 1.5rem}@media (max-width:768px){.project-detail__totals_container{padding:1.5rem 1rem}}.totals-piechart-wrapper{min-height:650px}@media (max-width:768px){.totals-piechart-wrapper{min-height:550px}}.project-card{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);cursor:pointer;display:flex;flex-direction:column;padding:1.5rem;transition:all var(--transition-base)}.project-card:hover{border-color:#6b8cae4d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.project-card:active{transform:translateY(0)}@media (max-width:768px){.project-card{padding:1.25rem}}.project-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:1rem}.project-card-header h3{color:var(--primary-color);font-size:1.25rem;font-weight:600;margin:0}@media (max-width:768px){.project-card-header h3{font-size:1.125rem}}.archive-badge{background:var(--background-elevated);border-radius:12px;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.project-card-body{flex:1 1;margin-bottom:1.25rem}.project-meta p{align-items:center;color:var(--text-secondary);display:flex;font-size:.9375rem;gap:.5rem;margin:.5rem 0}@media (max-width:768px){.project-meta p{font-size:.875rem}}.placeholder{color:var(--text-muted)}.project-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;margin-top:1.5rem}@media (max-width:768px){.project-actions{flex-direction:column;margin-bottom:1rem;margin-top:1rem}.project-actions a,.project-actions button{width:100%}}.project-card.archived{background:var(--background-elevated);opacity:.7}.project-card.archived:hover{opacity:.85}.projects-list{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr;margin-top:2rem}@media (min-width:640px){.projects-list{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.projects-list{gap:1.5rem;grid-template-columns:repeat(3,1fr)}}.info-card{background:linear-gradient(135deg,var(--background-card) 0,var(--background-elevated) 100%);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:1.5rem;transition:all var(--transition-base)}.info-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-lg);transform:translateY(-2px)}@media (max-width:768px){.info-card{padding:1.25rem}}.info-card h3{align-items:center;border-bottom:3px solid var(--primary-color);color:var(--primary-color);display:flex;font-size:1.375rem;font-weight:700;gap:.75rem;letter-spacing:.05em;margin-bottom:1.5rem;padding-bottom:.75rem;text-transform:uppercase}.info-card h3:before{background:var(--primary-color);border-radius:4px;box-shadow:0 2px 8px #6b8cae00;content:"";display:inline-block;height:28px;width:8px}@media (max-width:768px){.info-card h3{font-size:1.125rem}.info-card h3:before{height:22px;width:6px}}.info-card h4{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.info-card p{align-items:center;background:#fff0;border-left:3px solid var(--primary-color);border-radius:var(--radius-sm);color:var(--text-primary);display:flex;font-size:1.0625rem;font-weight:500;justify-content:space-between;margin:.875rem 0;padding:1rem;transition:all var(--transition-base)}.info-card p:hover{background:#fff0;border-left-color:var(--primary-hover)}.info-card p:last-of-type{margin-bottom:0}.info-card p strong{align-items:center;color:var(--text-secondary);display:flex;font-size:.875rem;font-weight:700;gap:.5rem;letter-spacing:.08em;min-width:160px;text-transform:uppercase}.info-card p strong:after{color:var(--primary-color);content:":";font-size:1.125rem;font-weight:900}@media (max-width:768px){.info-card p{align-items:flex-start;flex-direction:column;gap:.5rem;padding:.875rem}.info-card p strong{font-size:.8125rem;min-width:auto}}.info-card label{color:var(--primary-color);display:block;font-size:.875rem;font-weight:700;letter-spacing:.08em;margin-bottom:.5rem;margin-top:1rem;text-transform:uppercase}.info-card label:first-of-type{margin-top:0}.info-card input{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-size:1rem;font-weight:500;margin-bottom:.75rem;padding:.875rem 1rem;transition:all var(--transition-base);width:100%}.info-card input:focus{background:var(--background-card);border-color:var(--primary-color);box-shadow:0 0 0 4px #6b8cae00;outline:none}.project-info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;margin-bottom:2rem}@media (min-width:768px){.project-info-grid{gap:2.5rem;grid-template-columns:repeat(2,1fr)}}.project-info-grid.full-width{grid-template-columns:1fr}.project-timesheet-summary-card{grid-gap:1.5rem;background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem;padding:1.5rem}.project-timesheet-summary-card .summary-item{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:.5rem;padding:1rem}.project-timesheet-summary-card .summary-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.project-timesheet-summary-card .summary-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.project-timesheet-status-summary{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.status-summary-count{font-weight:700;margin-left:.25rem}.timesheet-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media (max-width:768px){.timesheet-cards-grid{gap:1.25rem;grid-template-columns:1fr}}.project-timesheet-card{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;gap:1rem;padding:1.25rem;text-decoration:none;transition:all var(--transition-base)}.project-timesheet-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-timesheet-card:active{transform:scale(.98)}.project-timesheet-card .timesheet-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding-bottom:.75rem}.project-timesheet-card .timesheet-project{color:var(--primary-color);font-size:1.125rem;font-weight:700}.project-timesheet-card .timesheet-card-body{display:flex;flex-direction:column;gap:.75rem}.project-timesheet-card .timesheet-detail-row{align-items:center;display:flex;font-size:.9375rem;justify-content:space-between}.project-timesheet-card .detail-label{color:var(--text-secondary);font-weight:600}.project-timesheet-card .detail-value{color:var(--text-primary);font-weight:600}.project-timesheet-card .detail-value.highlight{color:var(--primary-color);font-size:1.0625rem;font-weight:700}.project-timesheet-card-actions{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem;margin-top:auto;padding-top:1rem}.project-timesheet-card-actions .btn-delete,.project-timesheet-card-actions .btn-view{text-align:center;width:100%}.donut-chart-container{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;width:100%}.donut-chart-title{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.donut-chart-wrapper{align-items:center;display:flex;justify-content:center;padding:1rem 0}.donut-chart-svg{height:auto;max-width:400px;overflow:visible;width:100%}.donut-segment{transition:all .2s ease}.donut-segment:hover{filter:brightness(1.15)}.donut-center-text{fill:var(--text-secondary);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.donut-center-value{fill:var(--text-primary);font-size:14px;font-weight:700}.donut-chart-legend{grid-gap:1rem;border-top:1px solid var(--border-color);display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2rem;padding-top:1.5rem}.legend-item{align-items:center;background:var(--background-elevated);border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:all var(--transition-base)}.legend-item.active,.legend-item:hover{background:var(--background-card);transform:translateX(4px)}.legend-color{border:2px solid var(--background-dark);border-radius:50%;height:16px;min-width:16px;width:16px}.legend-label{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.legend-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.legend-value{color:var(--text-secondary);font-size:.875rem;font-weight:500}@media (max-width:768px){.donut-chart-container{padding:1rem}.donut-chart-svg{max-width:300px}.donut-chart-legend{gap:.75rem;grid-template-columns:1fr}.donut-center-text{font-size:10px}.donut-center-value{font-size:12px}}.timesheet-form,.timesheet-list{margin:auto;max-width:1200px;min-width:0;padding:1.25rem}@media (min-width:768px){.timesheet-form,.timesheet-list{padding:2rem}}.create-timesheet-wrapper{display:flex;justify-content:center;margin-bottom:1.5rem}.btn-add-timesheet{align-items:center;background:var(--success-color);border:none;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Helvetica Neue,sans-serif;font-size:1rem;font-weight:700;gap:.5rem;justify-content:center;letter-spacing:.05em;line-height:1.5;min-height:48px;padding:.875rem 1.5rem;text-decoration:none;text-transform:uppercase;transition:all var(--transition-base)}.btn-add-timesheet:hover{background:#059669;box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (max-width:768px){.btn-add-timesheet{font-size:1.0625rem;min-height:52px;padding:1rem 1.25rem;width:100%}}.btn-approve{background:var(--success-color)!important;color:#fff!important}.btn-approve:hover{background:#059669!important}.filters,.timesheetlist-toolbar{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;padding:1.5rem}.timesheetlist-search{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;padding:.875rem 1rem;transition:all var(--transition-base);width:100%}.timesheetlist-search:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.filters-dropdowns{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width:768px){.filters-dropdowns{grid-template-columns:1fr}}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.filter-group select{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:1rem;padding:.875rem 1rem;transition:all var(--transition-base)}.filter-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.status-badge{border-radius:12px;font-size:.75rem;padding:.375rem .75rem}.status-badge-approved_by_voorman,.status-badge-pending{background:#f59e0b00;color:var(--warning-color)}.status-badge-approved{background:#10b98100;color:var(--success-color)}.status-badge-rejected{background:#ef444400;color:var(--error-color)}.timesheet-list-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}@media (max-width:768px){.timesheet-list-grid{gap:1.25rem;grid-template-columns:1fr}}.timesheet-card{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;padding:1.25rem;transition:all var(--transition-base)}.timesheet-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.timesheet-card-header{align-items:center;flex-wrap:wrap;justify-content:space-between}.timesheet-card-title{color:var(--primary-color);font-size:1.125rem;font-weight:700}.timesheet-card-details{display:flex;flex-direction:column;gap:.75rem;padding:.75rem 0}.timesheet-card-details>div{align-items:center;display:flex;font-size:.9375rem;justify-content:space-between}.timesheet-card-details b{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.timesheet-card-details span{color:var(--text-primary);font-weight:600}.timesheet-card-actions{border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem;margin-top:auto;padding-top:1rem}.timesheet-card-actions .btn-primary,.timesheet-card-actions .btn-primary.full-width,.timesheet-card-actions .btn-view,.timesheet-card-actions .btn-view.full-width{justify-content:center!important;text-align:center!important;width:100%!important}.timesheet-card-actions a,.timesheet-card-actions button{align-items:center;display:flex;justify-content:center;text-align:center;width:100%}.timesheet-card-actions button:contains("Verwijderen"),.timesheet-card-actions button[onClick*=confirmDelete]{background:var(--error-color)!important;color:#fff!important}.timesheet-card-actions button[onClick*=confirmDelete]:hover{background:#dc2626!important}.voorman-projects-list{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:1rem 0;padding:0}.voorman-projects-list li{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-weight:600;padding:1rem}.notifications__empty{color:var(--text-secondary);font-size:1rem;padding:2rem}.timesheet-form{color:#fff;font-family:Segoe UI,sans-serif;margin:auto;max-width:1200px;min-width:0;padding:20px}.timesheet-form--card{margin:2.5rem auto;max-width:1200px;padding:2.5rem}.timesheet-form__title{font-size:1.8rem;font-weight:700;margin-bottom:.5rem;text-align:center}.timesheet-form__subtitle{color:#aaa;font-size:1.1rem;margin-bottom:2rem;text-align:center}.timesheet-form__nav{display:flex;justify-content:space-between;margin-bottom:20px}.timesheet-form__nav button{background-color:#7495b4;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 18px}.timesheet-form__nav button:hover{background-color:#374959}.timesheet-form__project{margin-bottom:20px}.timesheet-form__project label,.timesheet-form__row label{color:#bfc4d1;display:block;font-weight:600;margin-bottom:6px}.timesheet-form__project select{background:#2c2f3b;border:1.5px solid #7495b4;border-radius:6px;color:#fff;font-size:1.08rem;padding:12px;width:100%}.timesheet-form__grid{grid-gap:1.5rem 2.5rem;display:grid;gap:1.5rem 2.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:.5rem;margin-left:auto;margin-right:auto;max-width:600px}.timesheet-form__grid-wrapper{width:100%}.timesheet-form__day{align-items:flex-start;background:#23252b;border:1px solid #374959;border-radius:.5rem;display:flex;flex-direction:column;gap:.3rem;min-width:120px;padding:.7rem .6rem}.timesheet-form__day label{color:#bfc4d1;font-size:1.05rem;font-weight:600;margin-bottom:4px}.timesheet-form__day input{background:#2c2f3b;border:1.5px solid #444;border-radius:6px;color:#fff;font-size:1.08rem;margin-bottom:2px;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.timesheet-form__day input:focus{border-color:#7495b4;box-shadow:0 0 8px #7495b4aa}.timesheet-form__extra-section,.timesheet-form__material-section{margin-top:30px}.timesheet-form__section{background:#23252b;border:1px solid #2c2f3b;border-radius:.7rem;box-shadow:0 1px 6px #0000;margin-bottom:2.5rem;padding:2rem 2rem 1.5rem}.timesheet-form__section h3{border-bottom:1px solid #374959;color:#fff;font-size:1.25rem;margin-bottom:1.2rem;padding-bottom:.5rem}.timesheet-form__row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1.2rem;margin-bottom:1.2rem}.timesheet-form__row--extra,.timesheet-form__row--material{align-items:center;background:#23252b;border:1px solid #374959;border-radius:.5rem;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;padding:1rem .8rem}.timesheet-form__row input,.timesheet-form__row select{background:#2c2f3b;border:1.5px solid #444;border-radius:6px;color:#fff;font-size:1.08rem;margin-bottom:2px;min-width:0;padding:12px;transition:border-color .2s,box-shadow .2s}.timesheet-form__row input:focus,.timesheet-form__row select:focus{border-color:#7495b4;box-shadow:0 0 8px #7495b4aa}.timesheet-form__row input[type=file]{background:none;color:#bfc4d1;padding:0}.timesheet-form__row button{background-color:#a71d2a;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:10px}.timesheet-form__row button:hover{background-color:#dc3545}.file-input-wrapper{display:flex;flex-direction:column;gap:.3rem}.file-selected{color:#1d5c3b;display:inline-block;font-size:.9rem;font-weight:600;margin-top:.2rem}.timesheet-form__summary{background:#2c2f3b;border:1px solid #374959;border-radius:8px;color:#ccc;font-size:1.08rem;margin-bottom:30px;margin-top:30px;padding:18px}.timesheet-form__actions{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:flex-end;margin-top:2rem}.timesheet-form__actions button{border:none;border-radius:6px;cursor:pointer;font-size:1.1rem;font-weight:600;max-width:100%;padding:16px 0;transition:background-color .3s ease;width:220px}.timesheet-form__actions button.btn-view{color:#fff}.timesheet-form__actions button.btn-save{background-color:#1d5c3b;color:#fff}.timesheet-form__actions button.btn-save:hover{background-color:#1e7e34}.timesheet-form__actions button:disabled{background-color:#555;cursor:not-allowed}@media (max-width:1100px){.timesheet-form--card{max-width:98vw}.timesheet-form__grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.timesheet-form__grid{grid-template-columns:repeat(2,1fr)}.timesheet-form--card{padding:1.2rem .5rem 1.5rem}.timesheet-form__section{padding:.7rem .3rem}}@media (max-width:700px){.timesheet-form__grid{gap:.7rem;grid-template-columns:1fr}.timesheet-form__row{flex-direction:column;gap:.5rem}.timesheet-form__row input,.timesheet-form__row select{font-size:1rem;min-height:38px;padding:10px 8px}.timesheet-form__row--extra,.timesheet-form__row--material{padding:.5rem .4rem}.timesheet-form__actions{align-items:stretch;flex-direction:column;gap:.7rem}.timesheet-form__actions button{width:100%}}.timesheet-container{margin:auto;max-width:1200px;min-width:0;padding:1.25rem;width:100%}@media (min-width:768px){.timesheet-container{padding:2rem}}.timesheet-detail--card{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:1.5rem}@media (max-width:768px){.timesheet-detail--card{box-shadow:var(--shadow-sm);padding:1.25rem}}.timesheet-header{margin-bottom:2rem}.timesheet-header h2{color:var(--text-primary);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;margin-bottom:1.5rem;text-align:center}.timesheet-header--card{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:1.5rem}@media (max-width:768px){.timesheet-header--card{padding:1.25rem}}.meta-info{grid-gap:1rem;display:grid;font-size:.9375rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1.5rem}@media (max-width:768px){.meta-info{font-size:.875rem;gap:.75rem;grid-template-columns:1fr}}.meta-info div{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-weight:500;padding:1rem}@media (max-width:768px){.meta-info div{padding:.875rem}}.meta-info div strong{color:var(--text-secondary);display:block;font-size:.8125rem;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.meta-info--card{background:#0000;padding:0}.status-badge{border-radius:var(--radius-sm);display:inline-block;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1rem;text-align:center;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.status-badge.approved,.status-badge.approved_by_voorman{background:#10b98100;color:var(--success-color)}.status-badge.rejected{background:#ef444400;color:var(--error-color)}.status-badge.pending{background:#f59e0b00;color:var(--warning-color)}@media (max-width:768px){.status-badge{font-size:.75rem;padding:.375rem .75rem;width:100%}}a.btn-view{display:inline-block;margin-top:1rem;padding:.875rem 1.5rem}.timesheet-section{display:block;margin-bottom:2rem;width:100%}.timesheet-section--card{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:1.5rem}@media (max-width:768px){.timesheet-section--card{padding:1.25rem}}.timesheet-info{width:100%}.timesheet-section h3{border-bottom:2px solid var(--border-color);color:var(--primary-color);font-size:1.25rem;font-weight:600;margin-bottom:1.25rem;padding-bottom:.75rem}@media (max-width:768px){.timesheet-section h3{font-size:1.125rem;margin-bottom:1rem}}.table-wrapper{-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm);margin-bottom:1rem;overflow-x:auto;width:100%}.extra-work-table,.materials-table,.timesheet-table{background:var(--background-card);border:1px solid var(--border-color);border-collapse:collapse;border-radius:var(--radius-sm);margin-top:1rem;overflow:hidden;width:100%}.extra-work-table th,.materials-table th,.timesheet-table th{background:var(--background-elevated);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600;padding:1rem .75rem;text-align:left}.extra-work-table td,.materials-table td,.timesheet-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:.875rem .75rem}.extra-work-table tr:last-child td,.materials-table tr:last-child td,.timesheet-table tr:last-child td{border-bottom:none}.extra-work-table tbody tr:hover,.materials-table tbody tr:hover,.timesheet-table tbody tr:hover{background:var(--background-elevated)}@media (max-width:768px){.extra-work-table,.materials-table{border:none;display:block}.extra-work-table thead,.materials-table thead{display:none}.extra-work-table tbody,.extra-work-table tr,.materials-table tbody,.materials-table tr{display:block;width:100%}.extra-work-table tr,.materials-table tr{background:var(--background-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1rem}.extra-work-table td,.materials-table td{border:none;display:flex;flex-direction:column;padding:.75rem 0;text-align:left}.extra-work-table td:before,.materials-table td:before{color:var(--text-secondary);content:attr(data-label);font-size:.8125rem;font-weight:600;letter-spacing:.05em;margin-bottom:.375rem;text-transform:uppercase}.extra-work-table td,.materials-table td{color:var(--text-primary)}.timesheet-table{font-size:.875rem}.timesheet-table td,.timesheet-table th{font-size:.8125rem;padding:.75rem .5rem}}.meerwerk-foto{border:2px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;max-height:120px;max-width:120px;object-fit:cover;transition:transform var(--transition-base)}.meerwerk-foto:hover{border-color:var(--primary-color);transform:scale(1.05)}@media (max-width:768px){.meerwerk-foto{max-height:100px;max-width:100px}}.timesheet-actions{border-top:2px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem;padding-top:1.5rem}@media (max-width:768px){.timesheet-actions{flex-direction:column;gap:.75rem}.timesheet-actions button{width:100%}}.summary-badge{align-items:center;border-radius:var(--radius-md);display:inline-flex;font-size:1.25rem;font-weight:700;justify-content:center;margin:1.5rem 0;padding:1rem 1.5rem;text-align:center}.summary-badge.positive{background:#10b98100;color:var(--success-color)}.summary-badge.negative{background:#ef444400;color:var(--error-color)}@media (max-width:768px){.summary-badge{font-size:1.125rem;padding:.875rem 1.25rem}}.notifications{background:#23252b;border-radius:8px;box-shadow:0 4px 12px #0000;color:#fff;margin:30px auto;max-width:1000px;padding:30px}.notifications__title{font-size:1.5rem;margin-bottom:20px;text-align:center}.notifications__empty{color:#bbb;font-size:1.2rem;padding:40px 0;text-align:center}.notifications__table{background:#2c2f3b;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.notifications__table td,.notifications__table th{border-bottom:1px solid #3d3f4a;padding:14px 16px;text-align:left}.notifications__table th{background:#7495b4;color:#fff}.notifications__row td{color:#ddd}.notifications__row.status-unread{background:#f000}.notifications__row.status-read{background:#00800000}.top-margin{margin-top:.5rem}.notification__message{background:#2c2f3b;border-radius:6px;color:#e0e0e0;line-height:1.5;margin:10px 0;padding:10px}.notification__message-table{background:#23252b;border-radius:6px;font-size:1rem;line-height:1.5;max-width:250px;overflow-wrap:break-word;padding:10px 12px;white-space:pre-line;word-break:break-word}.notification__message-table a{color:#4ea1f7;font-weight:500;text-decoration:underline;transition:color .2s;word-break:break-all}.notification__message-table a:hover{color:#1d5c3b;text-decoration:underline}.notification__message-table strong{color:#fff}@media (max-width:700px){.notifications__table,.notifications__table tbody,.notifications__table thead,.notifications__table tr{box-sizing:border-box;display:block;width:100%}.notifications__table thead{display:none}.notifications__table tr{background:#23252b;border-radius:8px;box-shadow:0 2px 8px #0000;box-sizing:border-box;margin-bottom:18px;padding:10px 0;width:100%}.notifications__table td{align-items:center;background:none;border:none;border-bottom:1px solid #3d3f4a;box-sizing:border-box;display:flex;font-size:1rem;justify-content:space-between;padding:10px 16px;position:relative;width:100%;word-break:break-word}.notifications__table td:last-child{border-bottom:none}.notifications__table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);flex:0 0 50%;font-size:.95em;font-weight:600;padding-right:10px;text-align:left;word-break:break-word}.notifications__table td[data-label=Acties]{align-items:stretch;flex-direction:column;gap:8px}.notifications__table td[data-label=Acties] button{margin-bottom:6px;width:100%}.notifications__table td[data-label=Acties] button:last-child{margin-bottom:0}.actions{align-items:stretch;flex-direction:column;gap:8px}}.todo-list{background:#23252b;border-radius:8px;box-shadow:0 4px 8px #0000;color:#fff;margin:30px auto;max-width:1000px;padding:30px}.todo-list h2{margin-bottom:20px;text-align:center}.todo-add-form{display:flex;gap:8px;margin-bottom:16px}.todo-add-form select{min-width:120px}.todo-add-form input[type=text]{flex:1 1}.todo-add-form .error{margin-left:8px}.todo-table{background:#2c2f3b;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.todo-table td,.todo-table th{padding:14px 16px;text-align:left}.todo-table th{background-color:#7495b4;color:#fff;cursor:pointer}.todo-table th:hover{background-color:#5d7a94}.todo-table td{border-bottom:1px solid #444}.actions{display:flex;flex-direction:column;gap:8px}.btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;padding:8px 12px;transition:.2s}.btn-complete{background-color:#28a745;color:#fff}.btn:hover{opacity:.9}.error,.loader,.no-todos{color:#bbb;margin-top:40px;text-align:center}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.modal-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:700;padding:8px 16px}.modal-btn-secondary{background-color:#6c757d;color:#fff}.modal-btn-danger{background-color:#dc3545;color:#fff}@media (max-width:700px){.todo-table,.todo-table tbody,.todo-table thead,.todo-table tr{box-sizing:border-box;display:block;width:100%}.todo-table thead{display:none}.todo-table tr{background:#23252b;border-radius:8px;box-shadow:0 2px 8px #0000;margin-bottom:18px;padding:10px 0}.todo-table td,.todo-table tr{box-sizing:border-box;width:100%}.todo-table td{align-items:center;background:none;border:none;border-bottom:1px solid #444;display:flex;font-size:1rem;justify-content:space-between;padding:10px 16px;position:relative;word-break:break-word}.todo-table td:last-child{border-bottom:none}.todo-table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);flex:0 0 50%;font-size:.95em;font-weight:600;padding-right:10px;text-align:left;word-break:break-word}.actions{align-items:stretch;flex-direction:column;gap:8px}}.dashboard,.dashboard-card,.dashboard-row,.dashboard-timesheet-cards,.financial-overview-card,.timesheet-card-dashboard{box-sizing:border-box}.dashboard{margin:auto;max-width:1200px;min-width:0;padding:1.25rem}@media (min-width:768px){.dashboard{padding:2rem}}h1{color:var(--text-primary);font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin-bottom:2rem;text-align:center}.dashboard-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr}@media (min-width:768px){.dashboard-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}@media (min-width:1024px){.dashboard-grid{gap:2rem}}.dashboard-row{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:1fr;margin-bottom:1.5rem;width:100%}@media (min-width:768px){.dashboard-row{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}.dashboard-card{background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-md);color:var(--text-primary);display:flex;flex-direction:column;margin-bottom:1.5rem;padding:1.5rem;transition:all var(--transition-base)}.dashboard-card:hover{border-color:#6b8cae4d;box-shadow:var(--shadow-lg)}@media (max-width:768px){.dashboard-card{margin-bottom:1.25rem;padding:1.25rem}}.dashboard-card h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1.25rem;text-align:center}.dashboard-card ul{display:flex;flex-direction:column;gap:1rem;list-style:none;margin:0;padding:0;width:100%}.dashboard-card ul li{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;flex-direction:column;gap:.75rem;padding:1.25rem;transition:all var(--transition-base)}.dashboard-card ul li:hover{background:var(--background-card);border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-card ul li:active{transform:scale(.98)}.dashboard-card ul li .project-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding-bottom:.75rem}.dashboard-card ul li .project-name{color:var(--primary-color);font-size:1.125rem;font-weight:700}.dashboard-card ul li .project-details{display:flex;flex-direction:column;gap:.5rem}.dashboard-card ul li .project-detail-row{align-items:center;display:flex;font-size:.9375rem;justify-content:space-between}.dashboard-card ul li .project-detail-label{color:var(--text-secondary);font-weight:500}.dashboard-card ul li .project-detail-value{color:var(--text-primary);font-weight:600}@media (max-width:768px){.dashboard-card ul li{padding:1rem}}.dashboard-card a.btn-view{background:var(--primary-color)!important;border-radius:var(--radius-sm);color:var(--text-primary)!important;display:block;font-weight:700;letter-spacing:.05em;margin-top:1.25rem;padding:.875rem 1.5rem;text-align:center;text-decoration:none;text-transform:uppercase;transition:all var(--transition-base);width:100%}.dashboard-card a.btn-view:hover{background:var(--primary-hover)!important;box-shadow:var(--shadow-md);transform:translateY(-2px)}.dashboard-card a.btn-view:active{transform:translateY(0)}.dashboard-card table{background:var(--background-card);border-radius:var(--radius-sm);font-size:.9375rem;overflow:hidden;width:100%}@media (max-width:768px){.dashboard-card table{-webkit-overflow-scrolling:touch;display:block;font-size:.875rem;overflow-x:auto}}.dashboard-card td,.dashboard-card th{padding:.875rem .75rem;text-align:left}@media (max-width:768px){.dashboard-card td,.dashboard-card th{font-size:.8125rem;padding:.75rem .5rem}}.dashboard-card th{background:var(--background-elevated);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:600}.dashboard-card td{border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.dashboard-card tr{transition:background var(--transition-fast)}.dashboard-card tr:hover{background:var(--background-elevated)}.profit{border-radius:var(--radius-sm);display:inline-block;font-size:1.125rem;font-weight:700;padding:.25rem .75rem}.profit.positive{background:#10b98100;color:var(--success-color)}.profit.negative{background:#ef444400;color:var(--error-color)}.financial-overview-card{background:linear-gradient(135deg,var(--background-card) 0,var(--background-elevated) 100%);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:var(--text-primary);display:flex;flex-direction:column;grid-column:1/-1;margin-bottom:2rem;padding:2rem 1.5rem;transition:all var(--transition-base);width:100%}.financial-overview-card:hover{border-color:#6b8cae00;box-shadow:var(--shadow-xl)}@media (max-width:768px){.financial-overview-card{border-radius:var(--radius-md);padding:1.5rem 1rem}}.financial-overview-card h3{color:var(--text-primary);font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.01em;margin-bottom:2rem;text-align:center}.financial-overview-card .totals-overview{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}@media (max-width:768px){.financial-overview-card .totals-overview{gap:1rem;grid-template-columns:1fr}}.financial-overview-card .totals-row{align-items:flex-start;background:var(--background-card);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;flex-direction:column;padding:1.25rem;transition:all var(--transition-base)}.financial-overview-card .totals-row:hover{background:var(--background-elevated);border-color:#6b8cae4d}.financial-overview-card .totals-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.financial-overview-card .totals-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.01em}@media (max-width:768px){.financial-overview-card .totals-value{font-size:1.25rem}}.totals-piechart-wrapper{margin-top:1.5rem;min-height:600px;position:relative;width:100%}.totals-piechart-wrapper .recharts-wrapper{margin:0 auto}.totals-piechart-wrapper .recharts-legend-wrapper{border-top:2px solid var(--border-color);bottom:auto!important;margin-top:3rem!important;padding-top:2rem!important;position:relative!important}@media (max-width:768px){.totals-piechart-wrapper{min-height:550px}.totals-piechart-wrapper .recharts-legend-wrapper{margin-top:2rem!important;padding-top:1.5rem!important}}.chart-container{align-items:center;display:flex;height:300px;justify-content:center;margin-top:1rem;width:100%}@media (max-width:768px){.chart-container{height:250px}}.dashboard-timesheet-cards{display:flex;flex-direction:column;gap:1.25rem;width:100%}.timesheet-card-dashboard{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;padding:1.25rem;transition:all var(--transition-base)}.timesheet-card-dashboard:hover{background:var(--background-card);border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.timesheet-card-dashboard:active{transform:scale(.98)}.timesheet-card-header{border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem}.timesheet-project{color:var(--primary-color);font-size:1.125rem;font-weight:700}.timesheet-week{color:var(--text-secondary);font-size:.9375rem;font-weight:500}.timesheet-card-body{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between}.timesheet-status{display:inline-block}.timesheet-hours{background:var(--background-card);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9375rem;font-weight:600;padding:.375rem .75rem}.status-badge-dashboard{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.375rem .75rem;text-transform:uppercase}.status-badge-dashboard.status-approved{background:#10b98100;color:var(--success-color)}.status-badge-dashboard.status-approved_by_voorman,.status-badge-dashboard.status-pending{background:#f59e0b00;color:var(--warning-color)}.status-badge-dashboard.status-rejected{background:#ef444400;color:var(--error-color)}.invalid-users-card{background:var(--background-card);padding:0}.invalid-users-list{display:flex;flex-direction:column;gap:1.25rem;list-style:none;margin:0;padding:0}.invalid-user-card{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;padding:1.5rem;position:relative;transition:all var(--transition-base)}.invalid-user-card:before{background:var(--warning-color);bottom:0;content:"";left:0;position:absolute;top:0;transition:all var(--transition-base);width:4px}.invalid-user-card.has-expired:before{background:var(--error-color)}.invalid-user-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateX(4px)}.invalid-user-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem}.invalid-user-avatar{align-items:center;background:var(--background-card);border:2px solid var(--primary-color);border-radius:50%;color:var(--primary-color);display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:48px;justify-content:center;width:48px}.invalid-user-info{flex:1 1;min-width:0}.invalid-user-name{color:var(--text-primary);font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.invalid-user-email{color:var(--text-secondary);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invalid-user-docs{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}.doc-status-section{background:var(--background-card);border-left:3px solid #0000;border-radius:var(--radius-sm);padding:1rem}.doc-status-section.has-missing{background:#f59e0b00;border-left-color:var(--warning-color)}.doc-status-section.has-expired{background:#ef444400;border-left-color:var(--error-color)}.doc-status-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.75rem}.doc-status-icon{align-items:center;border-radius:50%;display:flex;font-size:.875rem;font-weight:700;height:24px;justify-content:center;width:24px}.doc-status-icon.warning{background:#f59e0b00;color:var(--warning-color)}.doc-status-icon.error{background:#ef444400;color:var(--error-color)}.doc-status-label{font-size:.875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.doc-status-label.missing{color:var(--warning-color)}.doc-status-label.expired{color:var(--error-color)}.doc-status-list{display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0;padding:0}.doc-status-item{align-items:center;background:var(--background-elevated);border-radius:var(--radius-sm);color:var(--text-primary);display:flex;font-size:.9375rem;gap:.5rem;padding:.5rem .75rem}.doc-status-item:before{color:inherit;content:"•";font-weight:700}.invalid-user-action{width:100%}@media (max-width:768px){.invalid-user-card{padding:1.25rem}.invalid-user-header{gap:.75rem}.invalid-user-avatar{font-size:1rem;height:40px;width:40px}}.user-list{margin:auto;max-width:1200px;min-width:0;padding:1.25rem;width:100%}@media (min-width:768px){.user-list{padding:2rem}}.invite-section{margin-bottom:1.5rem}.invite-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.invite-form input,.invite-form select{margin:0}.invite-form button{margin-top:.5rem}.delete{background-color:var(--error-color)!important}.userlist-toolbar{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem}.userlist-search{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);color:var(--text-primary);flex:1 1 250px;font-size:1rem;margin-bottom:0;max-width:350px;padding:.875rem 1rem;transition:all var(--transition-base)}.userlist-search:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a}.invite-section>button{min-height:48px}.user-list-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:1.5rem}@media (max-width:768px){.user-list-grid{gap:1.25rem;grid-template-columns:1fr}}.user-card{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;padding:1.5rem;position:relative;transition:all var(--transition-base)}.user-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (max-width:768px){.user-card{padding:1.25rem}}.user-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;padding-bottom:1rem}.user-card-avatar{align-items:center;background:var(--background-card);border:2px solid var(--primary-color);border-radius:50%;color:var(--primary-color);display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:56px;justify-content:center;overflow:hidden;position:relative;width:56px}.user-card-avatar img{height:100%;object-fit:cover;width:100%}@media (max-width:768px){.user-card-avatar{font-size:1.25rem;height:48px;width:48px}}.user-card-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.user-card-name{color:var(--text-primary);font-size:1.125rem;font-weight:700}.user-card-email,.user-card-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-card-email{color:var(--text-secondary);font-size:.875rem}.user-card-details{display:flex;flex-direction:column;font-size:.9375rem;gap:.75rem}.user-card-details>div{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.user-card-details b{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;min-width:90px;text-transform:uppercase}.user-card-details span{align-items:center;color:var(--text-primary);display:flex;font-weight:600;gap:.5rem;text-align:right}.status-ball{border-radius:50%;display:inline-block;flex-shrink:0;height:10px;width:10px}.status-ball.active{background-color:var(--success-color);box-shadow:0 0 8px #10b98100}.status-ball.inactive{background-color:var(--error-color);box-shadow:0 0 8px #ef444400}.status-ball.valid{background-color:var(--success-color);box-shadow:0 0 8px #10b98100}.status-ball.expired{background-color:var(--error-color);box-shadow:0 0 8px #ef444400}.status-ball.missing{background-color:var(--warning-color);box-shadow:0 0 8px #f59e0b00}.user-card-actions{border-top:1px solid var(--border-color);display:flex;gap:.75rem;margin-top:auto;padding-top:1rem}@media (max-width:768px){.user-card-actions{flex-direction:column;gap:.5rem}}@media (max-width:700px){table,table tbody,table thead,table tr{box-sizing:border-box;display:block;width:100%}table thead{display:none}table tr{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.25rem;padding:1rem}table td{align-items:center;background:none;border:none;border-bottom:1px solid var(--border-color);display:flex;font-size:1rem;justify-content:space-between;padding:.75rem 0;width:100%}table td:last-child{border-bottom:none}table td:before{color:var(--text-secondary);content:attr(data-label);flex:0 0 50%;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding-right:1rem;text-align:left;text-transform:uppercase}table td[data-label=Acties]{align-items:stretch;flex-direction:column;gap:.5rem}table td[data-label=Acties] button{width:100%}.actions{align-items:stretch;flex-direction:column;gap:.5rem}}.user-detail,.user-detail--card{margin:auto;max-width:1200px;min-width:0;padding:20px}.user-detail--card{color:#fff}.user-detail h2{font-size:1.75rem;margin-bottom:1rem}.user-detail__info{flex:1 1}.user-detail__info--card{align-items:flex-start;display:flex;flex:2 1;flex-direction:column;gap:.5rem}.user-detail__info--card h3{color:#fff;font-size:1.5rem;font-weight:700;margin-bottom:.2rem}.user-detail__company{color:#bfc4d1;font-size:1.1rem;margin-bottom:.2rem}.user-detail__role{color:#7495b4;font-size:1rem;font-weight:700}.user-detail__details{flex:3 1}.user-detail__details--card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:.7rem;box-shadow:0 1px 6px #0000;margin-bottom:1.5rem;padding:1.2rem 1rem}.user-detail__container{align-content:center;align-items:center;display:flex;flex-direction:row;gap:5rem;width:100%}@media (max-width:768px){.user-detail__container{align-items:flex-start;flex-direction:column;gap:2rem}}.user-detail__container--card{align-items:center;background:none;display:flex;flex-direction:row;gap:2.5rem;margin-bottom:2rem}@media (max-width:768px){.user-detail__container--card{align-items:center;flex-direction:column;gap:1.5rem}}.user-detail__image-wrapper{align-items:center;cursor:pointer;display:flex;justify-content:center;min-width:120px;outline:none;position:relative}.user-detail__image-placeholder{align-items:center;background:#374959;border:3px solid #7495b4;border-radius:100%;color:#bfc4d1;display:flex;flex:1 1;font-size:1.1rem;height:120px;justify-content:center;width:120px}.user-detail__image{height:120px;transition:box-shadow .2s,transform .2s;width:120px}.user-detail__image,.user-detail__image--clickable{border:3px solid #7495b4;border-radius:50%;cursor:pointer;object-fit:cover}.user-detail__image--clickable{max-height:360px;max-width:360px}.user-detail__image:hover{box-shadow:0 4px 24px #7495b4aa;transform:scale(1.04)}.user-detail__image-modal{align-items:center;animation:fadeIn .2s;background:#1e202800;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.user-detail__image-modal-img{background:#23252b;border:4px solid #7495b4;border-radius:18px;box-shadow:0 8px 32px #23252bcc;max-height:92vh;max-width:92vw}.user-detail__image-modal-close{background:none;border:none;color:#fff;cursor:pointer;font-size:2.5rem;position:absolute;right:2vw;text-shadow:0 2px 8px #23252b;top:2vw;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.user-detail__row{border-bottom:1px solid #374959;display:flex;font-size:1.08em;justify-content:space-between;padding:1rem 0}.user-detail__row label{color:#bfc4d1;flex:1 1;font-weight:700}.user-detail__row input,.user-detail__row span{flex:2 1}.user-detail__info input,.user-detail__row input{background:#2c2f3b;border:1px solid #444;border-radius:6px;box-sizing:border-box;color:#e0e0e0;font-size:1rem;padding:12px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.user-detail__actions{display:flex;gap:1rem;margin:2rem 0}.user-detail__actions--card{display:flex;gap:1rem;justify-content:flex-end;margin-bottom:1.5rem}.user-detail__documents{border-radius:6px;display:flex;flex-direction:column;gap:10px;margin-top:2rem;padding:15px}.user-detail__documents,.user-detail__documents--card{background:linear-gradient(135deg,#23252b 80%,#2b3a49)}.user-detail__documents--card{border-radius:.7rem;box-shadow:0 1px 6px #0000;margin-bottom:1.5rem;padding:1.2rem 1rem}.user-detail__documents--card h2{font-size:1.3rem;font-weight:700;margin-bottom:1rem;text-align:center}.documents-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:1.5rem}@media (max-width:768px){.documents-grid{gap:1.25rem;grid-template-columns:1fr}}.no-documents-message{border-radius:var(--radius-sm);color:var(--text-secondary);font-size:1rem;margin-top:1.5rem;padding:2rem;text-align:center}.document-card,.no-documents-message{background:var(--background-elevated)}.document-card{word-wrap:break-word;border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;max-width:100%;min-width:0;overflow:hidden;overflow-wrap:break-word;padding:1.25rem;transition:all var(--transition-base)}.document-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.document-card.expired{background:#ef444400}.document-card.expired,.document-card.expired:hover{border-color:var(--error-color)}.document-card-header{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;max-width:100%;min-width:0;padding-bottom:1rem}.document-info{flex:1 1;max-width:100%;min-width:0;overflow:hidden}.document-info h4,.document-info p,.document-name{overflow:hidden;text-overflow:ellipsis}.document-name{color:var(--text-primary);font-size:1rem;font-weight:700;margin:0 0 .5rem;max-width:100%;white-space:nowrap}.document-type{background:#6b8cae00;border-radius:12px;color:var(--primary-color);display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.document-card-body{display:flex;flex-direction:column;gap:.75rem}.document-detail{align-items:center;display:flex;font-size:.9375rem;justify-content:space-between}.document-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.document-value{color:var(--text-primary);font-weight:600}.document-value.expired-date{color:var(--error-color);font-weight:700}.document-card-actions{border-top:1px solid var(--border-color);display:flex;gap:.75rem;margin-top:auto;padding-top:1rem}@media (max-width:768px){.document-card-actions{flex-direction:column}}.upload-form{background:var(--background-elevated);border:2px solid var(--border-color);border-radius:var(--radius-md);flex-direction:column;gap:1rem;margin-top:1.5rem;padding:1.5rem}.upload-form .bold-label{color:var(--text-secondary);font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.upload-form input[type=file]{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;padding:.75rem}.upload-form input[type=date],.upload-form select{background:var(--background-card);border:2px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;padding:.875rem 1rem}.upload-form select{cursor:pointer}.upload-form input:focus,.upload-form select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6b8cae1a;outline:none}.toggle-upload-form-btn{border:none;border-radius:6px;color:#fff;font-size:1em;font-weight:700;padding:.7em 1.2em;transition:background .2s}.toggle-upload-form-btn.btn-cancel{background:#a71d2a}.toggle-upload-form-btn:hover{background:#374959}.documents-table-wrapper{overflow-x:auto;width:100%}.documents-table-users{border-collapse:collapse;margin-top:1rem;width:100%}.documents-table-users thead th{background:#2c2f3b;border-bottom:2px solid #444;color:#fff;padding:12px;text-align:left}.documents-table-users tbody td{border-bottom:1px solid #444;padding:12px}.documents-table-users tbody td[data-label=Acties]{display:flex;gap:.5rem}.documents-table-users td,.documents-table-users th{border-bottom:1px solid #374959;padding:.75rem .5rem;text-align:left}.documents-table-users th{background:#374959;color:#fff;font-size:1.05em;font-weight:600}.documents-table-users tr:hover{background:#2c2f3b}.btn-viewfile,.documents-table-users td a{background:#7495b4;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;margin-bottom:.5rem;padding:.4rem .75rem;text-align:center;text-decoration:none;transition:background .2s}.btn-viewfile:hover,.documents-table-users td a:hover{background:#374959}.btn-delete{background:#a71d2a;font-weight:600}.margin-bottom{margin-bottom:1rem}.btn-delete:hover{background:#821d24}.valid{color:#1d5c3b;font-weight:700}.invalid{color:#a71d2a;font-weight:700}@media (max-width:700px){.user-detail--card{border-radius:10px;padding:1rem .5rem 1.5rem}.user-detail__container--card{align-items:stretch;flex-direction:column;gap:1.2rem}.user-detail__details--card,.user-detail__documents--card{border-radius:8px;padding:1rem}.user-detail__actions--card{align-items:stretch;flex-direction:column;gap:.7rem}.documents-table-users td,.documents-table-users th{font-size:.97em;padding:.5rem .2rem}.upload-form{flex-direction:column;gap:.7rem;padding:1rem}.user-detail__image,.user-detail__image-placeholder{flex:0 0 auto;font-size:.95rem;height:120px;width:120px}.user-detail__image-modal-img{max-height:70vh;max-width:98vw}.user-detail__image-modal-close{font-size:2rem;right:1vw;top:1vw}}.customer-list{margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.invite-section{margin-bottom:20px}.invite-form{margin-top:10px}.invite-form input,.invite-form select{margin:10px 10px 10px 0}.delete{background-color:red!important}table td,table th{text-align:center}@media (max-width:700px){table,table tbody,table thead,table tr{box-sizing:border-box;display:block;width:100%}table thead{display:none}table tr{background:#23252b;border-radius:8px;box-shadow:0 2px 8px #0000;margin-bottom:18px;padding:10px 0}table td,table tr{box-sizing:border-box;width:100%}table td{align-items:center;background:none;border:none;border-bottom:1px solid #444;display:flex;font-size:1rem;justify-content:space-between;padding:10px 16px;position:relative;word-break:break-word}table td:last-child{border-bottom:none}table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);flex:0 0 50%;font-size:.95em;font-weight:600;padding-right:10px;text-align:left;word-break:break-word}table td[data-label=Acties]{align-items:stretch;flex-direction:column;gap:8px}table td[data-label=Acties] button{margin-bottom:6px;width:100%}table td[data-label=Acties] button:last-child{margin-bottom:0}.actions{align-items:stretch;flex-direction:column;gap:8px}}.customer-info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.customer-info-grid.enhanced-mobile-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-top:1.5rem}.customer-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #0000;display:flex;flex:1 1 220px;flex-direction:column;min-width:220px;outline:none;padding:1.1rem 1.2rem;transition:box-shadow .2s,border .2s}.customer-card:hover{box-shadow:0 4px 16px #0000}.customer-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.customer-card-header h3{color:#7495b4;font-size:1.2rem;font-weight:600;margin:0}.customer-card-body{flex:1 1;margin-bottom:1rem}.customer-meta p{color:#e0e0e0;font-size:1rem;margin:.2em 0}.customer-card p{color:#e0e0e0;font-size:.9em;margin:5px 0}.placeholder{color:#bbb;font-style:italic}.customer-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:15px}.btn-view{background:#7495b4}.btn-add-customer,.btn-view{border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;padding:8px 16px;transition:background .2s}.btn-add-customer{background:#1d5c3b;margin-bottom:20px}.btn-add-customer:hover{background:#28a745}.btn-view:hover{background:#374959}.btn-delete{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;padding:8px 16px;transition:background .2s}.btn-delete:hover{background:#a71d2a}@media (max-width:768px){.customer-info-grid{grid-template-columns:1fr}.customer-info-grid.enhanced-mobile-grid{gap:.7rem;grid-template-columns:1fr;margin-top:1rem}.customer-card{font-size:.98em;padding:.8rem .5rem}.customer-card-header h3{font-size:1.08em}.customer-card p,.customer-meta p{font-size:.97em}.customer-actions{align-items:stretch;flex-direction:column;gap:8px;margin-top:8px;width:100%}.customer-actions button{margin-bottom:6px;width:100%}.customer-actions button:last-child{margin-bottom:0}}.customer-detail{margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.customer-detail h2{font-size:1.75rem;margin-bottom:1rem}.customer-detail__info{flex:1 1}.customer-detail__details{flex:3 1}.customer-detail__container{align-content:center;align-items:center;display:flex;flex-direction:row;gap:5rem;width:100%}.customer-detail__image-placeholder{align-items:center;background:#f1f1f1;border-radius:100%;color:#aaa;display:flex;flex:1 1;font-size:.9rem;height:120px;justify-content:center;width:120px}.customer-detail__row{border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:1rem 0}.customer-detail__row label{flex:1 1;font-weight:700}.customer-detail__row input,.customer-detail__row span{flex:2 1}.customer-detail__info input,.customer-detail__row input{background:#2c2f3b;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;color:#fff;font-size:1rem;padding:12px;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.customer-detail__actions{display:flex;gap:1rem;margin:2rem 0}.customer-detail__documents{background:#23252b;border-radius:6px;display:flex;flex-direction:column;gap:10px;margin-top:2rem;padding:15px}.upload-form{display:flex;flex-wrap:wrap;gap:1.5rem}.toggle-upload-form-btn,.upload-form{margin-bottom:1rem}.documents-table{border-collapse:collapse;margin-top:1rem;max-width:1000px}.documents-table td,.documents-table th{border-bottom:1px solid #eee;padding:.75rem;text-align:left}.documents-table td a{background-color:#7495b4;border-radius:6px;color:#fff;display:block;margin-bottom:.5rem;padding:.5rem;text-align:center;text-decoration:none}.documents-table td a:hover{background-color:#374959}.btn-viewfile{background:#17a2b8;border:none;border-radius:.5rem;color:#fff;cursor:pointer;padding:.4rem .75rem;width:100%!important}.active{color:#4eb722;font-weight:700}.inactive{color:#dc3545;font-weight:700}@media (max-width:700px){.customer-detail__container{align-items:stretch;flex-direction:column;gap:2rem}.customer-detail__row{align-items:flex-start;flex-direction:column;gap:.25rem;padding:.75rem 0}.customer-detail__row label{flex:initial;font-size:1rem;margin-bottom:.25rem}.customer-detail__row input,.customer-detail__row span{flex:initial;font-size:1rem;width:100%}.customer-detail__documents{font-size:.98rem;padding:8px}.documents-table,.documents-table tbody,.documents-table thead,.documents-table tr{box-sizing:border-box;display:block;width:100%}.documents-table thead{display:none}.documents-table tr{background:#23252b;border-radius:8px;box-shadow:0 2px 8px #0000;box-sizing:border-box;margin-bottom:18px;padding:10px 0;width:100%}.documents-table td{align-items:center;background:none;border:none;border-bottom:1px solid #eee;box-sizing:border-box;display:flex;font-size:1rem;justify-content:space-between;padding:10px 16px;position:relative;width:100%;word-break:break-word}.documents-table td:last-child{border-bottom:none}.documents-table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);flex:0 0 50%;font-size:.95em;font-weight:600;padding-right:10px;text-align:left;word-break:break-word}}
/*# sourceMappingURL=main.40a37d92.css.map*/