@import"https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--blue: #1a56db;--blue-dark: #1e429f;--blue-light: #ebf5ff;--blue-mid: #3f83f8;--dark: #0d1117;--dark2: #161b22;--dark3: #1c2333;--sidebar-w: 220px;--sidebar-w-closed: 64px;--topbar-h: 56px;--text: #111928;--muted: #6b7280;--border: #e5e7eb;--surface: #f9fafb;--success: #057a55;--success-bg: #d1fae5;--warn: #d97706;--warn-bg: #fef3c7;--danger: #e02424;--danger-bg: #fde8e8;--radius: 10px;--radius-lg: 14px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Sora,sans-serif;font-size:14px;color:var(--text);background:#f0f2f7;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select,textarea{font-family:inherit;font-size:14px}a{color:var(--blue);text-decoration:none}code{font-family:JetBrains Mono,monospace;font-size:12px;background:#f3f4f6;padding:2px 6px;border-radius:4px;color:var(--blue-dark)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;min-height:100vh}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left .25s ease}.main-area.sidebar-open{margin-left:var(--sidebar-w)}.main-area.sidebar-closed{margin-left:var(--sidebar-w-closed)}.page-content{flex:1;overflow:auto}.sidebar{position:fixed;top:0;left:0;bottom:0;background:var(--dark);display:flex;flex-direction:column;z-index:100;transition:width .25s ease;overflow:hidden}.sidebar.open{width:var(--sidebar-w)}.sidebar.closed{width:var(--sidebar-w-closed)}.sidebar-logo{padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}@media (max-width: 768px){.sidebar-overlay{display:block}.sidebar{z-index:100}.main-area.sidebar-open,.main-area.sidebar-closed{margin-left:0!important}.sidebar.closed{width:0;overflow:hidden}.sidebar.open{width:var(--sidebar-w);box-shadow:4px 0 20px #0000004d}}.login-logo{width:200px}.login-brand{display:flex;align-items:center;gap:14px}.login-logo-icon{width:64px;height:64px;border-radius:14px;flex-shrink:0}.login-brand-tekst{display:flex;flex-direction:column;gap:2px}.login-brand-naam{color:#fff;font-size:22px;font-weight:700;letter-spacing:.2px;line-height:1.2}.login-brand-sub{color:#ffffff59;font-size:11px;letter-spacing:.3px}.logo-wrap{display:flex;align-items:center;gap:10px}.logo-tekst{display:flex;flex-direction:column;gap:1px}.logo-naam{color:#fff;font-size:15px;font-weight:700;letter-spacing:.2px;line-height:1.2}.logo-sub{color:#ffffff4d;font-size:9px;letter-spacing:.4px;white-space:nowrap}.sidebar-logo-icon{width:52px;height:52px;border-radius:10px;display:block;flex-shrink:0}.sidebar-logo-icon-mini{width:42px;height:42px;border-radius:8px;display:block;margin:0 auto}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-group{margin-bottom:4px}.nav-section-label{padding:10px 16px 3px;color:#fff3;font-size:9px;text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:#ffffff73;font-size:13px;border-left:3px solid transparent;border-radius:0;width:100%;transition:all .15s;white-space:nowrap}.nav-item i{font-size:16px;flex-shrink:0}.nav-item:hover{color:#fffc;background:#ffffff0a}.nav-item.active{color:#fff;background:#1a56db2e;border-left-color:var(--blue-mid)}.nav-label{flex:1;text-align:left}.nav-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;line-height:1.2}.sidebar-footer{padding:12px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.user-card{display:flex;align-items:center;gap:10px;margin-bottom:8px}.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.user-name{color:#fff;font-size:12px;font-weight:500;white-space:nowrap}.user-role{color:#ffffff59;font-size:10px}.logout-btn{display:flex;align-items:center;gap:8px;color:#ffffff59;font-size:12px;padding:6px 4px;width:100%;transition:color .15s}.logout-btn:hover{color:#ffffffb3}.logout-btn i{font-size:15px}.topbar{height:var(--topbar-h);background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:12px;position:sticky;top:0;z-index:50}.topbar-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.toggle-btn{color:var(--muted);font-size:20px;display:flex;padding:4px;border-radius:6px}.toggle-btn:hover{background:var(--surface)}.topbar-title h1{font-size:15px;font-weight:600;color:var(--text);line-height:1.2}.topbar-date{font-size:11px;color:var(--muted)}.topbar-right{display:flex;align-items:center;gap:8px}.tb-action-btn{display:flex;align-items:center;gap:6px;background:var(--blue);color:#fff;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:500}.tb-action-btn:hover{background:var(--blue-dark)}.icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:18px;color:var(--muted);border:1px solid var(--border)}.icon-btn:hover{background:var(--surface);color:var(--text)}.icon-btn.sm{width:28px;height:28px;font-size:15px;border-radius:6px}.icon-btn.danger:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.notif-wrap,.notif-btn{position:relative}.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid #fff}.notif-dropdown{position:absolute;right:0;top:calc(100% + 8px);width:320px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;z-index:200}.notif-header{padding:12px 16px;font-weight:600;font-size:13px;border-bottom:1px solid var(--border)}.notif-item{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid #f9fafb}.notif-item.unread{background:#f0f7ff}.notif-icon{font-size:16px;color:var(--blue);margin-top:2px}.notif-text{font-size:12px;color:var(--text);line-height:1.4;margin-bottom:3px}.notif-time{font-size:11px;color:var(--muted)}.tb-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600}.login-shell{display:flex;min-height:100vh}.login-left{width:440px;background:var(--dark);padding:48px;display:flex;flex-direction:column;justify-content:space-between;flex-shrink:0}.login-brand{margin-bottom:0}.login-hero h2{color:#fff;font-size:28px;font-weight:500;line-height:1.3;margin-bottom:12px}.login-hero p{color:#ffffff73;font-size:14px;line-height:1.7}.login-features{display:flex;flex-direction:column;gap:10px}.login-feature{display:flex;align-items:center;gap:10px;color:#ffffff73;font-size:13px}.login-feature i{color:var(--blue-mid);font-size:16px}.login-version{color:#fff3;font-size:11px}.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#f0f2f7}.login-form-wrap{background:#fff;border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}.login-form-wrap h3{font-size:22px;font-weight:600;margin-bottom:4px}.login-sub{color:var(--muted);font-size:13px;margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:12px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.4px}.req{color:var(--danger)}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap>i{position:absolute;left:12px;font-size:16px;color:var(--muted);pointer-events:none}.input-wrap input{padding-left:38px!important;padding-right:38px!important}.input-wrap select{padding-left:38px!important}input:not([type=submit]):not([type=checkbox]):not([type=radio]):not([type=file]):not([type=button]):not([type=image]):not([type=reset]):not([type=range]):not([type=hidden]),select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}input:not([type=submit]):not([type=checkbox]):not([type=radio]):not([type=file]):not([type=button]):not([type=image]):not([type=reset]):not([type=range]):not([type=hidden]):focus,select:focus,textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px #1a56db1a}textarea{resize:vertical;line-height:1.5}.login-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fca5a5;border-radius:8px;padding:10px 12px;font-size:13px;display:flex;align-items:center;gap:8px}.login-btn{width:100%;padding:12px;background:var(--blue);color:#fff;border-radius:8px;font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}.login-btn:hover:not(:disabled){background:var(--blue-dark)}.login-btn:disabled{opacity:.7}.login-options{display:flex;justify-content:space-between;align-items:center;margin-top:-4px}.remember-check{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none}.remember-check input[type=checkbox]{width:15px;height:15px;accent-color:var(--blue);cursor:pointer;flex-shrink:0}.forgot-link{font-size:12px;color:var(--blue)}.forgot-link:hover{text-decoration:underline}.pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:16px;padding:4px;display:flex;align-items:center;background:none;border:none;cursor:pointer}.pw-toggle:hover{color:var(--text)}.login-footer{text-align:center;color:var(--muted);font-size:11px;margin-top:24px}.gebruiker-keuze{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}.gebruiker-optie{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.gebruiker-optie:hover,.gebruiker-optie.actief{border-color:var(--blue);background:var(--blue-light)}.gebruiker-optie .ti-check{margin-left:auto;color:var(--blue);font-size:15px}.gebruiker-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}.gebruiker-naam{font-size:13px;font-weight:500;color:var(--text)}.page-wrap{padding:20px;display:flex;flex-direction:column;gap:16px}.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bulk-balk{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:var(--blue-light);border:1.5px solid #bfdbfe;border-radius:10px}.bulk-telling{font-size:13px;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:6px}.primary-btn{display:flex;align-items:center;gap:6px;background:var(--blue);color:#fff;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500;transition:background .15s;white-space:nowrap}.primary-btn:hover:not(:disabled){background:var(--blue-dark)}.primary-btn:disabled{opacity:.6}.secondary-btn{display:flex;align-items:center;gap:6px;background:#fff;color:var(--text);padding:9px 16px;border-radius:8px;font-size:13px;border:1px solid var(--border);transition:background .15s;white-space:nowrap}.secondary-btn:hover{background:var(--surface)}.secondary-btn.sm{padding:6px 12px;font-size:12px}.secondary-btn.export-btn.excel{color:var(--success);border-color:#6ee7b7}.secondary-btn.export-btn.pdf{color:var(--danger);border-color:#fca5a5}.filter-tabs{display:flex;gap:0;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.filter-tab{padding:7px 14px;font-size:12px;font-weight:500;color:var(--muted);border-right:1px solid var(--border);display:flex;align-items:center;gap:6px;transition:all .15s}.filter-tab:last-child{border-right:none}.filter-tab:hover{background:var(--surface)}.filter-tab.active{background:var(--blue-light);color:var(--blue)}.tab-count{background:var(--border);color:var(--muted);font-size:10px;padding:1px 5px;border-radius:10px;line-height:1.4}.filter-tab.active .tab-count{background:var(--blue);color:#fff}.search-wrap{position:relative;flex:1;max-width:320px}.search-wrap i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:15px;pointer-events:none}.search-wrap input{padding-left:34px!important}.view-toggle{display:flex;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.view-toggle button{padding:8px 10px;color:var(--muted);font-size:16px;border-right:1px solid var(--border)}.view-toggle button:last-child{border-right:none}.view-toggle button:hover{background:var(--surface)}.view-toggle button.active{background:var(--blue-light);color:var(--blue)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.kpi-card{background:#fff;border-radius:var(--radius-lg);padding:18px;border:1px solid var(--border);display:flex;gap:14px;align-items:flex-start;box-shadow:var(--shadow)}.kpi-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.kpi-body{flex:1;min-width:0}.kpi-label{font-size:12px;color:var(--muted);margin-bottom:4px}.kpi-value{font-size:24px;font-weight:600;color:var(--text);line-height:1.2;margin-bottom:4px}.kpi-trend{font-size:11px;color:var(--muted)}.kpi-trend.up{color:var(--success)}.kpi-trend.warn{color:var(--warn)}.card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:14px;font-weight:600;color:var(--text)}.card-link{font-size:12px;color:var(--blue)}.card-link:hover{text-decoration:underline}.status-pill{font-size:11px;font-weight:500;padding:4px 10px;border-radius:20px;white-space:nowrap}.status-pill.lg{font-size:13px;padding:6px 16px}.bar-chart{display:flex;align-items:flex-end;gap:8px;padding:16px 20px 8px;height:160px}.bar-chart.tall{height:200px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.bar-val{font-size:10px;font-weight:600;color:var(--muted)}.bar-track{flex:1;width:100%;background:#f3f4f6;border-radius:4px 4px 0 0;position:relative;overflow:hidden}.bar-fill{position:absolute;bottom:0;left:0;right:0;background:var(--blue);border-radius:4px 4px 0 0;transition:height .5s ease}.bar-fill.empty{background:#e5e7eb}.bar-fill.accent{background:var(--blue-dark)}.bar-day{font-size:10px;color:var(--muted);white-space:nowrap}.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.proj-list{display:flex;flex-direction:column}.proj-row{display:flex;align-items:center;gap:10px;padding:10px 20px;border-bottom:1px solid #f9fafb;cursor:pointer;transition:background .1s}.proj-row:last-child{border-bottom:none}.proj-row:hover{background:var(--surface)}.proj-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.proj-info{flex:1;min-width:0}.proj-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-client{font-size:11px;color:var(--muted)}.proj-uren{font-size:13px;font-weight:600;color:var(--text);margin-right:8px}.approval-list{display:flex;flex-direction:column;gap:8px;padding:16px 20px}.appr-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border-radius:10px;border:1px solid var(--border)}.appr-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;flex-shrink:0}.appr-info{flex:1;min-width:0}.appr-name{font-size:13px;font-weight:500;color:var(--text)}.appr-detail{font-size:11px;color:var(--muted)}.appr-opmerking{font-size:11px;color:var(--text);margin-top:3px;display:flex;align-items:flex-start;gap:4px;font-style:italic;white-space:pre-line}.appr-opmerking i{font-size:12px;color:var(--muted);flex-shrink:0;margin-top:1px}.appr-hours{font-size:14px;font-weight:600;color:var(--text)}.appr-actions,.action-btns{display:flex;gap:6px}.appr-btn{width:30px;height:30px;border-radius:7px;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}.appr-btn.ok{border-color:#6ee7b7;color:var(--success);background:var(--success-bg)}.appr-btn.ok:hover{background:#a7f3d0}.appr-btn.nok{border-color:#fca5a5;color:var(--danger);background:var(--danger-bg)}.appr-btn.nok:hover{background:#fecaca}.appr-btn.wide{width:auto;padding:6px 14px;font-size:12px;display:flex;align-items:center;gap:5px}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:600px}.data-table th{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 14px;border-bottom:2px solid var(--border);text-align:left;white-space:nowrap;background:var(--surface)}.data-table td{padding:11px 14px;border-bottom:1px solid #f3f4f6;font-size:13px;color:var(--text);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#fafbff}.td-user{display:flex;align-items:center;gap:8px}.td-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:600;flex-shrink:0}.td-avatar.sm{width:22px;height:22px;font-size:9px}.td-main{font-weight:500}.td-sub{font-size:11px;color:var(--muted)}.overuur-chip{background:#fde8e8;color:var(--danger);font-size:10px;padding:2px 6px;border-radius:8px;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:620px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal.sm{max-width:440px}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2;background:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-head h2{font-size:17px;font-weight:600}.modal-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:18px}.modal-close:hover{background:var(--surface);color:var(--text)}.modal-form{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--border);position:sticky;bottom:0;z-index:2;background:#fff;margin:8px -24px -24px;padding:14px 24px 20px}.keur-balk{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:8px;margin:0 -24px}.keur-label{font-size:12px;font-weight:600;color:var(--success);display:flex;align-items:center;gap:5px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row.three{grid-template-columns:1fr 1fr 1fr}.uren-calc{display:flex;align-items:center;gap:10px;background:#ebf5ff;color:var(--blue-dark);border:1px solid #bfdbfe;border-radius:8px;padding:10px 14px;font-size:13px}.uren-calc i{font-size:16px}.uren-calc.overuur{background:var(--warn-bg);color:#92400e;border-color:#fcd34d}.overuur-tag{color:var(--warn);font-weight:600}.gps-banner{display:flex;align-items:center;gap:10px;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:8px;padding:10px 14px;color:#065f46;font-size:12px}.gps-banner i{font-size:16px;color:var(--success)}.gps-ok{margin-left:auto;font-weight:600}.photo-upload{border:2px dashed var(--border);border-radius:8px;padding:24px;text-align:center;cursor:pointer;transition:border-color .15s}.photo-upload:hover{border-color:var(--blue)}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--muted)}.photo-placeholder i{font-size:28px}.photo-placeholder span{font-size:13px}.photo-placeholder small{font-size:11px}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.project-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:18px;cursor:pointer;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.pc-nummer{font-size:10px;color:var(--muted);font-family:JetBrains Mono,monospace;margin-bottom:2px}.pc-naam{font-size:15px;font-weight:600;color:var(--text);line-height:1.3}.pc-client{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.pc-client i{font-size:13px}.pc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.pc-stat{text-align:center}.pc-stat-val{font-size:15px;font-weight:600;color:var(--text)}.pc-stat-label{font-size:10px;color:var(--muted);margin-top:1px}.pc-progress{height:4px;background:#f3f4f6;border-radius:2px;overflow:hidden}.pc-progress-bar{height:100%;border-radius:2px;transition:width .5s ease}.pc-footer{display:flex;align-items:center;justify-content:space-between}.pc-avatars{display:flex}.pc-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:9px;font-weight:600;border:2px solid #fff;margin-left:-6px}.pc-avatar:first-child{margin-left:0}.pc-avatar.more{background:var(--border);color:var(--muted)}.pc-dates{font-size:10px;color:var(--muted)}.breadcrumb-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.back-btn{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);padding:6px 0;transition:color .15s}.back-btn:hover{color:var(--text)}.back-btn i{font-size:15px}.breadcrumb-sep{color:var(--border);font-size:18px}.breadcrumb-cur{font-size:14px;font-weight:600;color:var(--text)}.proj-hero-card{background:var(--dark);border-radius:var(--radius-lg);padding:24px 28px;display:flex;gap:24px;justify-content:space-between;align-items:flex-start}.phc-left{flex:1}.phc-nummer{font-size:11px;color:#ffffff59;letter-spacing:1px;font-family:JetBrains Mono,monospace;margin-bottom:6px}.phc-naam{font-size:22px;font-weight:600;color:#fff;margin-bottom:10px;line-height:1.3}.phc-meta-row{display:flex;align-items:center;gap:8px;color:#ffffff80;font-size:13px;margin-bottom:5px}.phc-meta-row i{font-size:14px}.phc-right{display:flex;flex-direction:column;align-items:flex-end;gap:16px;flex-shrink:0}.phc-kpi-row{display:flex;gap:16px}.phc-kpi{text-align:center;background:#ffffff0f;border-radius:10px;padding:10px 14px;border:1px solid rgba(255,255,255,.08)}.phc-kpi-val{font-size:16px;font-weight:600;color:#fff}.phc-kpi-label{font-size:10px;color:#fff6;margin-top:2px}.tabs-bar{display:flex;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;align-self:flex-start}.tab-btn{padding:10px 18px;font-size:13px;font-weight:500;color:var(--muted);border-right:1px solid var(--border);display:flex;align-items:center;gap:6px;transition:all .15s}.tab-btn:last-child{border-right:none}.tab-btn:hover{background:var(--surface);color:var(--text)}.tab-btn.active{background:var(--blue-light);color:var(--blue)}.tab-badge{background:var(--danger);color:#fff;font-size:10px;padding:1px 5px;border-radius:10px}.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.team-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);padding:20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;box-shadow:var(--shadow)}.tc-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:600}.tc-avatar.lg{width:56px;height:56px;font-size:18px}.tc-name{font-size:14px;font-weight:600;color:var(--text)}.tc-role{font-size:12px;color:var(--muted)}.tc-email{font-size:11px;color:var(--blue);display:flex;align-items:center;gap:4px}.tc-uren{font-size:12px;color:var(--success);font-weight:500}.tc-stats{display:flex;gap:20px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);width:100%;justify-content:center}.tc-stat{text-align:center}.tc-stat div{font-size:16px;font-weight:600}.tc-stat small{font-size:10px;color:var(--muted)}.tc-actions{width:100%}.tc-actions .secondary-btn{width:100%;justify-content:center}.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:20px}.doc-grid.large{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.doc-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .15s;position:relative}.doc-card:hover{border-color:var(--blue);background:var(--blue-light)}.doc-card.add{border-style:dashed;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;justify-content:center;min-height:100px}.doc-card.add:hover{border-color:var(--blue)}.doc-icon{font-size:28px;color:var(--blue);margin-bottom:8px;display:block}.doc-icon.add{color:var(--muted)}.doc-name{font-size:11px;font-weight:500;color:var(--text);word-break:break-word;margin-bottom:4px}.doc-project{font-size:10px;color:var(--muted);margin-bottom:4px}.doc-meta{font-size:10px;color:var(--muted)}.doc-dl{position:absolute;top:8px;right:8px;opacity:0;font-size:14px;color:var(--blue);padding:4px}.doc-card:hover .doc-dl{opacity:1}.doc-actions{display:flex;justify-content:center;gap:4px;margin-top:8px}.verlof-layout{display:grid;grid-template-columns:340px 1fr;gap:16px}.cal-card{padding:16px}.cal-nav-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-month-label{font-size:14px;font-weight:600}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:12px}.cal-dow{font-size:10px;color:var(--muted);text-align:center;padding:4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.cal-day{font-size:12px;text-align:center;padding:6px 2px;border-radius:6px;cursor:pointer;color:var(--text);min-height:30px;display:flex;align-items:center;justify-content:center;transition:background .1s}.cal-day:hover{background:var(--surface)}.cal-day.other{color:var(--border)}.cal-day.weekend{color:var(--muted)}.cal-day.today{background:var(--blue);color:#fff;font-weight:600}.cal-day.verlof.goedgekeurd{background:var(--success-bg);color:#065f46;font-weight:600}.cal-day.verlof.afwachtend{background:var(--warn-bg);color:#92400e;font-weight:600}.cal-day.niet-beschikbaar{background:#fde8e8;color:#9b1c1c;font-weight:600}.cal-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:14px}.leg-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.leg-dot{width:10px;height:10px;border-radius:3px}.leg-dot.ok{background:#6ee7b7}.leg-dot.pend{background:#fcd34d}.leg-dot.today{background:var(--blue)}.leg-dot.niet-beschikbaar{background:#fca5a5}.verlof-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:12px;border-top:1px solid var(--border)}.vs-item{text-align:center}.vs-val{font-size:20px;font-weight:600;color:var(--text)}.vs-label{font-size:10px;color:var(--muted);margin-top:2px}.verlof-list-wrap{display:flex;flex-direction:column;gap:10px}.verlof-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow)}.vc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.vc-user{display:flex;align-items:center;gap:10px}.vc-name{font-size:13px;font-weight:600}.vc-type{font-size:12px;color:var(--muted)}.vc-detail{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:10px;flex-wrap:wrap}.vc-detail i{font-size:13px;margin-right:3px}.vc-actions{display:flex;gap:8px}.rep-bars{display:flex;flex-direction:column;gap:10px;padding:14px 20px 18px}.rep-bar-row{display:flex;align-items:center;gap:10px}.rep-bar-label{font-size:12px;color:var(--muted);width:100px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rep-bar-track{flex:1;height:18px;background:#f3f4f6;border-radius:4px;overflow:hidden}.laad-indicator{display:flex;align-items:center;gap:10px;padding:3rem;color:var(--muted);font-size:15px;justify-content:center}.laad-indicator i{font-size:22px;color:var(--blue)}.rep-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.rep-bar-fill.blue{background:var(--blue)}.rep-bar-fill.green{background:var(--success)}.rep-bar-val{font-size:12px;font-weight:600;color:var(--text);width:36px;text-align:right;flex-shrink:0}.export-banner{display:flex;align-items:center;gap:10px;background:var(--blue-light);border:1px solid #bfdbfe;border-radius:8px;padding:12px 16px;font-size:13px;color:var(--blue-dark)}.export-banner i{font-size:16px}.export-banner button{margin-left:auto;color:var(--muted);font-size:15px}.opmerking-list{display:flex;flex-direction:column;gap:14px;padding:18px 20px}.opmerking-item{display:flex;gap:12px}.opm-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;flex-shrink:0}.opm-body{flex:1}.opm-header{display:flex;align-items:center;gap:10px;margin-bottom:5px}.opm-header strong{font-size:13px}.opm-header span{font-size:11px;color:var(--muted)}.opm-tekst{font-size:13px;color:var(--text);line-height:1.5}.opm-new{padding:16px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.sign-pad{border:2px dashed var(--border);border-radius:8px;height:140px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;background:var(--surface)}.filter-bar{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;margin-bottom:4px}.filter-bar-veld{display:flex;flex-direction:column;gap:4px}.filter-bar-veld label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:4px}.filter-bar-veld input[type=date],.filter-bar-veld select{padding:5px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-family:inherit;background:#fff;color:var(--text);height:32px}.filter-bar-veld select{padding-right:28px}.nav-link-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:12px;font-weight:600;color:var(--blue);background:var(--blue-light);border:1px solid #bfdbfe;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background .15s}.nav-link-btn:hover{background:#dbeafe}.nav-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:200;min-width:160px;overflow:hidden}.nav-dropdown-item{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13px;color:var(--text);text-decoration:none;transition:background .12s}.nav-dropdown-item i{font-size:16px;color:var(--muted)}.nav-dropdown-item:hover{background:var(--blue-light);color:var(--blue)}.nav-dropdown-item:hover i{color:var(--blue)}.locatie-btn{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--border);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.locatie-btn:hover:not(:disabled){background:#f0fdf4;color:var(--success);border-color:#6ee7b7}.locatie-btn:disabled{opacity:.6;cursor:default}.sugestie-banner{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.sugestie-blok{display:flex;flex-direction:column;gap:6px}.sugestie-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:flex;align-items:center;gap:5px}.sugestie-label-toggle{width:100%;background:none;border:none;cursor:pointer;padding:4px 0;text-align:left}.sugestie-item{position:relative;display:flex;flex-direction:column;gap:3px;padding:10px 14px;border-radius:8px;cursor:pointer;text-align:left;transition:background .15s,border-color .15s;border:1.5px solid transparent}.sugestie-project{background:#ebf5ff;border-color:#bfdbfe}.sugestie-project:hover{background:#dbeafe;border-color:var(--blue)}.sugestie-klant{background:#f0fdf4;border-color:#bbf7d0}.sugestie-klant:hover{background:#dcfce7;border-color:#22c55e}.sugestie-type-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:1px}.sugestie-project .sugestie-type-badge{color:var(--blue)}.sugestie-klant .sugestie-type-badge{color:#16a34a}.sugestie-naam{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--text)}.sugestie-naam strong{font-weight:600}.sugestie-nr{font-size:11px;color:var(--muted);font-family:var(--mono)}.sugestie-sub{font-size:12px;color:var(--muted)}.sugestie-adres{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:4px}.sugestie-adres i{font-size:11px}.sugestie-freq{position:absolute;top:8px;right:10px;font-size:10px;color:var(--muted);font-family:var(--mono)}.sugestie-hoofd{display:flex;align-items:center;justify-content:space-between;gap:12px}.sugestie-meta{display:flex;gap:10px;font-size:11px;color:var(--muted);white-space:nowrap;flex-shrink:0}.sugestie-meta i{font-size:11px}.materiaal-sectie{border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;background:var(--surface)}.materiaal-sectie-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text)}.materiaal-sectie-header i{color:var(--blue);margin-right:2px}.materiaal-leeg{font-size:12px;color:var(--muted);text-align:center;padding:6px 0}.materiaal-rij{display:flex;gap:8px;align-items:flex-end}.materiaal-rij .form-field{margin-bottom:0}.materiaal-rij .form-field label{font-size:11px}.materiaal-rij input,.materiaal-rij select{height:34px;padding:6px 10px;font-size:13px}@media (max-width: 640px){.materiaal-rij{flex-wrap:wrap}.materiaal-rij .form-field[style*="flex: 3"]{flex:1 1 100%!important}}.td-badges{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}.td-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;background:#ede9fe;color:#6d28d9}.td-badge i{font-size:11px}.td-badge.foto{background:#fce7f3;color:#be185d}.bijlagen-sectie{border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;background:var(--surface)}.bijlagen-lijst{display:flex;flex-wrap:wrap;gap:8px}.bijlage-item{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:4px 8px;max-width:220px}.bijlage-thumb{width:36px;height:36px;object-fit:cover;border-radius:4px;flex-shrink:0}.bijlage-icon{width:36px;height:36px;background:var(--blue-light);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue);font-size:18px}.bijlage-naam{font-size:11px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.icon-btn.sm{width:24px;height:24px;font-size:13px}.klanten-layout{display:flex;flex-direction:column;gap:12px}.klanten-layout.split{flex-direction:row;align-items:flex-start;gap:14px}.klanten-lijst-panel{flex:1;min-width:0}.klanten-layout.split .klanten-lijst-panel{flex:0 0 38%;max-width:38%}.klanten-detail-panel{flex:1;min-width:0}.klanten-detail-panel .card{display:flex;flex-direction:column;max-height:calc(100vh - 220px)}.klant-selected{background:var(--blue-light)!important}.klant-selected td{color:var(--blue-dark)}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 16px;background:#f9fafb}.detail-tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--muted);border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .15s}.detail-tab:hover{color:var(--text)}.detail-tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}.dash-eigen-prestaties-mobiel{display:none}@media (max-width: 1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-grid,.verlof-layout{grid-template-columns:1fr}.klanten-layout.split{flex-direction:column}.klanten-layout.split .klanten-lijst-panel{flex:unset;max-width:100%}}@media (max-width: 768px){.login-left{display:none}.kpi-grid{grid-template-columns:1fr 1fr}.project-grid{grid-template-columns:1fr}.phc-kpi-row{flex-wrap:wrap}.tabs-bar{overflow-x:auto}.main-area.sidebar-open{margin-left:var(--sidebar-w-closed)}.dash-eigen-prestaties-mobiel{display:block}}@media (max-width: 480px){.kpi-grid,.form-row,.form-row.three{grid-template-columns:1fr}}.project-memo-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);padding:14px 18px;margin-bottom:14px}.project-memo-banner.leeg{background:#f9fafb;border-color:var(--border)}.klant-memo-blok{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:10px 14px;margin-top:4px}.klant-memo-blok.leeg{background:#f9fafb;border-color:var(--border)}.memo-banner-header{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:#92400e;text-transform:uppercase;letter-spacing:.4px;margin-bottom:6px}.project-memo-banner.leeg .memo-banner-header,.klant-memo-blok.leeg .memo-banner-header{color:var(--muted)}.memo-banner-header .icon-btn{margin-left:auto}.memo-banner-tekst{font-size:13.5px;color:#78350f;line-height:1.55;white-space:pre-wrap}.project-memo-banner.leeg .memo-banner-tekst,.klant-memo-blok.leeg .memo-banner-tekst{color:var(--muted)}.memo-leeg-hint{font-style:italic;font-size:12px}.memo-edit-area textarea{width:100%;padding:7px 10px;border:1px solid #fde68a;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;background:#fff;color:var(--text)}.memo-edit-area textarea:focus{outline:none;border-color:var(--warn)}.memo-popup-banner{display:flex;align-items:flex-start;gap:10px;background:#fffbeb;border:1.5px solid #fbbf24;border-radius:8px;padding:10px 14px;margin-bottom:2px}.memo-popup-banner>.ti{color:#d97706;font-size:18px;flex-shrink:0;margin-top:1px}.memo-popup-titel{font-size:11px;font-weight:700;color:#92400e;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}.memo-popup-tekst{font-size:13px;color:#78350f;line-height:1.5;white-space:pre-wrap}
