:root{--primary-color:#c33;--secondary-color:#a22;--accent-color:#c33;--background-color:#f8f9fa;--surface-color:#fff;--text-color:#2c3e50;--text-secondary:#6c757d;--border-color:#dee2e6;--success-color:#27ae60;--error-color:#e74c3c;--rooijakkers-red:#c33;--rooijakkers-dark-red:#a22;--rooijakkers-light-red:#ffe6e6;--rooijakkers-gray:#4a4a4a;--rooijakkers-light-gray:#f5f5f5;--rooijakkers-secondary:#38a9ff;--rooijakkers-secondary-hover:#0091ff;--rooijakkers-purple:#7c5ac2;--rooijakkers-yellow:#ffd600;--rooijakkers-green:#08ddc1;--rooijakkers-body-bg:#f8f9fa;--rooijakkers-white:#fff;--rooijakkers-light:#f8f8fb;--rooijakkers-dark-gray:#515365;--rooijakkers-text:#515365;--rooijakkers-text-light:#888da8;--rooijakkers-light-blue:#e9f5ff;--rooijakkers-light-pink:#ffe6e6;--rooijakkers-light-green:#ebfcf5;--rooijakkers-light-yellow:#fffceb;--rooijakkers-light-purple:#f2eaff;--sidebar-width:280px;--header-height:70px;--rooijakkers-card-shadow:0 0 34px 0 rgba(63,66,87,.1)}body{font-family:'Circular',-apple-system,BlinkMacSystemFont,Roboto,sans-serif;background-color:var(--background-color);color:var(--text-color);margin:0;line-height:1.5}.goeveni-header{background-color:var(--surface-color);box-shadow:var(--rooijakkers-card-shadow);position:sticky;top:0;width:100%;z-index:1000;height:var(--header-height)}.header-container{display:flex;align-items:center;justify-content:space-between;padding:0 20px;max-width:1400px;margin:0 auto;height:100%}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;text-decoration:none}.logo img{height:40px}.logo h1{font-size:24px;font-weight:700;color:var(--rooijakkers-red);margin:0}.header-search{flex:1;max-width:400px;margin:0 20px;position:relative}.search-form{position:relative;width:100%}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--rooijakkers-gray)}.search-form input{width:100%;padding:10px 15px 10px 40px;border-radius:30px;border:1px solid var(--border-color);background-color:var(--rooijakkers-light);font-size:14px;transition:all .3s;box-sizing:border-box}.search-form input:focus{outline:0;border-color:var(--rooijakkers-red);box-shadow:0 0 0 3px rgba(204,51,51,.1)}.header-right{display:flex;align-items:center}.nav-links{display:flex;list-style:none;margin:0;padding:0}.nav-links li{margin:0 5px}.nav-links a{display:flex;align-items:center;color:var(--text-color);text-decoration:none;padding:10px 15px;border-radius:5px;font-weight:500;font-size:14px;transition:all .2s}.nav-links a i{margin-right:6px;font-size:16px}.nav-links a:hover{background-color:var(--rooijakkers-light)}.nav-links a.active{color:var(--rooijakkers-red);background-color:var(--rooijakkers-light-pink)}.notifications{margin-left:15px;position:relative}.notification-btn{position:relative;background:none;border:0;padding:8px;cursor:pointer;color:var(--text-color);font-size:18px;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.notification-btn:hover{background-color:var(--rooijakkers-light)}.notification-badge{position:absolute;top:0;right:0;background-color:var(--rooijakkers-red);color:#fff;font-size:10px;font-weight:600;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.notification-dropdown{position:absolute;top:52px;right:0;width:300px;background-color:var(--surface-color);border-radius:8px;box-shadow:0 5px 20px rgba(0,0,0,.15);z-index:100}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:1px solid var(--border-color)}.notification-header h3{margin:0;font-size:16px;font-weight:600}.mark-all-read{background:none;border:0;color:var(--rooijakkers-red);font-size:12px;cursor:pointer}.notification-list{max-height:300px;overflow-y:auto}.notification-item{display:flex;padding:12px 15px;border-bottom:1px solid var(--border-color);transition:background-color .2s}.notification-item:hover{background-color:var(--rooijakkers-light)}.notification-item.unread{background-color:var(--rooijakkers-light-pink)}.notification-icon{margin-right:10px;width:20px;text-align:center;color:var(--rooijakkers-red)}.notification-content{flex:1}.notification-title{font-weight:600;font-size:13px;margin-bottom:2px}.notification-message{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.notification-time{font-size:11px;color:var(--rooijakkers-gray)}.no-notifications{text-align:center;padding:30px;color:var(--text-secondary)}.no-notifications i{font-size:24px;margin-bottom:10px;display:block}.user-menu{position:relative;margin-left:20px}.user-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;cursor:pointer;position:relative;background:none;border:0;padding:0}.avatar-placeholder{width:100%;height:100%;background-color:var(--rooijakkers-light);display:flex;align-items:center;justify-content:center;color:var(--rooijakkers-red);font-size:16px}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-status{position:absolute;bottom:0;right:0;width:12px;height:12px;background-color:var(--rooijakkers-green);border-radius:50%;border:2px solid #fff}.user-dropdown{position:absolute;top:52px;right:0;width:280px;background-color:var(--surface-color);border-radius:8px;box-shadow:0 5px 20px rgba(0,0,0,.15);z-index:100}.user-info{display:flex;align-items:center;padding:15px;border-bottom:1px solid var(--border-color)}.user-avatar-sm{width:40px;height:40px;border-radius:50%;overflow:hidden;margin-right:12px}.avatar-placeholder-sm{width:100%;height:100%;background-color:var(--rooijakkers-light);display:flex;align-items:center;justify-content:center;color:var(--rooijakkers-red);font-size:16px}.user-avatar-sm img{width:100%;height:100%;object-fit:cover}.user-details h4{margin:0;font-size:14px;font-weight:600;color:var(--text-color)}.user-details p{margin:0;font-size:12px;color:var(--text-secondary)}.dropdown-menu{list-style:none;padding:10px 0;margin:0}.dropdown-menu li a{display:flex;align-items:center;color:var(--text-color);text-decoration:none;padding:10px 15px;font-size:14px;transition:background-color .2s}.dropdown-menu li a:hover{background-color:var(--rooijakkers-light)}.dropdown-menu li a i{margin-right:10px;width:20px;text-align:center;color:var(--text-secondary)}.logout-link{color:var(--error-color)!important}.version-info{padding:10px 15px;font-size:11px;color:var(--text-secondary);border-top:1px solid var(--border-color);text-align:center}.version-label{font-weight:500}.version-number{font-family:monospace}.goeveni-layout{display:flex;gap:30px;padding:20px;max-width:1440px;margin:0 auto;min-height:calc(100vh - var(--header-height))}.sidebar-filters{width:var(--sidebar-width);flex-shrink:0;background-color:var(--surface-color);border-radius:12px;padding:20px;box-shadow:var(--rooijakkers-card-shadow);position:sticky;top:calc(var(--header-height) + 20px);height:fit-content}.filter-header{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.filter-header h3{font-size:18px;font-weight:600;color:var(--text-color);margin:0}.filter-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border-color)}.filter-section:last-child{border-bottom:0;padding-bottom:0}.filter-section h4{font-size:15px;font-weight:500;color:var(--text-color);margin:0 0 12px 0;display:flex;align-items:center;gap:8px}.filter-section h4 i{color:var(--rooijakkers-red)}.filter-date-group,.filter-amount-group{display:flex;flex-direction:column;gap:10px}.filter-date-group label,.filter-amount-group label{font-size:13px;color:var(--text-secondary);margin-bottom:2px}.sidebar-filters select,.sidebar-filters input[type="text"],.sidebar-filters input[type="date"],.sidebar-filters input[type="number"]{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;background-color:var(--background-color);box-sizing:border-box}.sidebar-filters input:focus,.sidebar-filters select:focus{outline:0;border-color:var(--rooijakkers-red)}.filter-btn{width:100%;margin-top:10px;background-color:var(--rooijakkers-red);color:#fff;border:0;border-radius:8px;padding:10px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.filter-btn:hover{background-color:var(--rooijakkers-dark-red)}.reset-btn{width:100%;padding:10px;background-color:var(--background-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.reset-btn:hover{background-color:var(--border-color)}.status-options{display:flex;flex-direction:column;gap:10px}.status-option{display:flex;align-items:center;gap:8px;cursor:pointer}.status-option input[type="checkbox"]{width:16px;height:16px;accent-color:var(--rooijakkers-red)}.status-option span{font-size:14px;color:var(--text-color)}.mobile-filter-toggle{display:none;width:100%;padding:14px 20px;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:12px;font-size:16px;font-weight:500;color:var(--text-color);cursor:pointer;margin-bottom:16px;box-shadow:var(--rooijakkers-card-shadow);transition:all .2s;align-items:center}.mobile-filter-toggle:hover{border-color:var(--rooijakkers-red)}.mobile-filter-toggle i.fa-filter{margin-right:10px;color:var(--rooijakkers-red)}.mobile-filter-toggle .filter-count{background-color:var(--rooijakkers-red);color:#fff;font-size:12px;font-weight:600;padding:2px 8px;border-radius:12px;margin-left:8px}.mobile-filter-toggle .toggle-icon{margin-left:auto;transition:transform .3s ease}.mobile-filter-toggle.active .toggle-icon{transform:rotate(180deg)}.mobile-filter-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);z-index:1001;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-filter-overlay.active{opacity:1;visibility:visible}.mobile-filter-header{display:none;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background-color:var(--surface-color);z-index:1;border-radius:20px 20px 0 0}.mobile-filter-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-color)}.mobile-filter-close{background:none;border:0;font-size:24px;color:var(--text-color);cursor:pointer;padding:8px;border-radius:8px;transition:background-color .2s}.mobile-filter-close:hover{background-color:var(--rooijakkers-light)}.mobile-filter-handle{display:none;width:40px;height:4px;background-color:var(--border-color);border-radius:2px;margin:12px auto 8px}body.mobile-filter-open{overflow:hidden}.main-content{flex-grow:1}.activities-header,.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.activities-header h2,.content-header h1{font-size:24px;font-weight:600;margin:0;color:var(--text-color)}.add-btn{background-color:var(--rooijakkers-red);color:#fff;border:0;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.add-btn:hover{background-color:var(--rooijakkers-dark-red)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px;padding:15px}.stat-card{background-color:var(--surface-color);border-radius:12px;box-shadow:var(--rooijakkers-card-shadow);padding:20px;display:flex;align-items:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(63,66,87,.16)}.stat-icon{flex-shrink:0;width:50px;height:50px;border-radius:12px;background-color:var(--rooijakkers-light-pink);color:var(--rooijakkers-red);display:flex;align-items:center;justify-content:center;font-size:24px;margin-right:15px}.stat-content{flex-grow:1}.stat-content h3{font-size:14px;font-weight:500;color:var(--text-secondary);margin:0 0 5px 0}.stat-value{font-size:28px;font-weight:600;color:var(--text-color);margin:0}.dashboard-actions{display:flex;flex-direction:column;gap:12px}.dashboard-action-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:var(--background-color);color:var(--text-color);text-decoration:none;border-radius:8px;border:1px solid var(--border-color);transition:all .2s}.dashboard-action-btn:hover{background-color:var(--surface-color);border-color:var(--rooijakkers-red);color:var(--rooijakkers-red)}.dashboard-action-btn i{font-size:18px;color:var(--rooijakkers-red)}.activities-grid,.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.activity-card{background-color:var(--surface-color);border-radius:12px;overflow:hidden;box-shadow:var(--rooijakkers-card-shadow);transition:transform .2s,box-shadow .2s;position:relative}.activity-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px rgba(0,0,0,.1)}.activity-image{height:80px;max-height:180px;overflow:hidden;position:relative}.activity-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.activity-card:hover .activity-image img{transform:scale(1.05)}.card-badges-left{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;gap:5px;z-index:1}.card-badges-left .activity-type-tag,.card-badges-left .project-status-badge{position:static}.activity-type-tag{position:absolute;top:10px;left:10px;background-color:rgba(0,0,0,.7);color:#fff;padding:5px 10px;border-radius:20px;font-size:12px;font-weight:500}.project-number-badge{position:absolute;top:10px;right:10px;background-color:var(--rooijakkers-red);color:#fff;padding:5px 10px;border-radius:20px;font-size:12px;font-weight:600}.activity-status{position:absolute;top:10px;right:10px}.activity-info{padding:16px}.activity-name,.project-client{font-size:18px;font-weight:600;margin:0 0 10px 0;color:var(--text-color)}.activity-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:15px}.meta-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.meta-item i{color:var(--rooijakkers-red);font-size:15px;width:18px}.activity-capacity{margin-top:10px}.capacity-bar{height:6px;background-color:var(--rooijakkers-light);border-radius:3px;margin-top:5px;overflow:hidden}.capacity-progress{height:100%;background-color:var(--rooijakkers-red);border-radius:3px}.staff-card{position:relative;min-height:200px}.staff-avatar{position:absolute;top:-15px;right:15px;z-index:2}.avatar-img{width:60px;height:60px;border-radius:50%;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.1);background-color:#f8f9fa;object-fit:cover}.activity-header h3{margin-right:70px;line-height:1.2}.card-actions{display:flex;gap:10px;margin-top:15px;flex-wrap:wrap}.card-actions button{flex:1;font-size:.85rem;justify-content:center;padding:.5rem 1rem;border-radius:.25rem;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;transition:background-color .2s;border:1px solid var(--border-color)}.edit-btn{background-color:var(--rooijakkers-light);color:var(--rooijakkers-red);border:1px solid var(--border-color)}.edit-btn:hover{background-color:var(--rooijakkers-light-pink)}.delete-btn{background-color:var(--rooijakkers-light);color:var(--rooijakkers-red);border:1px solid var(--border-color)}.delete-btn:hover{background-color:var(--rooijakkers-light-pink)}.user-management-btn{background-color:var(--rooijakkers-light);color:var(--rooijakkers-red);border:1px solid var(--border-color)}.status-badge{display:inline-block;padding:5px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.confirmed{background-color:var(--rooijakkers-light-green);color:var(--rooijakkers-green)}.status-badge.option{background-color:var(--rooijakkers-light-yellow);color:#f57c00}.form-row{display:flex;gap:16px;margin-bottom:15px}.form-col{flex:1}.full-width{flex-direction:column}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.no-data,.no-results{grid-column:1/-1;text-align:center;padding:40px;background-color:var(--surface-color);border-radius:12px;color:var(--text-secondary);box-shadow:var(--rooijakkers-card-shadow)}.error-message{color:var(--error-color);font-size:12px;margin-top:4px}.required{color:var(--error-color)}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:none;border:0;cursor:pointer;padding:8px;margin-right:8px;border-radius:8px;transition:background-color .2s}.hamburger-btn:hover{background-color:var(--rooijakkers-light)}.hamburger-line{display:block;width:24px;height:3px;background-color:var(--text-color);border-radius:2px;transition:all .3s ease}.hamburger-line+.hamburger-line{margin-top:5px}.hamburger-btn.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,6px)}.hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(6px,-7px)}.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.5);z-index:1001;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-menu-overlay.active{opacity:1;visibility:visible}.mobile-menu{position:fixed;top:0;left:-100%;width:85%;max-width:320px;height:100%;background-color:var(--surface-color);z-index:1002;overflow-y:auto;transition:left .3s ease;box-shadow:2px 0 10px rgba(0,0,0,.1)}.mobile-menu.active{left:0}.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.mobile-menu-header .logo img{height:32px}.mobile-menu-close{background:none;border:0;font-size:24px;color:var(--text-color);cursor:pointer;padding:8px;border-radius:8px;transition:background-color .2s}.mobile-menu-close:hover{background-color:var(--rooijakkers-light)}.mobile-menu-search{padding:16px 20px;border-bottom:1px solid var(--border-color)}.mobile-menu-search .search-form{position:relative}.mobile-menu-search .search-form input{width:100%;padding:12px 40px 12px 44px;border:1px solid var(--border-color);border-radius:8px;font-size:16px;background-color:var(--rooijakkers-light);box-sizing:border-box}.mobile-menu-search .search-clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:0;padding:6px;cursor:pointer;color:var(--text-secondary);display:none;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s}.mobile-menu-search .search-clear-btn:hover{background-color:rgba(0,0,0,.1);color:var(--text-color)}.mobile-menu-search .search-clear-btn.visible{display:flex}.mobile-menu-search .search-form input:focus{outline:0;border-color:var(--rooijakkers-red);box-shadow:0 0 0 3px rgba(204,51,51,.1)}.mobile-menu-search .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-secondary)}.mobile-nav{padding:16px 0}.mobile-nav-links{list-style:none;margin:0;padding:0}.mobile-nav-links li{border-bottom:1px solid var(--border-color)}.mobile-nav-links li:last-child{border-bottom:0}.mobile-nav-links a{display:flex;align-items:center;padding:16px 20px;color:var(--text-color);text-decoration:none;font-size:16px;font-weight:500;transition:background-color .2s,color .2s}.mobile-nav-links a:hover,.mobile-nav-links a.active{background-color:var(--rooijakkers-light-pink);color:var(--rooijakkers-red)}.mobile-nav-links a i{margin-right:12px;font-size:18px;width:24px;text-align:center;color:var(--rooijakkers-red)}.mobile-user-section{border-top:1px solid var(--border-color);margin-top:auto;padding:16px 0}.mobile-user-info{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.mobile-user-info .avatar-placeholder{width:48px;height:48px;border-radius:50%;background-color:var(--rooijakkers-light);display:flex;align-items:center;justify-content:center;color:var(--rooijakkers-red);font-size:20px;margin-right:12px;flex-shrink:0}.mobile-user-details{display:flex;flex-direction:column;overflow:hidden}.mobile-user-name{font-weight:600;color:var(--text-color);font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-user-email{font-size:14px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-user-links{list-style:none;margin:0;padding:0}.mobile-user-links li a{display:flex;align-items:center;padding:14px 20px;color:var(--text-color);text-decoration:none;font-size:15px;transition:background-color .2s}.mobile-user-links li a:hover{background-color:var(--rooijakkers-light)}.mobile-user-links li a i{margin-right:12px;width:20px;text-align:center;color:var(--text-secondary)}.mobile-user-links .mobile-logout-link{color:var(--error-color)}.mobile-user-links .mobile-logout-link i{color:var(--error-color)}.header-search-desktop{display:none}.main-nav{display:none}body.mobile-menu-open{overflow:hidden}@media(min-width:992px){.hamburger-btn{display:none}.mobile-menu,.mobile-menu-overlay{display:none}.main-nav{display:flex}.header-search-desktop{display:block;flex:1;max-width:400px;margin:0 20px}}@media(max-width:1200px){.dashboard-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media(max-width:991px){.goeveni-layout{flex-direction:column}.sidebar-filters{display:none;position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;max-height:85vh;z-index:1002;border-radius:20px 20px 0 0;transform:translateY(100%);transition:transform .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 20px calc(100px + env(safe-area-inset-bottom,0px)) 20px;box-sizing:border-box}.sidebar-filters.active{display:block;transform:translateY(0)}.mobile-filter-toggle{display:flex}.mobile-filter-overlay{display:block}.mobile-filter-header{display:flex;margin:0 -20px;padding:16px 20px}.mobile-filter-handle{display:block}.sidebar-filters .filter-header{display:none}.form-row{flex-direction:column;gap:15px}.header-container{padding:10px 16px}.activities-grid,.items-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media(max-width:768px){.header-container{justify-content:space-between}.user-menu{display:none}.notifications{margin-left:8px}.dashboard-stats{grid-template-columns:1fr;padding:10px}.activities-header,.content-header{flex-direction:column;align-items:flex-start;gap:15px}.add-btn{width:100%;justify-content:center}.notification-dropdown,.user-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:70vh;border-radius:16px 16px 0 0;overflow-y:auto}}@media(max-width:480px){.activities-grid,.items-grid{grid-template-columns:1fr}.goeveni-layout{padding:10px;gap:20px}.stat-card{flex-direction:column;text-align:center}.stat-icon{margin-right:0;margin-bottom:10px}.header-left .logo img{height:32px}.notification-btn,.user-avatar{width:36px;height:36px}}.login-form{margin-top:20px}.btn-large{padding:12px 30px;font-size:16px;font-weight:500;border-radius:8px;border:0;cursor:pointer;transition:all .3s ease;width:100%}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px;box-sizing:border-box}.login-card{background:#fff;padding:40px;border-radius:10px;box-shadow:0 15px 35px rgba(0,0,0,.1);width:100%;max-width:400px;text-align:center}.login-header h2{margin:0 0 10px 0;color:#333;font-size:28px;font-weight:600}.login-header p{margin:0 0 30px 0;color:#666;font-size:16px}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.form-control{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:6px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.form-control:focus{outline:0;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.login-buttons{margin:30px 0 20px 0}.btn{padding:12px 24px;border:0;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5a67d8;transform:translateY(-2px);box-shadow:0 5px 15px rgba(102,126,234,.4)}.btn-secondary{background:#f8f9fa;color:#495057;border:2px solid #dee2e6}.btn-secondary:hover:not(:disabled){background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.btn-block{width:100%;margin-bottom:10px}.btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:20px;padding-top:20px;border-top:1px solid #e1e5e9}.login-footer a{color:#667eea;text-decoration:none;font-size:14px}.login-footer a:hover{text-decoration:underline}.spinner{display:inline-block;width:16px;height:16px;border:2px solid #ffffff3d;border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.login-card{padding:30px 20px}.login-header h2{font-size:24px}}.home-dashboard-layout{padding:20px;max-width:1400px;margin:0 auto;background-color:var(--background-color);min-height:100vh}.home-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:30px}.home-metric-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px rgba(0,0,0,.1);display:flex;align-items:center;transition:transform .3s ease,box-shadow .3s ease}.home-metric-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.home-metric-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-right:20px}.home-metric-card.primary .home-metric-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.home-metric-card.secondary .home-metric-icon{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.home-metric-card.success .home-metric-icon{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.home-metric-card.warning .home-metric-icon{background:linear-gradient(135deg,#f7971e,#ffd200);color:#fff}.home-metric-content{flex:1}.home-metric-value{font-size:32px;font-weight:700;color:var(--text-color);line-height:1}.home-metric-label{font-size:14px;color:var(--text-secondary);margin:4px 0;font-weight:500}.home-metric-change{font-size:12px;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-block}.home-metric-change.positive{background:#e8f5e8;color:#2e7d32}.home-metric-change.negative{background:#ffebee;color:#c62828}.home-analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,400px),1fr));gap:20px;margin-bottom:30px}.home-analytics-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px rgba(0,0,0,.1);max-width:100%;overflow:hidden}.home-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid #f0f0f0;padding-bottom:15px}.home-card-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-color)}.home-period{font-size:14px;color:var(--text-secondary);background:#f8f9fa;padding:4px 12px;border-radius:6px}.home-view-all{color:#667eea;text-decoration:none;font-size:14px;font-weight:500}.home-view-all:hover{text-decoration:underline}.home-chart-container{position:relative;height:200px}.home-performers-list,.home-activities-list{max-height:200px;overflow-y:auto}.home-performer-item,.home-activity-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.home-performer-item:last-child,.home-activity-item:last-child{border-bottom:0}.home-performer-info,.home-activity-info{display:flex;align-items:center;gap:12px}.home-performer-avatar,.home-activity-icon{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.home-performer-details,.home-activity-details{flex:1}.home-performer-name,.home-activity-title{font-weight:600;color:var(--text-color);margin:0;font-size:14px}.home-performer-role,.home-activity-time{font-size:12px;color:var(--text-secondary);margin:2px 0 0 0}.home-performer-hours,.home-activity-status{font-weight:600;font-size:14px}.home-quick-actions,.home-project-summary{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px rgba(0,0,0,.1)}.home-quick-actions h3,.home-project-summary h3{margin:0 0 20px 0;font-size:18px;font-weight:600;color:var(--text-color)}.home-action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.home-action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:8px;border:0;cursor:pointer;text-decoration:none;font-weight:500;font-size:14px;transition:all .3s ease;color:#fff}.home-action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.home-action-btn.secondary{background:linear-gradient(135deg,#f093fb,#f5576c)}.home-action-btn.success{background:linear-gradient(135deg,#4facfe,#00f2fe)}.home-action-btn.warning{background:linear-gradient(135deg,#f7971e,#ffd200)}.home-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.home-project-status-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0f0f0}.home-project-status-item:last-child{border-bottom:0}.home-project-info h4{margin:0;font-size:14px;font-weight:600;color:var(--text-color)}.home-project-meta{font-size:12px;color:var(--text-secondary);margin:2px 0 0 0}.home-project-progress{text-align:right}.home-progress-bar{width:80px;height:6px;background:#f0f0f0;border-radius:3px;margin:4px 0;overflow:hidden}.home-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .3s ease}.home-progress-text{font-size:12px;font-weight:600;color:var(--text-color)}@media(max-width:992px){.home-analytics-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media(max-width:768px){.home-dashboard-layout{padding:15px}.home-metrics-grid{grid-template-columns:1fr;gap:15px;margin-bottom:20px}.home-metric-card{padding:16px}.home-metric-icon{width:48px;height:48px;font-size:20px;margin-right:14px}.home-metric-value{font-size:26px}.home-metric-label{font-size:13px}.home-analytics-grid{grid-template-columns:1fr;gap:15px;margin-bottom:20px}.home-analytics-card{padding:16px}.home-card-header{flex-direction:column;align-items:flex-start;gap:10px;padding-bottom:12px;margin-bottom:15px}.home-card-header h3{font-size:16px}.home-card-actions select{width:100%}.home-chart-container{height:180px;overflow-x:auto}.home-chart-container canvas{min-width:300px}.home-action-buttons{grid-template-columns:1fr 1fr;gap:10px}.home-action-btn{padding:10px 12px;font-size:12px;flex-direction:column;gap:4px}.home-quick-actions,.home-project-summary{padding:16px}.home-quick-actions h3,.home-project-summary h3{font-size:16px;margin-bottom:15px}.home-performer-item,.home-activity-item{padding:10px 0}.home-performer-avatar,.home-activity-icon{width:32px;height:32px;font-size:12px}.home-performer-name,.home-activity-title{font-size:13px}.home-performer-role,.home-activity-time{font-size:11px}.home-project-status-item{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 0}.home-project-progress{width:100%;display:flex;align-items:center;gap:10px}.home-progress-bar{flex:1;width:auto}}@media(max-width:480px){.home-dashboard-layout{padding:10px}.home-metric-card{padding:14px}.home-metric-icon{width:40px;height:40px;font-size:18px;margin-right:12px}.home-metric-value{font-size:22px}.home-action-buttons{grid-template-columns:1fr}.home-action-btn{flex-direction:row;justify-content:center}.home-chart-container{height:160px}.home-performers-list,.home-activities-list{max-height:180px}}.card-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:4rem}.card-icon i{opacity:.9;transition:transform .3s ease,opacity .3s ease}.activity-card:hover .card-icon i{transform:scale(1.1);opacity:1}.certificate-type-icon{background:linear-gradient(135deg,var(--rooijakkers-red) 0%,#8b0000 100%)}.staff-icon{background:linear-gradient(135deg,#3b82f6 0%,#1e40af 100%)}.cost-icon{background:linear-gradient(135deg,#10b981 0%,#047857 100%)}.timetracking-icon{background:linear-gradient(135deg,#f59e0b 0%,#b45309 100%)}.project-icon{background:linear-gradient(135deg,#8b5cf6 0%,#5b21b6 100%)}.activity-image:has(.project-map){height:initial;min-height:80px}.project-map{width:100%;height:100%;min-height:180px;background:linear-gradient(135deg,#e8f4f8 0%,#d1e7dd 100%)}.project-map .leaflet-container{width:100%;height:100%}.map-fallback{width:100%;height:100%;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf6 0%,#5b21b6 100%);color:#fff;text-align:center;padding:1rem}.map-fallback i{font-size:3rem;margin-bottom:.5rem;opacity:.9}.map-fallback span{font-size:.9rem;opacity:.9;max-width:90%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.certificates-section{margin:.75rem 0;padding-top:.75rem;border-top:1px solid #e5e7eb}.certificates-badges{display:flex;flex-wrap:wrap;gap:.5rem}.certificate-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.certificate-badge i{font-size:.7rem}.cert-valid{background-color:#d1fae5;color:#065f46}.cert-expiring{background-color:#fef3c7;color:#92400e}.cert-expired{background-color:#fee2e2;color:#991b1b}.no-certificates{color:#9ca3af;font-size:.85rem;font-style:italic}.no-certificates i{margin-right:.25rem}.certificate-btn{background-color:#8b5cf6;color:#fff;border:0}.certificate-btn:hover{background-color:#7c3aed}.modal-lg{max-width:600px}.modal-body{padding:1rem}.modal-divider{margin:1.5rem 0;border:0;border-top:1px solid #e5e7eb}.certificate-list-container h3,.add-certificate-section h3{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:#374151}.certificate-list{display:flex;flex-direction:column;gap:.5rem;max-height:200px;overflow-y:auto}.certificate-list-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:.375rem;background-color:#f9fafb;border-left:4px solid}.certificate-list-item.cert-valid{border-left-color:#10b981;background-color:#f0fdf4}.certificate-list-item.cert-expiring{border-left-color:#f59e0b;background-color:#fffbeb}.certificate-list-item.cert-expired{border-left-color:#ef4444;background-color:#fef2f2}.cert-info{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.cert-name{font-weight:500;color:#1f2937}.cert-name i{color:#8b5cf6;margin-right:.25rem}.cert-dates{font-size:.8rem;color:#6b7280}.cert-dates i{margin-right:.25rem}.cert-status{font-size:.9rem}.cert-status i{vertical-align:middle}.delete-cert-btn{background:none;border:0;color:#ef4444;cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background-color .2s}.delete-cert-btn:hover{background-color:#fee2e2}.no-items{color:#9ca3af;font-style:italic;text-align:center;padding:1rem}.add-certificate-section{background-color:#f9fafb;padding:1rem;border-radius:.375rem}.project-status-badge{position:absolute;bottom:10px;left:10px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-open{background:#ffc107;color:#000}.status-progress{background:#17a2b8;color:#fff}.status-completed{background:#28a745;color:#fff}.project-progress-container{width:100%;margin:12px 0;padding:12px;background:var(--rooijakkers-light-gray,#f5f5f5);border-radius:8px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-label{font-size:13px;font-weight:600;color:var(--text-color,#2c3e50)}.progress-percentage{font-size:13px;font-weight:700;color:var(--text-color,#2c3e50)}.progress-bar-wrapper{width:100%;height:12px;background:#e0e0e0;border-radius:6px;overflow:hidden}.progress-bar{display:flex;height:100%;border-radius:6px;overflow:hidden}.progress-segment{height:100%;transition:width .3s ease}.progress-invoiced{background:linear-gradient(90deg,#28a745,#20c997)}.progress-billing{background:linear-gradient(90deg,#17a2b8,#6f42c1)}.progress-bar.progress-warning .progress-invoiced{background:linear-gradient(90deg,#ffc107,#fd7e14)}.progress-bar.progress-warning .progress-billing{background:linear-gradient(90deg,#fd7e14,#e83e8c)}.progress-bar.progress-danger .progress-invoiced{background:linear-gradient(90deg,#dc3545,#c82333)}.progress-bar.progress-danger .progress-billing{background:linear-gradient(90deg,#c82333,#a71d2a)}.progress-legend{display:flex;gap:16px;margin-top:8px;font-size:11px;color:var(--text-secondary,#6c757d)}.legend-item{display:flex;align-items:center;gap:4px}.legend-color{width:12px;height:12px;border-radius:3px}.legend-invoiced{background:linear-gradient(90deg,#28a745,#20c997)}.legend-billing{background:linear-gradient(90deg,#17a2b8,#6f42c1)}.progress-amounts{display:flex;justify-content:space-between;gap:12px;margin-top:10px;padding:10px 12px;background-color:var(--background-color,#f8f9fa);border-radius:6px;font-size:12px}.amount-item{display:flex;flex-direction:column;gap:2px}.amount-label{color:var(--text-secondary,#6c757d);font-weight:500}.amount-value{color:var(--text-color,#2c3e50);font-weight:600}.amount-over-budget{color:#dc3545}.success-message-container,.error-message-container{position:fixed;top:80px;right:20px;z-index:9999;max-width:400px;animation:slideInRight .3s ease-out}@keyframes slideInRight{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes fadeOut{from{opacity:1}to{opacity:0;transform:translateX(100%)}}.success-message-container .success-message,.error-message-container .error-message{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);font-size:14px;font-weight:500}.success-message-container .success-message{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.success-message-container .success-message i{color:#28a745;font-size:18px}.error-message-container .error-message{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.error-message-container .error-message i{color:#dc3545;font-size:18px}.success-message-container .success-message span,.error-message-container .error-message span{flex:1}.success-message-container .success-message button,.error-message-container .error-message button{background:none;border:0;font-size:20px;cursor:pointer;padding:0;line-height:1;opacity:.6;transition:opacity .2s}.success-message-container .success-message button:hover,.error-message-container .error-message button:hover{opacity:1}.success-message-container .success-message button{color:#155724}.error-message-container .error-message button{color:#721c24}.emp-main-content{max-width:1200px;margin:0 auto;padding:24px 20px}.welcome-section{margin-bottom:24px}.welcome-section h2{font-size:24px;font-weight:700;color:var(--rooijakkers-text);margin-bottom:4px}.welcome-section p{font-size:14px;color:var(--rooijakkers-text-light)}.metrics-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.metric-card{background:var(--rooijakkers-white);border-radius:12px;padding:18px;box-shadow:var(--rooijakkers-card-shadow);display:flex;align-items:center;gap:14px;transition:transform .2s}.metric-card:hover{transform:translateY(-2px)}.metric-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.metric-icon.red{background:var(--rooijakkers-light-red);color:var(--rooijakkers-red)}.metric-icon.blue{background:var(--rooijakkers-light-blue);color:var(--rooijakkers-secondary)}.metric-icon.green{background:var(--rooijakkers-light-green);color:#27ae60}.metric-icon.yellow{background:var(--rooijakkers-light-yellow);color:#f0a500}.metric-value{font-size:26px;font-weight:700;color:var(--rooijakkers-text);line-height:1.1}.metric-label{font-size:12px;color:var(--rooijakkers-text-light);margin-top:2px}.section-card{background:var(--rooijakkers-white);border-radius:12px;box-shadow:var(--rooijakkers-card-shadow);margin-bottom:20px;overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color,#dee2e6);gap:12px}.section-header h3{font-size:16px;font-weight:600;color:var(--rooijakkers-text);display:flex;align-items:center;gap:8px}.section-header h3 i{color:var(--rooijakkers-red);font-size:15px}.section-body{padding:20px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}.project-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}.project-assign-card{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid var(--border-color,#dee2e6);border-radius:10px;transition:all .2s}.project-assign-card:hover{border-color:var(--rooijakkers-red);box-shadow:0 2px 8px rgba(204,51,51,.1)}.project-color{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.project-assign-info h4{font-size:13px;font-weight:600;color:var(--rooijakkers-text);margin-bottom:2px}.project-assign-meta{font-size:11px;color:var(--rooijakkers-text-light)}.activity-list{list-style:none}.activity-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid #f0f0f0}.activity-item:last-child{border-bottom:0}.activity-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.activity-icon.clock{background:var(--rooijakkers-light-blue);color:var(--rooijakkers-secondary)}.activity-icon.check{background:var(--rooijakkers-light-green);color:#27ae60}.activity-icon.alert{background:var(--rooijakkers-light-yellow);color:#f0a500}.activity-text{font-size:13px;color:var(--rooijakkers-text)}.activity-text strong{font-weight:600}.activity-time{font-size:11px;color:var(--rooijakkers-text-light);margin-top:2px}.hours-chart{display:flex;align-items:flex-end;gap:8px;height:120px;padding-top:10px}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.chart-bar{width:100%;max-width:48px;border-radius:6px 6px 0 0;transition:height .3s}.chart-bar-label{font-size:11px;color:var(--rooijakkers-text-light);font-weight:500}.chart-bar-value{font-size:12px;font-weight:600;color:var(--rooijakkers-text)}.loading-state{padding:20px;text-align:center;color:var(--rooijakkers-text-light);font-size:13px}@media(max-width:991px){.two-col{grid-template-columns:1fr}.metrics-row{grid-template-columns:repeat(2,1fr);gap:12px}.project-list{grid-template-columns:1fr 1fr}}@media(max-width:599px){.emp-main-content{padding:16px 12px}.welcome-section h2{font-size:20px}.metrics-row{gap:10px;margin-bottom:16px}.metric-card{padding:14px;gap:10px}.metric-icon{width:40px;height:40px;font-size:16px}.metric-value{font-size:22px}.project-list{grid-template-columns:1fr}.section-body{padding:16px}}.week-nav-btn{background:none;border:1px solid var(--border-color);border-radius:8px;padding:6px 12px;cursor:pointer;color:var(--rooijakkers-text);font-size:13px;transition:all .2s}.week-nav-btn:hover:not(:disabled){border-color:var(--rooijakkers-red);color:var(--rooijakkers-red)}.week-nav-btn:disabled{opacity:.35;cursor:default}.week-label{font-size:13px;font-weight:600;color:var(--text-color);white-space:nowrap}.project-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.day-card{background:var(--surface-color);border-radius:12px;box-shadow:var(--rooijakkers-card-shadow);margin-bottom:12px;overflow:hidden}.day-card-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--rooijakkers-light-gray);border-bottom:1px solid var(--border-color)}.day-card-title{font-size:15px;font-weight:700;color:var(--text-color)}.day-card-total{font-size:14px;font-weight:600;color:var(--rooijakkers-red)}.day-card-total.complete{color:var(--success-color)}.day-card-entry{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid #f5f5f5}.day-card-entry:last-child{border-bottom:0}.day-card-entry-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.day-card-entry-info{min-width:0}.day-card-project-name{font-size:14px;font-weight:600;color:var(--text-color)}.day-card-project-note{font-size:12px;color:var(--text-secondary);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-card-hours{font-size:20px;font-weight:700;color:var(--rooijakkers-red);flex-shrink:0;margin-left:12px}.day-card-empty{padding:20px 18px;text-align:center;color:var(--rooijakkers-text-light);font-size:13px;font-style:italic}.day-card-delete-btn{background:none;border:0;color:var(--text-secondary);cursor:pointer;padding:4px 6px;border-radius:6px;font-size:13px;margin-left:8px;flex-shrink:0;transition:color .2s,background .2s}.day-card-delete-btn:hover{color:var(--rooijakkers-red);background:var(--rooijakkers-light-red)}.week-summary{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--rooijakkers-light-gray);gap:12px;flex-wrap:wrap}.week-summary-left{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.summary-item{display:flex;align-items:center;gap:8px;font-size:13px}.summary-item .label{color:var(--text-secondary)}.summary-item .value{font-weight:700;color:var(--text-color)}.fab-btn{position:fixed;bottom:90px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--rooijakkers-red);color:#fff;border:0;font-size:24px;cursor:pointer;box-shadow:0 4px 16px rgba(204,51,51,.4);z-index:999;display:flex;align-items:center;justify-content:center;transition:all .2s}.fab-btn:hover{transform:scale(1.08);box-shadow:0 6px 20px rgba(204,51,51,.5)}.fab-btn:active{transform:scale(.95)}.fab-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:1100;align-items:flex-end;justify-content:center}.fab-modal-overlay.open{display:flex}.fab-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:500px;padding:24px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));animation:slideUp .3s ease}@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}.fab-modal-handle{width:40px;height:4px;background:var(--border-color);border-radius:2px;margin:0 auto 16px}.fab-modal h3{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--text-color)}.fab-form-group{margin-bottom:14px}.fab-form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.fab-form-group select,.fab-form-group input,.fab-form-group textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:10px;font-size:15px;font-family:inherit;color:var(--text-color);background:#fff;box-sizing:border-box}.fab-form-group select:focus,.fab-form-group input:focus,.fab-form-group textarea:focus{outline:0;border-color:var(--rooijakkers-red);box-shadow:0 0 0 3px rgba(204,51,51,.1)}.fab-form-row{display:flex;gap:12px}.fab-form-row .fab-form-group{flex:1}.fab-submit-btn{width:100%;padding:14px;background:var(--rooijakkers-red);color:#fff;border:0;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;margin-top:4px;transition:background .2s}.fab-submit-btn:hover{background:var(--rooijakkers-dark-red)}.fab-submit-btn:disabled{opacity:.6;cursor:default}@media(max-width:599px){.fab-btn{bottom:calc(var(--bottom-nav-height,70px) + 16px)}}.eo-filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.eo-filter-select,.eo-filter-input{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:13px;color:var(--text-color);background:#fff;font-family:inherit}.eo-filter-select:focus,.eo-filter-input:focus{outline:0;border-color:var(--rooijakkers-red);box-shadow:0 0 0 3px rgba(204,51,51,.08)}.eo-filter-input{flex:1;min-width:140px}.eo-table{width:100%;border-collapse:collapse;font-size:14px}.eo-table th{padding:10px 14px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);border-bottom:2px solid #f0f0f0;white-space:nowrap}.eo-table td{padding:12px 14px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.eo-table tbody tr:last-child td{border-bottom:0}.eo-table tbody tr:hover{background:#fafafa}.eo-desc-cell{color:var(--text-secondary);font-size:13px;max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.eo-status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;white-space:nowrap}.eo-status-badge.approved{background:var(--rooijakkers-light-green);color:#27ae60}.eo-status-badge.pending{background:var(--rooijakkers-light-yellow);color:#f0a500}.eo-status-badge.rejected{background:var(--rooijakkers-light-red);color:var(--rooijakkers-red)}.eo-status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}.eo-status-dot.approved{background:#27ae60}.eo-status-dot.pending{background:#f0a500}.eo-status-dot.rejected{background:var(--rooijakkers-red)}.eo-mobile-card{padding:14px 0;border-bottom:1px solid #f0f0f0}.eo-mobile-card:last-child{border-bottom:0}.eo-mobile-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.eo-mobile-project{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--text-color)}.eo-mobile-hours{font-size:18px;font-weight:700;color:var(--rooijakkers-red)}.eo-mobile-desc{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.eo-mobile-bottom{display:flex;justify-content:space-between;align-items:center}.eo-mobile-date{font-size:12px;color:var(--text-secondary)}.eo-desktop-only{display:block}.eo-mobile-only{display:none}.eo-pagination{display:flex;justify-content:space-between;align-items:center;padding-top:16px;font-size:13px;color:var(--text-secondary);flex-wrap:wrap;gap:10px}.eo-pagination-btns{display:flex;gap:8px}.eo-pagination-btn{padding:6px 14px;border:1px solid var(--border-color);border-radius:8px;background:#fff;cursor:pointer;font-size:13px;color:var(--text-color);font-family:inherit;transition:all .2s}.eo-pagination-btn:hover:not(:disabled){border-color:var(--rooijakkers-red);color:var(--rooijakkers-red)}.eo-pagination-btn:disabled{opacity:.35;cursor:default}@media(max-width:767px){.eo-desktop-only{display:none}.eo-mobile-only{display:block}.eo-filter-bar{gap:8px}}