body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;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}body{background-color:#1b1d23;color:#e0e0e0;font-family:Arial,sans-serif;margin:0;padding:0}.container{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:12px;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;color:#fff;font-family:Segoe UI,sans-serif;margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}header{background:#7495b4;color:#fff;font-size:1.8em;font-weight:700;padding:15px;text-align:center}footer{color:#aaa;font-size:.9em;padding:15px 0;position:fixed}form{display:flex;flex-direction:column;gap:15px}a.btn-view,button,input[type=date],input[type=email],input[type=number],input[type=password],input[type=text]{background-color:#2c2f3b;border:1px solid #444;border-radius:6px;color:#e0e0e0;font-size:1em;padding:12px;transition:all .3s ease-in-out}input:focus{border-color:#7495b4;box-shadow:0 0 8px #007bff66;outline:none}button{background-color:#7495b4;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;padding:10px 15px;transition:background-color .3s ease}button:hover{background-color:#374959}button:disabled{background-color:#555;cursor:not-allowed}h1,h2,h3{color:#fff;font-weight:700}.loader,h1,h2,h3{text-align:center}.loader{color:#7495b4;font-size:1.2em}table{background:#2c2f3b;border-collapse:collapse;border-radius:8px;color:#e0e0e0;margin-top:20px;overflow:hidden;table-layout:auto;width:100%}td,th{border-bottom:1px solid #444;padding:12px;text-align:left}th{background-color:#7495b4;color:#fff;font-size:1em}tr:nth-child(2n){background-color:#23252b}.notification-badge{background-color:red;margin-left:8px;vertical-align:middle}.navigation{background:#23252b;box-shadow:0 2px 4px #0003;padding:15px 0}.navigation .container{align-items:center;display:flex;justify-content:space-between}.navigation ul{display:flex;gap:20px;list-style:none;margin:0;padding:0}.navigation ul li{display:inline-block}.navigation ul li a{color:#e0e0e0;font-size:1em;padding:10px 15px;text-decoration:none;transition:background-color .3s}.navigation ul li a:hover{background-color:#7495b4;border-radius:4px;color:#fff}.profile-pic{border:2px solid #7495b4;border-radius:50%;cursor:pointer;height:40px;object-fit:cover;width:40px}.todo-list{padding:15px}.todo-item{background:#2c2f3b;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:5px;padding:10px}.todo-item span{color:#fff}.btn-complete{background-color:#1e7e34;border-radius:6px;cursor:pointer;padding:8px 12px;transition:background-color .3s}.btn-complete:hover{background-color:#1d5c3b}.btn-delete,.btn-logout{background:#a71d2a;color:#fff;width:100%}.btn-cancel:hover,.btn-delete:hover{background:#821d24}.btn-toggle{background:#ffc107;color:#212529;margin-top:10px;width:100%}.btn-pending,.btn-toggle:hover{background:#ffc107ab}.btn-view,a.btn-view{background:#7495b4;color:#fff;width:100%}.btn-view:hover,a.btn-view:hover{background:#374959}.btn-timesheets{background:#17a2b8;color:#fff;width:100%}.btn-timesheets:hover{background:#117a8b}.btn-add{background:#1d5c3b;display:block;font-size:1rem;font-weight:700;margin:0 0 20px;padding:12px 20px;text-align:center;text-decoration:none}.btn-add:hover,.btn-save:hover{background:#1e7e34}.no-margin{margin:0}.btn-edit{background:#1f88e5;color:#fff}.btn-save{background:#1d5c3b;color:#fff}.btn-cancel{background:#a71d2a;padding:12px 20px}.btn-view{text-align:center;text-decoration:none}.btn-approve{background:#1d5c3b;color:#fff}.btn-reject{background:#ffc107;color:#212529}@media (max-width:768px){.container{padding:15px}.navigation ul{align-items:center;flex-direction:column;gap:10px}.dashboard-grid{grid-template-columns:1fr}}.badge{display:flex;flex-direction:column;font-size:.8rem;padding:4px 10px;text-align:center;text-transform:capitalize}.badge-unread{background-color:#a71d2a}.badge-read{background-color:#1e7e34}.badge-active{background-color:#198754;color:#fff}.badge-inactive{background-color:#fde2e2;color:#dc3545}.badge-pending,.status-pending{background-color:#b68b00}.status-approved_by_voorman{background-color:#7495b4}.badge-completed,.status-approved{background-color:#1d5c3b}.status-rejected{background-color:#821d24}.input-error{color:#821d24}.status-ball{align-self:center;border-radius:50%;display:inline-block;height:12px;margin-right:8px;vertical-align:middle;width:12px}.missing-row .missing-label,.missing-row .missing-value{color:#b68b00}.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)}}.navigation{background-color:#23252b;box-shadow:0 2px 4px #0000;padding:10px 20px}.nav-container{align-items:center;display:flex;justify-content:space-between;margin:auto;max-width:1200px}.nav-logo img{width:120px}.nav-links{align-items:center;display:flex;gap:20px;list-style:none;margin:0;padding:0}.nav-links li{cursor:pointer;position:relative}.nav-links li a{color:#fff;font-size:16px;padding:10px;text-decoration:none;transition:.3s ease}.nav-links li a.active{background:#847c83;border-radius:4px;color:#fff;font-weight:700}.nav-links li a:hover{color:#7495b4}.nav-profile .no-hover:hover{background:none;color:inherit;text-decoration:none}.notification-badge{background-color:#a71d2a;border-radius:50%;color:#fff;font-size:12px;font-weight:700;margin-left:5px;padding:4px 8px}.nav-profile img{border:2px solid #fff;border-radius:50%;cursor:pointer;height:40px;width:40px}.nav-profile:hover{background:#0000}.btn-logout{margin:0}.btn-logout:hover{background-color:#d43f3f}.hamburger{align-items:center;background:#7495b4;border:none;cursor:pointer;display:none;flex-direction:column;height:40px;justify-content:center;width:40px;z-index:1002}.hamburger .bar{background-color:#fff;border:2px solid #fff;border-radius:2px;box-shadow:0 1px 3px #0000;display:block;height:4.5px;margin:2px 0;transition:.3s;width:28px}.hamburger.open .bar:first-child{transform:translateY(9px) rotate(45deg)}.hamburger.open .bar:nth-child(2){opacity:0}.hamburger.open .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width:768px){.hamburger{display:flex}.nav-links{align-items:flex-start;background:#23252b;border-radius:0 0 0 8px;box-shadow:0 2px 8px #0000;flex-direction:column;gap:0;height:auto;opacity:0;padding:20px 0;pointer-events:none;position:absolute;right:-1.5rem;top:60px;transform:translateX(100%);transition:transform .3s ease;width:220px;z-index:1001}.nav-links.open{opacity:1;pointer-events:auto;transform:translateX(0)}.nav-links li{margin:0;padding:0;width:100%}.nav-links li a,.nav-links li button{background:none;border:none;border-radius:0;display:block;font-size:16px;padding:14px 24px;width:100%}.nav-profile img{margin-left:24px}.nav-container{position:relative}}footer{background:#23252b;bottom:0;color:#fff;font-size:1rem;left:0;letter-spacing:.02em;margin-top:1rem;padding:18px 0 12px;text-align:center;width:100%;z-index:10}@media (max-width:600px){footer{background:#23252b;border-top:1px solid #333;bottom:0;box-sizing:border-box;font-size:.98rem;left:0;margin:0;max-width:100vw;min-width:100vw;padding:14px 0 10px;position:fixed;width:100vw;z-index:100}}.login-container{align-items:center;display:flex;justify-content:center;margin-top:2rem}.login-box{background:#23252b;border-radius:12px;box-shadow:0 4px 12px #0000;max-width:400px;padding:40px;text-align:center;width:100%}.login-logo,h2{margin-bottom:20px}h2{color:#fff;font-size:22px}.login-form input{background-color:#2c2f36;margin-bottom:15px}.btn-login,.login-form input{border:none;border-radius:8px;color:#fff;font-size:16px;padding:14px;width:100%}.btn-login{background-color:#7495b4;cursor:pointer;transition:background .3s ease}.btn-login:hover{background-color:#374959}.error-message{color:#ff4d4d;font-size:14px;margin-bottom:15px}.register{margin-top:15px}.register a{color:#7495b4;font-size:1rem;text-decoration:none}.register a:hover{text-decoration:underline}.forgot-password{font-size:14px;margin-bottom:15px;margin-top:-10px;text-align:right}.forgot-password a{color:#7495b4;font-size:14px;text-decoration:none}.forgot-password a:hover{text-decoration:underline}@media (max-width:480px){.login-box{padding:30px;width:auto}}.register-form{background:#23252b;border-radius:12px;box-shadow:0 4px 12px #0000;max-width:800px;padding:40px;text-align:center;width:100%}.register-form input{margin-bottom:1rem}.register-form__wrapper{flex-direction:row;width:100%}.register-form__personal_info{flex:1 1;margin-right:2rem}.register-form__company_info{flex:1 1}.register-form__company_info>div,.register-form__personal_info>div{margin-bottom:1rem}.login-logo{margin:0 auto;width:120px}.enhanced-register-form{background:#23252b;border-radius:16px;box-shadow:0 4px 24px #2c3e5000;margin:0 auto;max-width:800px;padding:2.5rem 2rem;width:100%}.register-form__title{color:#7495b4;font-size:2rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.register-form__wrapper{display:flex;gap:2rem;margin-bottom:1.5rem}.register-form__card{background:#2c3e5000;border-radius:12px;box-shadow:0 2px 8px #0000;display:flex;flex:1 1;flex-direction:column;gap:1rem;min-width:0;padding:1.5rem 1rem}.register-form__field{display:flex;flex-direction:column;gap:.3rem}.register-form__field label{color:#bfc4d1;font-size:1rem;font-weight:600;margin-bottom:.1rem}.register-form__field input{background:#2c2f3b;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;color:#fff;font-size:1rem;outline:none;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.register-form__field input:focus{border-color:#7495b4;box-shadow:0 0 0 2px #7495b433}.error-message{color:#e57373;font-size:.98rem;margin:.2rem 0 0}.enhanced-register-checkbox{flex-direction:column;gap:.5rem;margin:24px 0 16px}.enhanced-register-checkbox,.enhanced-register-checkbox label{align-items:flex-start;color:#fff;display:flex;font-size:1rem;font-weight:400}.enhanced-register-checkbox label{gap:.7rem}.enhanced-register-checkbox input[type=checkbox]{accent-color:#1e88e5;height:20px;margin-top:2px;width:20px}.enhanced-register-checkbox a{color:#1e88e5;font-weight:500;text-decoration:underline}.register-form__actions{display:flex;justify-content:center;margin-top:1.2rem}.btn-add{background:#7495b4;border:none;border-radius:6px;cursor:pointer;font-size:1.1rem;min-width:180px;padding:.8em 1.5em;transition:background .2s,color .2s}@media (max-width:900px){.enhanced-register-form{padding:1.2rem .5rem}.register-form__wrapper{flex-direction:column;gap:1.2rem}.register-form__card{gap:1rem;margin:2rem;padding:1.2rem .7rem}.register-form__card input{width:100%}}@media (max-width:600px){.enhanced-register-form{padding:.7rem .2rem}.register-form__title{font-size:1.3rem}.btn-add{font-size:1rem;min-width:120px;padding:.7em 1em}}.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:#2c2f3b;border-radius:12px;box-shadow:0 10px 25px #0000;margin:auto;max-height:90vh;max-width:500px;padding:20px;width:100%}.modal-header{align-items:center;color:#fff;display:flex;justify-content:space-between;margin-bottom:15px}.modal-header h3{font-size:1.25rem;margin:0}.modal-close{background:none;border:none;color:#fff;cursor:pointer;font-size:1.5rem}.modal-body{color:#ddd;font-size:1rem;margin-bottom:20px}.modal-btn{font-size:.95rem;padding:10px 16px;transition:all .2s ease-in-out}.modal-btn-primary{background-color:#7495b4;color:#fff}.modal-btn-primary:hover{background-color:#374959}.modal-btn-secondary{background-color:#444}.modal-btn-secondary:hover{background-color:#555}@media (max-width:600px){.modal-overlay{align-items:flex-start;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-sizing:border-box;height:100vh;justify-content:center;padding:8px;width:100vw}.modal-content{border-radius:8px;font-size:1rem;max-height:95vh;max-width:98vw;min-width:0;padding:14px 8px;width:100vw}.modal-header h3{font-size:1.1rem}.modal-body{font-size:1rem;margin-bottom:16px}.modal-footer{flex-direction:column;gap:8px}.modal-btn{font-size:1rem;padding:12px 0;width:100%}.modal-close{font-size:2rem;padding:0 8px}}.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;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 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:1.2rem;justify-content:flex-end;margin-top:1.5rem}.wrapper{display:flex;flex-direction:row;gap:2rem;width:100%}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}@media (max-width:900px){.profile-form__card{flex-direction:column;gap:1.2rem;padding:1.2rem .5rem}.profile-form__section{background:none!important;flex-direction:column;gap:1.2rem}.profile-form__fields.wrapper{background:none;flex-direction:column;gap:1.2rem}}@media (max-width:600px){.profile-image-modal__img{max-height:60vh;max-width:98vw}.profile-form__card{gap:.7rem;padding:.7rem .2rem}}.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}}.project-detail,.projects-container{color:#fff;font-family:Segoe UI,sans-serif;margin:auto;max-width:1200px;min-width:0;padding:20px}.bottom-margin{margin-bottom:2rem}.toggle-btn{background:#374959!important}.toggle-btn:first-child{margin-right:1.5rem}.active{background:#7495b4!important;border-radius:4px;color:#fff!important}.project-info-grid{grid-gap:2rem;gap:2rem;margin-bottom:2rem}.project-info-grid.full-width{grid-template-columns:1fr}.project-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}.project-form{gap:2rem}.project-form label{font-weight:700;margin-bottom:1.5rem}.add-employee-form{border-radius:6px;display:flex;flex-direction:column;gap:1rem}.project-detail__documents_container,.project-detail__employees_container{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:12px;display:flex;flex-direction:column;gap:10px;margin-top:2rem;outline:none;padding:15px;transition:box-shadow .2s,border .2s}.project-detail__documents{padding:15px}.project-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #0000;cursor:pointer;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}.project-card:hover{box-shadow:0 4px 16px #0000}.project-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.project-card-header h3{font-size:1.2rem;font-weight:600;margin:0}.archive-badge{background:#e0e0e0;border-radius:12px;color:#666;font-size:.85rem;font-weight:500;margin-left:.5em;padding:.2em .7em}.project-card-body{flex:1 1;margin-bottom:1rem}.project-meta p{font-size:1rem;margin:.2em 0}.project-actions{flex-wrap:wrap;gap:.5rem}.project-card.archived{opacity:.7}.project-card h3{color:#7495b4;margin-bottom:10px}.project-card p{color:#e0e0e0;font-size:.9em;margin:5px 0}.profit{margin-top:10px;text-align:center}.project-actions{display:flex;flex-direction:row;gap:10px;margin-top:15px}.project-actions .btn-delete{margin:0}.no-projects{color:#bbb;font-size:1.2em;margin-top:20px;text-align:center}.total-profit{font-size:1.1rem;margin-top:2rem;text-align:right}.total-profit span.positive{color:#28a745}.total-profit span.negative{color:#dc3545}.project-detail h2,.project-detail h3{color:#fff;margin-bottom:15px;text-align:center}.project-info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.info-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:12px;box-shadow:0 2px 4px #0003;cursor:pointer;min-height:250px;outline:none;padding:1rem;transition:box-shadow .2s,border .2s}.info-card input,.info-card label,.info-card select{box-sizing:border-box;display:block;margin-bottom:10px;width:100%}@media (max-width:768px){.project-info-grid{grid-template-columns:1fr}.toggle-btn:first-child{margin-bottom:1.5rem}}.info-card h3{color:#7495b4}.info-card p{color:#e0e0e0}.project-detail__totals_container{margin-top:1.5rem!important}.employee-container{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:6px;padding:15px}.employee-table{border-collapse:collapse;display:table;margin-top:10px;width:100%}.employee-table th{background-color:#7495b4;color:#fff;padding:10px;text-align:center}.employee-table td{color:#ddd;padding:10px;text-align:center}.employee-actions{gap:1rem}.employee-actions,.employee-actions-inline{align-items:center;display:flex;flex-direction:row;justify-content:space-evenly}.employee-actions-inline{gap:1.5rem;width:100%}.btn-primary{background:#7495b4;padding:10px 0}.btn-danger,.btn-primary{border-radius:6px;color:#fff;font-weight:700;width:100%}.btn-danger{background:#dc3545;margin:5px 0;padding:10px}.btn-primary:hover{background:#374959}.btn-danger:hover{background:#a71d2a}select{background-color:#2c2f3b;border:1px solid #7495b4;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;padding:10px;width:100%}select.short-select{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:80px}input[type=date],input[type=email],input[type=number],input[type=password],input[type=text]{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%}input[type=number]{max-width:6rem}input[type=text]{max-width:95%}input[type=number].full-width{max-width:100%!important}.document-table{border-collapse:collapse;margin-top:10px;width:100%}.document-table th{background-color:#7495b4;color:#fff}.document-table td{color:#ddd}.upload-form{border-radius:6px;flex-direction:column;gap:10px;padding:15px}.upload-form input[type=file]{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #7495b4;border-radius:6px;color:#fff;padding:10px}.upload-form button{width:100%}.map-container{border-radius:12px;box-shadow:0 2px 4px #0003;margin-top:20px;overflow:hidden;width:100%}.map-container iframe{border-radius:8px}@media (max-width:768px){.project-info-grid{grid-template-columns:1fr}.document-table,.employee-container,.map-container{padding:0;width:100%}button{width:100%}.employee-actions{align-items:center;flex-direction:column}.project-grid{grid-template-columns:1fr}.btn{width:100%}.total-profit{text-align:center}}.project-table tr{cursor:pointer}.project-table tr:hover{background-color:#374959}.upload-form input[type=date],.upload-form input[type=file],.upload-form input[type=number],.upload-form input[type=text],.upload-form select{box-sizing:border-box;width:100%}.project-form__actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:20px}.project-btn{min-width:126px}@media (max-width:700px){.project-actions{align-items:stretch;flex-direction:column;gap:8px}.project-actions button{margin-bottom:6px;width:100%}.project-actions button:last-child{margin-bottom:0}.timesheet-table,.timesheet-table tbody,.timesheet-table thead,.timesheet-table tr{box-sizing:border-box;display:block;width:100%}.timesheet-table thead{display:none}.timesheet-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%}.timesheet-table td,.timesheet-table th{text-align:center!important}.timesheet-table td:last-child{border-bottom:none}.timesheet-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;word-break:break-word}}.responsive-table-wrapper{margin-top:1.5rem;overflow-x:auto;width:100%}.timesheet-table{background:#23252b;border-collapse:collapse;border-radius:8px;margin-bottom:2rem;overflow:hidden;width:100%}.timesheet-table td,.timesheet-table th{border-bottom:1px solid #374959;color:#e0e0e0;padding:12px 8px;text-align:left}.timesheet-table th{background:#374959;color:#fff;font-size:1.05em;font-weight:600}.timesheet-table tr{transition:background .15s}.timesheet-table tr:hover{background:linear-gradient(135deg,#23252b 80%,#2b3a49)}.timesheet-table .total-row{background:#1b1d22;color:#fff;font-size:1.08em}.timesheet-table .total-row td{border-bottom:none;font-weight:700}.badge{font-size:.95em;font-weight:700;margin-right:.2em;padding:.2em .7em}@media (max-width:700px){.responsive-table-wrapper{margin:0 -8px;overflow-x:auto}.timesheet-table,.timesheet-table tbody,.timesheet-table thead,.timesheet-table tr{box-sizing:border-box;display:block;width:100%}.timesheet-table thead{display:none}.timesheet-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%}.timesheet-table td{align-items:center;border-bottom:none;display:flex;font-size:1em;justify-content:space-between;padding:10px 8px;text-align:left!important}.timesheet-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;word-break:break-word}.timesheet-table .total-row td{background:#1b1d22;border-radius:0 0 8px 8px;color:#fff;font-size:1.08em}}.timesheet-list-container{border-radius:12px;margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.timesheet-list-container h2{color:#fff;font-size:1.3em;margin-bottom:1.2em;text-align:center}@media (max-width:700px){.timesheet-list-container{margin:10px 0;padding:10px 2px}.timesheet-list-container h2{font-size:1.08em;margin-bottom:.7em}}.project-detail__totals_container{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:8px;box-shadow:0 2px 8px #0000;margin:2rem auto;max-width:100%;padding:20px 18px 18px}.totals-overview{display:flex;flex-direction:column;gap:1.2rem}.totals-row{align-items:center;background:#23252b;border-radius:6px;box-shadow:0 1px 4px #0000;display:flex;font-size:1.08em;justify-content:space-between;margin-bottom:.5rem;padding:12px 16px}.totals-label{color:#bfc4d1;font-weight:500}.totals-value{color:#fff;font-size:1.08em;font-weight:700;letter-spacing:.5px}@media (max-width:700px){.project-detail__totals_container{margin-left:0;margin-right:0;max-width:100%;padding:12px 6px 10px}.totals-row{align-items:flex-start;flex-direction:column;gap:.2em;padding:10px 8px}.totals-label,.totals-row,.totals-value{font-size:1em}}.totals-piechart-wrapper .recharts-legend-wrapper{align-items:flex-start!important;bottom:0!important;display:flex!important;flex-direction:row!important;justify-content:flex-start!important;left:0!important;margin-top:24px;top:auto!important;width:100%!important}.totals-piechart-wrapper .recharts-default-legend{align-items:center;display:flex;flex-direction:row;gap:.3em;justify-content:flex-start;margin-left:0;padding-left:0}.totals-piechart-wrapper .recharts-legend-item{display:inline-block;margin-right:10px}.totals-piechart-wrapper .recharts-legend-item-text{font-size:15px;font-weight:600;vertical-align:middle}@media (max-width:700px){.totals-piechart-wrapper .recharts-legend-wrapper{align-items:flex-start!important;flex-direction:column!important;font-size:.98em;padding:0 2px}.totals-piechart-wrapper .recharts-default-legend{align-items:flex-start;flex-direction:column}}.project-detail .recharts-legend-item{-webkit-font-smoothing:antialiased;align-items:center;border-bottom:1px solid #fff0;color:#bfc4d1;cursor:default;display:inline-block;font-family:Arial,sans-serif;font-size:15px;font-weight:500;justify-content:space-between;list-style:none;margin-right:10px;padding:1rem .5rem}.project-detail .recharts-legend-item:last-child{border-bottom:none}.project-detail .recharts-legend-item-text{color:#bfc4d1;font-family:Arial,sans-serif;font-size:15px;font-weight:500;margin-left:.5em}.document-table,.employee-table{background:#23252b;border-collapse:collapse;border-radius:8px;font-size:1em;margin-top:10px;overflow-x:auto;width:100%}.document-table td,.document-table th,.employee-table td,.employee-table th{font-size:1em;padding:10px 6px;text-align:left}.document-table th,.employee-table th{background:#374959;color:#fff;font-weight:600}.document-table tr,.employee-table tr{transition:background .15s}.document-table tr:hover{background:linear-gradient(135deg,#23252b 80%,#2b3a49)}@media (max-width:700px){.document-table,.employee-table{display:block;font-size:.97em;overflow-x:auto;width:100%}.document-table td,.document-table th,.employee-table td,.employee-table th{min-width:90px;white-space:nowrap}.project-detail h2,.project-detail h3{font-size:1.1em;margin-bottom:10px}.info-card{font-size:.98em;padding:1rem}}.project-detail .recharts-pie-label-text{fill:#fff!important;stroke:#23252b;stroke-width:.7px;font-size:1.12em!important;font-weight:700!important;paint-order:stroke fill;pointer-events:none;text-shadow:0 2px 8px #23252b,0 0 2px #23252b,0 0 8px #000;-webkit-user-select:none;user-select:none}.project-detail .recharts-pie-label-text:empty,.project-detail .recharts-pie-label-text:has(tspan:empty),.project-detail .recharts-pie-label-text[tspan="0.0%"]{display:none!important;opacity:0!important}.project-detail .pie-center-label-bg{fill:#23252b;rx:12;opacity:.92}.project-detail .pie-center-label{fill:#fff;dominant-baseline:middle;background:#23252b00;border-radius:12px;box-sizing:border-box;display:inline-block;font-size:1.15em;font-weight:700;max-width:180px;overflow:hidden;padding:8px 16px;pointer-events:none;text-align:center;text-overflow:ellipsis;text-shadow:0 2px 8px #23252b,0 0 2px #23252b;white-space:pre-line}.dashboard .recharts-pie-label-text,.project-detail .recharts-pie-label-text{fill:#fff!important;stroke:#23252b;stroke-width:.7px;font-size:1.12em!important;font-weight:700!important;paint-order:stroke fill;pointer-events:none;text-shadow:0 2px 8px #23252b,0 0 2px #23252b,0 0 8px #000;-webkit-user-select:none;user-select:none}.dashboard .recharts-pie-label-text:empty,.dashboard .recharts-pie-label-text:has(tspan:empty),.dashboard .recharts-pie-label-text[tspan="0.0%"],.project-detail .recharts-pie-label-text:empty,.project-detail .recharts-pie-label-text:has(tspan:empty),.project-detail .recharts-pie-label-text[tspan="0.0%"]{display:none!important;opacity:0!important}.dashboard .pie-center-label-bg,.project-detail .pie-center-label-bg{fill:#23252b;rx:12;opacity:.92}.dashboard .pie-center-label,.project-detail .pie-center-label{fill:#fff;dominant-baseline:middle;background:#23252b00;border-radius:12px;box-sizing:border-box;display:inline-block;font-size:1.15em;font-weight:700;max-width:180px;overflow:hidden;padding:8px 16px;pointer-events:none;text-align:center;text-overflow:ellipsis;text-shadow:0 2px 8px #23252b,0 0 2px #23252b;white-space:pre-line}@media (max-width:700px){.employee-table,.employee-table tbody,.employee-table thead,.employee-table tr{box-sizing:border-box;display:block;width:100%}.employee-table thead{display:none}.employee-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%}.employee-table td{align-items:flex-start;border-bottom:none;display:flex;flex-direction:column;font-size:1em;justify-content:flex-start;padding:10px 8px;text-align:left!important;width:100%}.employee-table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);font-size:.95em;font-weight:600;margin-bottom:4px;word-break:break-word}.employee-actions,.employee-actions-inline{align-items:stretch!important;flex-direction:column!important;gap:8px!important;margin-top:8px;width:100%}.employee-actions button,.employee-actions-inline button{margin-bottom:6px;width:100%}.employee-actions button:last-child,.employee-actions-inline button:last-child{margin-bottom:0}}.project-timesheet-table{background:#23252b;border-radius:10px;box-shadow:0 1px 4px #2c3e5000;font-size:1.05em;margin-bottom:2rem;overflow:hidden;width:100%}.project-timesheet-table td,.project-timesheet-table th{background:none;border-bottom:1px solid #374959;color:#e0e0e0;padding:14px 10px;text-align:left}.project-timesheet-table th{background:#374959;color:#fff;font-size:1.08em;font-weight:600;letter-spacing:.01em}.project-timesheet-table tr{transition:background .15s}.project-timesheet-table tr:hover{background:#2c2f3b}.project-timesheet-table .total-row{background:#1b1d22;color:#fff;font-size:1.08em;font-weight:700}.project-timesheet-table .cell-label{color:#bfc4d1;display:none;font-weight:600;margin-right:.5em}@media (max-width:700px){.project-timesheet-table,.project-timesheet-table tbody,.project-timesheet-table thead,.project-timesheet-table tr{box-sizing:border-box;display:block;width:100%}.project-timesheet-table thead{display:none}.project-timesheet-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%}.project-timesheet-table td{align-items:center;background:none;border-bottom:none;display:flex;flex-direction:row;font-size:1em;justify-content:flex-start;padding:10px 8px;text-align:left!important;width:100%}.project-timesheet-table .cell-label{color:#bfc4d1;display:inline-block;font-size:.98em;font-weight:600;margin-right:.7em;min-width:110px}.project-timesheet-table .total-row td{background:#1b1d22;border-radius:0 0 8px 8px;color:#fff;font-size:1.08em;font-weight:700}}.project-timesheet-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-top:2rem}.project-timesheet-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #7495b4;border-radius:12px;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;color:#fff;cursor:pointer;outline:none;padding:1.5rem 1.2rem 1.2rem;transition:box-shadow .2s,transform .2s}.project-timesheet-card:focus,.project-timesheet-card:hover{border-color:#7495b4;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;transform:translateY(-2px) scale(1.01)}.project-timesheet-card-row{align-items:center;display:flex;font-size:1.08em;gap:.5em;justify-content:space-between;margin-bottom:.7em}.project-timesheet-label{font-weight:500;opacity:.85}.project-timesheet-value{font-weight:600;text-align:right}.total-summary-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:2px solid #7495b4;border-radius:12px;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;color:#fff;font-weight:700}.badge{border-radius:12px;color:#fff;display:inline-block;font-size:.98em;font-weight:600;letter-spacing:.01em;margin-left:.2em;padding:.25em .8em}@media (max-width:1100px){.project-timesheet-list{grid-template-columns:repeat(2,1fr)}}@media (max-width:700px){.project-timesheet-list{gap:.7rem;grid-template-columns:1fr;margin-top:1rem}.project-timesheet-card{font-size:.98em;padding:.8rem .5rem}.project-timesheet-card-row{align-items:flex-start;flex-direction:column;font-size:.98em;gap:.1em}.project-timesheet-label{font-size:.97em;margin-bottom:.1em}.project-timesheet-value{font-size:.97em;text-align:left}}.project-timesheet-summary-top{align-items:stretch;background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:2px solid #7495b4;border-radius:16px;box-shadow:0 4px 24px #2c3e5000,0 2px 8px #2c3e5000;color:#fff;display:flex;font-size:1.18em;font-weight:600;gap:2.5rem;justify-content:flex-start;margin:2.2rem 0 1.5rem;padding:1.2rem 2.2rem}.summary-item{align-items:flex-start;display:flex;flex-direction:column;margin-right:2.5rem;min-width:180px}.summary-label{color:#bfc4d1;font-size:1em;font-weight:500;letter-spacing:.01em;margin-bottom:.3em}.summary-value{color:#fff;font-size:1.25em;font-weight:700;letter-spacing:.01em}@media (max-width:900px){.project-timesheet-summary-top{flex-direction:column;font-size:1.05em;gap:1.2rem;padding:1rem 1.2rem}.summary-item{margin-right:0;min-width:0}}.project-timesheet-status-summary{align-items:center;display:flex;flex-wrap:wrap;gap:1.1rem;margin-bottom:1.2rem}.status-summary-badge{align-items:center;background:#374959;border-radius:14px;box-shadow:0 1px 4px #2c3e5000;color:#fff;display:flex;font-size:1.01em;font-weight:600;gap:.5em;padding:.3em 1.1em}.status-summary-badge .status-summary-count{color:#fff;font-size:1.08em;font-weight:700;margin-left:.3em}.modal-project-form{background:none;box-shadow:none;display:flex;flex-direction:column;gap:.5rem;margin:0;max-width:480px;min-width:0;padding:0;width:100%}.modal-form-title{color:#7495b4;font-size:1.35rem;font-weight:600;margin-bottom:.7rem;text-align:left}.modal-form-section{display:flex;gap:1.2rem;margin-bottom:.5rem}.modal-form-field{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.modal-form-field label{color:#bfc4d1;font-size:.98rem;font-weight:500;margin-bottom:.1rem}.modal-form-field input,.modal-form-field select{background:#23252b;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;color:#fff;font-size:1rem;margin-bottom:.1rem;outline:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.modal-form-field input:focus,.modal-form-field select:focus{border-color:#7495b4;box-shadow:0 0 0 2px #7495b433}.modal-form-error{color:#e57373;font-size:.98rem;margin:.5rem 0 .2rem}.modal-form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.2rem}.modal-project-form input,.modal-project-form select{max-width:97%}.btn-add,.btn-cancel{border:none;border-radius:6px;cursor:pointer;font-size:1rem;padding:.7em 1.2em;transition:background .2s,color .2s}.btn-add{color:#fff;font-weight:600}.btn-add:disabled{background:#bfc4d1;color:#eee;cursor:not-allowed}.btn-cancel{background:#821d24;color:#fff}.btn-cancel:hover{background:#a71d2a;color:#fff}@media (max-width:700px){.modal-project-form{max-width:98vw;padding:0 .5rem}.modal-form-actions,.modal-form-section{flex-direction:column;gap:.5rem}.modal-form-actions{align-items:stretch;max-width:97%}.btn-add,.btn-cancel{min-width:0;width:100%}}.timesheet-list{margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.filters{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.filter-group{color:#ccc;display:flex;flex-direction:column;font-size:.9rem}.filter-group label{font-weight:500;margin-bottom:4px}.filter-group select{background:#2c2f3b;border:1px solid #3a3d4d;border-radius:6px;color:#fff;font-size:.95rem;min-width:180px;padding:10px 12px}.btn-sort{align-items:center;background:#7495b4;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;padding:10px 16px;transition:background .3s ease}.btn-sort:hover{background:#374959}.arrow{border-left:5px solid #0000;border-right:5px solid #0000;display:inline-block;height:0;margin-left:2px;width:0}.arrow.up{border-bottom:6px solid #fff}.arrow.down{border-top:6px solid #fff}.modern-timesheet-table{background:#1d1f27;border-collapse:collapse;width:100%}.modern-timesheet-table thead th{background:#2c2f3b;border-bottom:1px solid #3a3d4d;color:#fff;font-weight:600;padding:12px 16px;text-align:center;vertical-align:middle}.modern-timesheet-table td{border-bottom:1px solid #2c2f3b;padding:14px 16px;text-align:center;vertical-align:middle}.modern-timesheet-table .btn-delete{margin:0}.approver{color:#ccc;font-size:.75rem;margin-top:6px}.actions{align-items:stretch}.actions .btn{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;padding:10px 14px;text-align:center;width:100%}.create-timesheet-wrapper{display:flex;justify-content:flex-end;margin-bottom:20px}.btn-create{background-color:#1d5c3b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:10px 18px;text-decoration:none;transition:background-color .3s ease}.btn-create:hover{background-color:#1e7e34}.timesheet-list-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));margin-top:2rem}.timesheet-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:1rem;box-shadow:0 2px 12px #0000;display:flex;flex-direction:column;gap:.7rem;justify-content:space-between;margin:0 auto;max-width:420px;min-height:200px;min-width:350px;padding:1.5rem 1.5rem 1rem;transition:box-shadow .2s}.timesheet-card:hover{box-shadow:0 0 8px #007bff66}.timesheet-card-header{align-items:center;display:flex;gap:1.2rem;justify-content:space-between;margin-bottom:1rem}.timesheet-card-title{color:#fff;font-size:1.15rem;font-weight:700;letter-spacing:.01em}.timesheet-card-details{color:#e0e0e0;display:flex;flex-direction:column;font-size:1rem;gap:.35rem;margin-bottom:1rem}.timesheet-card-details b{color:#bfc4d1;display:inline-block;font-weight:500;min-width:90px}.timesheet-card-details>div{align-items:center;display:flex;flex-direction:row;gap:.5rem;justify-content:space-between;line-height:1.5}.timesheet-card-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:auto}.timesheetlist-toolbar{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem}.timesheetlist-search{background:#23252b;border:1px solid #7495b4;border-radius:8px;box-shadow:0 1px 4px #0000;color:#e0e0e0;font-size:1.05rem;margin-top:1.1rem;max-width:350px;padding:12px 16px}.filters-dropdowns{display:flex;flex-wrap:wrap;gap:1.2rem}.btn-approve{width:100%}@media (max-width:768px){.actions,.filters{align-items:stretch;flex-direction:column}.btn{width:100%}}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto;width:100%}@media (max-width:900px){.modern-timesheet-table td,.modern-timesheet-table thead th{font-size:.95rem;padding:8px}}@media (max-width:600px){.modern-timesheet-table td,.modern-timesheet-table thead th{font-size:.85rem;padding:6px 4px}.timesheet-list{padding:8px}.filters{flex-direction:column;gap:8px}}@media (max-width:700px){.table-responsive{overflow-x:visible}.modern-timesheet-table,.modern-timesheet-table tbody,.modern-timesheet-table thead,.modern-timesheet-table tr{box-sizing:border-box;display:block;width:100%}.modern-timesheet-table thead{display:none}.modern-timesheet-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%}.modern-timesheet-table td{align-items:center;background:none;border:none;border-bottom:1px solid #2c2f3b;box-sizing:border-box;display:flex;font-size:1rem;justify-content:space-between;padding:10px 16px;position:relative;width:100%;word-break:break-word}.modern-timesheet-table td:last-child{border-bottom:none}.modern-timesheet-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}.timesheet-list-grid{gap:1.2rem;grid-template-columns:1fr}.timesheet-card{min-height:0;min-height:auto;padding:1rem}.timesheet-card-header{gap:.7rem}.timesheet-card-details b{min-width:70px}.filters-dropdowns{flex-direction:column;gap:.7rem}}.btn-add-timesheet{background-color:#1d5c3b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:10px 18px;text-decoration:none;transition:background-color .3s ease}.btn-add-timesheet:hover{background-color:#1e7e34}.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{background:#23252b;border:1px solid #374959;border-radius:.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}.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{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:12px;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;color:#fff;font-family:Segoe UI,sans-serif;margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.timesheet-header h2{color:#fff;margin-bottom:20px;text-align:center}.meta-info{grid-gap:10px;display:grid;font-size:.95rem;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:30px}.status-badge{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:700;text-align:center;width:fit-content}.status-badge.approved{background-color:#198754;color:#fff}.status-badge.rejected{background-color:#821d24;color:#fff}.status-badge.pending{background-color:#b68b00;color:#212529}a.btn-view{padding:10px 0}.timesheet-section{display:block;gap:2rem;margin-bottom:1rem;width:100%}.timesheet-info{flex:1 1}.timesheet-section h3{border-bottom:1px solid #444;color:#7495b4;margin-bottom:10px;padding-bottom:4px}.table-wrapper{margin-bottom:.5rem;overflow-x:auto;width:100%}.extra-work-table,.materials-table,.timesheet-table{background:#2c2f3b;border-collapse:collapse;border-radius:6px;margin-top:10px;overflow:hidden;table-layout:auto;width:100%}@media (max-width:700px){.timesheet-table,.timesheet-table tbody,.timesheet-table thead,.timesheet-table tr{box-sizing:border-box;display:block;width:100%}.timesheet-table thead{display:none}.timesheet-table tr{background:#23252b;border-radius:8px;box-shadow:0 2px 8px #0000;box-sizing:border-box;display:flex;flex-wrap:wrap;margin-bottom:10px;padding:0;width:100%}.timesheet-table td{align-items:center;background:none;border:none;border-bottom:1px solid #444;box-sizing:border-box;display:flex;font-size:1rem;justify-content:flex-start;min-width:120px;padding:10px 8px;position:relative;width:50%;word-break:break-word}.timesheet-table td:last-child{border-bottom:none}.timesheet-table td:before{box-sizing:border-box;color:#bfc4d1;content:attr(data-label);flex:0 0 60%;font-size:.95em;font-weight:600;padding-right:10px;text-align:left;word-break:break-word}}.extra-work-table td,.extra-work-table th,.materials-table td,.materials-table th,.timesheet-table td,.timesheet-table th{border-bottom:1px solid #444;font-size:.95rem;padding:12px;text-align:left;vertical-align:top}.extra-work-table th,.materials-table th,.timesheet-table th{background-color:#7495b4;color:#fff}.extra-work-table td,.materials-table td,.timesheet-table td{color:#ddd}@media (max-width:768px){.meta-info{grid-template-columns:1fr}.table-wrapper{overflow-x:auto}}.full-width{width:100%}.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:350px;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-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}.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:20px}h1{color:#fff;font-size:2.2rem;letter-spacing:.01em;margin-bottom:20px;text-align:center}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.dashboard-row{display:flex;flex-direction:row;flex-wrap:wrap;gap:2rem;width:100%}.dashboard-row .dashboard-card{flex:1 1;margin-bottom:2rem!important;max-width:100%;min-width:0}.dashboard-card{align-items:center;background:#23252b;background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:12px;box-shadow:0 4px 16px #0000;color:#fff;flex-direction:column;justify-content:space-between;margin-bottom:2rem!important;padding:1.5rem 1rem 1rem;transition:box-shadow .2s}.dashboard-card:focus-within,.dashboard-card:hover{box-shadow:0 8px 24px #2c3e5000}.dashboard-card h3{color:#bfc4d1;font-size:1.25rem;margin-bottom:1rem;text-align:center}.dashboard-card ul{list-style:none;padding:0;width:100%}.dashboard-card ul li{align-items:center;border-bottom:1px solid #fff0;display:flex;justify-content:space-between;padding:1rem .5rem}.dashboard-card ul li:last-child{border-bottom:none}.dashboard-card a.btn-view{background:#7495b4;border-radius:6px;color:#fff;display:block;font-weight:700;margin-top:1rem;padding:12px 0;text-align:center;transition:background .2s;width:100%}.dashboard-card a.btn-view:hover{background:#374959}.dashboard-card table{background:#23252b;border-radius:8px;font-size:1em;overflow-x:auto;width:100%}.dashboard-card td,.dashboard-card th{font-size:1em;padding:10px 6px;text-align:left}.dashboard-card th{background:#374959;color:#fff;font-weight:600}.dashboard-card tr{transition:background .15s}.dashboard-card tr:hover{background:#2c2f3b}.profit{font-size:18px;font-weight:700}.profit.positive{color:#28a745}.profit.negative{color:#dc3545}.financial-overview-card{align-items:stretch;background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:18px;box-shadow:0 8px 32px #2c3e502e,0 2px 8px #2c3e501a;color:#fff!important;cursor:pointer;display:flex;flex-direction:column;grid-column:1/-1;margin-bottom:2.5rem;margin-left:0;margin-right:0;max-width:100%;order:-1;outline:none;overflow:hidden;padding:2.5rem 1.5rem 2rem;position:relative;transition:box-shadow .2s,border .2s;width:100%}.financial-overview-card h3{color:#fff;font-size:2.1rem;font-weight:700;letter-spacing:.01em;margin-bottom:2.2rem;text-align:center}.financial-overview-card .totals-overview{grid-gap:1.5rem;background:#0000;border-radius:0;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:2.2rem;padding:0}.financial-overview-card .totals-row{align-items:flex-start;background:#23252b;border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #0000;display:flex;flex-direction:column;font-size:1.15rem;margin-bottom:0;min-height:90px;padding:1.2rem;position:relative}.financial-overview-card .totals-label{align-items:center;color:#bfc4d1;display:flex;font-size:1.05rem;font-weight:600;gap:.5em;margin-bottom:.5rem}.financial-overview-card .profit,.financial-overview-card .totals-value{color:#fff;font-size:1.45rem;font-weight:700;letter-spacing:.5px;margin-top:.2rem}.financial-overview-card .profit.positive{color:#28a745}.financial-overview-card .profit.negative{color:#dc3545}.financial-overview-card .totals-row .icon{font-size:1.3em;margin-right:.5em;vertical-align:middle}.financial-overview-card .summary-badge{background:#23252b;border-radius:16px;box-shadow:0 1px 4px #0000;color:#fff;display:inline-block;font-size:1.1em;font-weight:700;margin-top:1.2em;padding:.4em 1.2em}.financial-overview-card .summary-badge.positive{background:#28a745;color:#fff}.financial-overview-card .summary-badge.negative{background:#dc3545;color:#fff}@media (max-width:900px){.financial-overview-card .totals-overview{gap:1rem;grid-template-columns:1fr 1fr}}@media (max-width:700px){.financial-overview-card{padding:1.2rem .5rem 1rem}.financial-overview-card h3{font-size:1.2rem;margin-bottom:1.2rem}.financial-overview-card .totals-overview{gap:.7rem;grid-template-columns:1fr}.financial-overview-card .totals-row{font-size:1.05rem;min-height:60px;padding:.8rem .7rem}.financial-overview-card .totals-label{font-size:.98rem}.financial-overview-card .profit,.financial-overview-card .totals-value{font-size:1.1rem}}.dashboard-card.assigned-projects-card ul li{align-items:flex-start;background:#23252b;border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #0000;display:flex;flex-direction:column;font-size:1.13em;margin-bottom:1.1rem;padding:1.2rem 1rem;transition:box-shadow .2s,border .2s}.dashboard-card.assigned-projects-card ul li:focus-within,.dashboard-card.assigned-projects-card ul li:hover{border:1.5px solid #7495b4;box-shadow:0 2px 8px #2c3e5000}.dashboard-card.assigned-projects-card ul li strong{color:#fff;font-size:1.18em;margin-bottom:.2em}.dashboard-card.assigned-projects-card ul li .profit{display:inline-block;font-size:1.08em;font-weight:600;margin-top:.5em}.dashboard-card.assigned-projects-card ul li .profit.positive{color:#28a745}.dashboard-card.assigned-projects-card ul li .profit.negative{color:#dc3545}.dashboard-card.assigned-projects-card ul li .project-meta{color:#bfc4d1;font-size:.98em;margin-top:.2em}.dashboard-card.assigned-projects-card ul li .project-badge{background:#7495b4;border-radius:8px;color:#fff;display:inline-block;font-size:.95em;margin-right:.5em;margin-top:.5em;padding:.2em .8em}@media (max-width:700px){.dashboard-card.assigned-projects-card ul li{font-size:1em;padding:.8rem .5rem}.dashboard-card.assigned-projects-card ul li strong{font-size:1.05em}}.dashboard-timesheet-cards{display:flex;flex-direction:row;flex-wrap:wrap;gap:1.2rem;margin-top:1.2rem}.timesheet-card-dashboard{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #0000;cursor:pointer;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}.timesheet-card-dashboard:focus,.timesheet-card-dashboard:hover{border:1.5px solid #7495b4;box-shadow:0 2px 8px #2c3e5000}.timesheet-card-dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.7em}.timesheet-project{color:#fff;font-size:1.12em;font-weight:600}.timesheet-week{color:#bfc4d1;font-size:1em;font-weight:500}.timesheet-card-dashboard-body{align-items:center;display:flex;gap:1em;justify-content:space-between}.timesheet-status{font-size:.98em}.status-badge-dashboard{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:700;padding:.5rem;text-align:center;width:fit-content}.timesheet-hours{align-items:center;color:#7495b4;display:flex;font-size:1.08em;font-weight:600;margin-top:1rem}@media (max-width:900px){.dashboard-timesheet-cards{flex-direction:column;gap:1rem}.timesheet-card-dashboard{min-width:0;width:100%}}.invalid-users-list{grid-gap:1.2rem;display:grid;gap:1.2rem;grid-template-columns:repeat(3,1fr);margin:0;padding:0}@media (max-width:1100px){.invalid-users-list{grid-template-columns:repeat(2,1fr)}}@media (max-width:700px){.invalid-users-list{gap:.7rem;grid-template-columns:1fr}}.invalid-user-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border:1px solid #2b3a49;border-radius:10px;box-shadow:0 1px 4px #2c3e5000;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;min-height:0;min-width:0;outline:none;padding:1rem 1.1rem;position:relative;transition:box-shadow .2s,border .2s}.invalid-user-card:focus,.invalid-user-card:hover{border:1.5px solid #7495b4;box-shadow:0 2px 8px #2c3e5000}.invalid-user-card.has-expired{border:2px solid #a71d2a;box-shadow:0 0 0 2px #a71d2a33}.invalid-user-header{align-items:center;display:flex;flex-wrap:wrap;font-size:1em;gap:.5em;min-height:0}.invalid-user-name{color:#fff;font-size:1.05em;font-weight:600;margin-right:.2em}.invalid-user-email{color:#bfc4d1;font-size:.97em;margin-right:.4em}.invalid-user-toggle{color:#bfc4d1;cursor:pointer;font-size:1.1em;margin-left:auto}.invalid-user-details{align-items:flex-start;gap:.3em;margin-top:.2em}.doc-list,.invalid-user-details{display:flex;flex-direction:column}.doc-list{gap:.2em;margin:.2em 0}.doc-item{background:#a71d2a;border-radius:6px;color:#fff;display:inline-block;font-size:.98em;font-weight:500;letter-spacing:.01em;margin-bottom:.1em;padding:.18em .7em}.doc-item.missing{background:#374959;color:#fff}.doc-item.expired{background:#a71d2a;color:#fff}.btn-view-user{background:#7495b4;border:none;border-radius:6px;box-shadow:0 1px 2px #2c3e5000;color:#fff;cursor:pointer;display:block;font-size:.97em;font-weight:700;margin-top:.3em;padding:.5em 1em;transition:background .2s;width:100%}.btn-view-user:focus,.btn-view-user:hover{background:#374959}@media (max-width:700px){.invalid-user-card{font-size:.97em;padding:.7rem .5rem}.invalid-user-header{align-items:flex-start;flex-direction:column;font-size:.98em;gap:.1em}.invalid-user-toggle{margin-left:0;margin-top:.2em}.invalid-user-details{align-items:flex-start;flex-direction:column;gap:.2em}.btn-view-user{margin-top:.3em;width:100%}}@media (max-width:768px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width:900px){.financial-overview-card{max-width:100%}.dashboard-row{flex-direction:column;gap:1.5rem}.dashboard-card{margin-bottom:1.5rem!important;min-width:0;width:100%}}@media (max-width:700px){.dashboard{min-width:0;overflow-x:hidden;padding:8px}.timesheet-card-dashboard{box-sizing:border-box;margin-left:-8px;margin-right:-8px;min-width:0}}@media (max-width:600px){.dashboard-card table{display:block;overflow-x:auto;width:100%}.dashboard-card td,.dashboard-card th{min-width:90px;white-space:nowrap}}.doc-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.1em;padding:.18em .2em;width:100%}.doc-label{color:#bfc4d1;font-size:1em;font-weight:600;text-align:left}.doc-value{color:#fff;flex:1 1;font-size:1em;font-weight:500;margin-left:1em;text-align:right}.missing-row .missing-label,.missing-row .missing-value{color:#b68b00!important;font-weight:700}.expired-indicator,.expired-row .expired-label,.expired-row .expired-value{color:#a71d2a;font-weight:700}.expired-indicator{font-size:1.3em;margin-left:.5em;vertical-align:middle}.user-list{margin:auto;max-width:1200px;min-width:0;padding:20px;width:100vw}.user-list-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-top:2rem}.user-card{background:linear-gradient(135deg,#23252b 80%,#2b3a49);border-radius:1rem;box-shadow:0 2px 12px #0000;display:flex;flex-direction:column;gap:.7rem;justify-content:space-between;max-width:420px;min-height:260px;padding:1.5rem 1.5rem 1rem;transition:box-shadow .2s}.user-card:hover{box-shadow:0 4px 24px #0000}.user-card-header{align-items:center;display:flex;gap:1.2rem;margin-bottom:1rem}.user-card-avatar{align-items:center;background:#2c2f3b;border:2px solid #7495b4;border-radius:50%;color:#7495b4;display:flex;flex-shrink:0;font-size:2rem;font-weight:700;height:56px;justify-content:center;overflow:hidden;position:relative;width:56px}.user-card-avatar img{border-radius:50%;display:block;height:100%;object-fit:cover;width:100%}.user-card-info{display:flex;flex-direction:column;gap:.2rem;justify-content:center}.user-card-name{color:#fff;font-size:1.15rem;font-weight:700;letter-spacing:.01em;margin-bottom:2px}.user-card-email{color:#bfc4d1;font-size:.97rem;margin-bottom:2px;word-break:break-all}.user-card-details{color:#e0e0e0;display:flex;flex-direction:column;font-size:1rem;gap:.35rem;margin-bottom:1rem}.user-card-details b{color:#bfc4d1;display:inline-block;font-weight:500;min-width:90px}.user-card-details>div{align-items:center;display:flex;flex-direction:row;gap:.5rem;justify-content:space-between;line-height:1.5}.user-card-actions{display:flex;gap:.7rem;margin-top:auto}@media (max-width:700px){.user-list-grid{gap:1.2rem;grid-template-columns:1fr}.user-card{min-height:0;min-height:auto;padding:1rem}.user-card-header{gap:.7rem}.user-card-avatar{font-size:1.3rem;height:44px;width:44px}.user-card-details b{min-width:70px}}.userlist-toolbar{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem}.userlist-search{background:#23252b;border:1px solid #7495b4;border-radius:8px;box-shadow:0 1px 4px #0000;color:#e0e0e0;flex:1 1 250px;font-size:1.05rem;margin-bottom:0;max-width:350px;padding:12px 16px}.invite-section>button{height:44px!important}.btn-add-user{background:#1d5c3b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:700;margin-bottom:20px;padding:8px 16px;transition:background .2s}.btn-add-user:hover{background:#28a745}.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%}.user-detail__container--card{align-items:center;background:none;display:flex;flex-direction:row;gap:2.5rem;margin-bottom:2rem}.user-detail__image-wrapper{align-items:center;cursor:pointer;display:flex;justify-content:center;min-width:120px;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{border:3px solid #7495b4;border-radius:50%;cursor:pointer;height:120px;object-fit:cover;transition:box-shadow .2s,transform .2s;width:120px}.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}.upload-form{background:#23252b;border-radius:8px;box-shadow:0 1px 4px #2c3e5000;padding:1rem}.upload-form label{color:#bfc4d1;font-weight:600}.upload-form input,.upload-form select{background:#2c2f3b;border:1px solid #444;border-radius:6px;color:#fff;font-size:1em;margin-bottom:.5rem;padding:.5rem .7rem}.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{margin-top:1rem;overflow-x:auto}.documents-table-users{background:none;border-collapse:initial;border-spacing:0;color:#fff;font-size:1em;width:100%}.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.98a2b821.css.map*/