.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}.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}.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}