:root{--color-primary: #1a3a2a;--color-primary-light: #2a5e3f;--color-primary-dark: #0f2a1c;--color-accent: #c5a54e;--color-accent-hover: #a8893d;--color-accent-focus: rgba(197, 165, 78, .2);--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-success: #16a34a;--color-warning: #f59e0b;--color-error: #dc2626;--color-info: #0ea5e9;--sidebar-width: 240px;--header-height: 56px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s ease;--transition-normal: .25s ease;--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}[data-thema=blauw-oranje]{--color-primary: #1b5b6f;--color-primary-light: #247a94;--color-primary-dark: #134858;--color-accent: #f97316;--color-accent-hover: #ea580c;--color-accent-focus: rgba(249, 115, 22, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:.9375rem;line-height:1.6;color:var(--color-gray-800);background-color:var(--color-gray-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-hover)}img{max-width:100%;display:block}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:600;color:var(--color-gray-900)}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;color:var(--color-gray-500)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-gray-200);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background-color:var(--color-primary-dark);color:#fff;display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-header{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{font-size:1.125rem;font-weight:700;color:#fff;margin-bottom:.125rem}.sidebar-subtitle{font-size:.75rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.sidebar-nav{flex:1;padding:.75rem 0}.nav-link{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;color:#ffffffb3;font-size:.875rem;font-weight:500;transition:background-color var(--transition-fast),color var(--transition-fast);border-left:3px solid transparent}.nav-link:hover{background-color:#ffffff14;color:#fff}.nav-link.active{background-color:#ffffff1f;color:#fff;border-left-color:var(--color-accent)}.nav-icon{display:inline-flex;width:20px;justify-content:center;font-size:.875rem;opacity:.8}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.main-header{position:sticky;top:0;height:var(--header-height);background-color:#fff;border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;z-index:50}.header-left{display:flex;align-items:center;gap:.5rem}.header-right{display:flex;align-items:center;gap:1rem}.header-user{font-size:.875rem;color:var(--color-gray-700);display:flex;align-items:center;gap:.5rem}.header-rol{display:inline-block;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background-color:var(--color-gray-100);color:var(--color-gray-500);border-radius:var(--radius-sm)}.tab-bar{background-color:var(--color-gray-100);border-bottom:1px solid var(--color-gray-200);overflow:hidden;flex-shrink:0}.tab-bar-inner{display:flex;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--color-gray-300) transparent;padding:0 .5rem}.tab-bar-inner::-webkit-scrollbar{height:3px}.tab-bar-inner::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:2px}.tab-item{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;color:var(--color-gray-500);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;max-width:180px;transition:color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast);font-family:var(--font-sans)}.tab-item:hover{color:var(--color-gray-700);background-color:var(--color-gray-200)}.tab-item.tab-active{color:var(--color-primary);border-bottom-color:var(--color-accent);background-color:#fff}.tab-label{overflow:hidden;text-overflow:ellipsis}.tab-close{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:.875rem;line-height:1;border-radius:var(--radius-sm);color:var(--color-gray-400);flex-shrink:0;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.tab-close:hover{background-color:var(--color-gray-300);color:var(--color-gray-700)}.tab-active .tab-close:hover{background-color:var(--color-error);color:#fff}.main-content{flex:1;padding:1.5rem}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--color-gray-100);padding:1rem}.login-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.login-header{background-color:var(--color-primary);color:#fff;padding:2rem;text-align:center}.login-header h1{color:#fff;font-size:1.5rem;margin-bottom:.25rem}.login-header p{color:#ffffffb3;font-size:.875rem}.login-form{padding:2rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.375rem;font-size:.8125rem;font-weight:600;color:var(--color-gray-700)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],input[type=search],select,textarea{width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;line-height:1.5;color:var(--color-gray-800);background-color:#fff;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-focus)}input::placeholder{color:var(--color-gray-400)}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-gray-50);color:var(--color-gray-400);cursor:not-allowed}textarea{min-height:80px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1.5;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-accent-hover)}.btn-secondary{background-color:var(--color-gray-600);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-700)}.btn-outline{background-color:transparent;color:var(--color-gray-600);border-color:var(--color-gray-300)}.btn-outline:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-danger{background-color:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.btn-sm{padding:.25rem .625rem;font-size:.8125rem}.btn-full{width:100%}.alert{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;margin-bottom:1rem}.alert-error{background-color:#fef2f2;color:var(--color-error);border:1px solid #fecaca}.alert-success{background-color:#f0fdf4;color:var(--color-success);border:1px solid #bbf7d0}.alert-warning{background-color:#fffbeb;color:#92400e;border:1px solid #fde68a}.alert-info{background-color:#f0f9ff;color:#0369a1;border:1px solid #bae6fd}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);padding:1.25rem}.card h3{margin-bottom:.5rem}.card-placeholder{color:var(--color-gray-400);font-size:.875rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1.5rem}.table-wrapper{overflow-x:auto;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background-color:var(--color-gray-50)}th{text-align:left;padding:.75rem 1rem;font-weight:600;font-size:.8125rem;color:var(--color-gray-600);border-bottom:1px solid var(--color-gray-200);white-space:nowrap}td{padding:.625rem 1rem;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700)}tbody tr:hover{background-color:var(--color-gray-50)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:.125rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px;white-space:nowrap}.badge-open{background-color:#f3f4f6;color:#6b7280}.badge-aangevraagd{background-color:#fef3c7;color:#92400e}.badge-voorlopig-ingepland{background-color:#dbeafe;color:#1e40af}.badge-ingepland{background-color:#e0e7ff;color:#3730a3}.badge-definitief{background-color:#d1fae5;color:#065f46}.badge-afgesloten{background-color:#dcfce7;color:#166534}.badge-in-planning{background-color:#ede9fe;color:#6d28d9}.badge-geannuleerd{background-color:#f3f4f6;color:#9ca3af;text-decoration:line-through}.badge-feestdag{background-color:#fef3c7;color:#92400e}.badge-vakantie{background-color:#dbeafe;color:#1e40af}.dashboard{max-width:1200px}.dashboard h1{margin-bottom:.25rem}.dashboard-subtitle{color:var(--color-gray-500);font-size:.9375rem}.dashboard-tabel{width:100%;font-size:.8125rem}.dashboard-tabel th{text-align:left;font-weight:600;padding:.375rem .5rem;color:var(--color-gray-500);border-bottom:1px solid var(--color-gray-200);white-space:nowrap}.dashboard-tabel td{padding:.375rem .5rem;border-bottom:1px solid var(--color-gray-100)}.dashboard-tabel-rij-klikbaar{cursor:pointer;transition:background-color var(--transition-fast)}.dashboard-tabel-rij-klikbaar:hover{background-color:var(--color-gray-50)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200)}.modal-header h2{margin:0}.modal-body{padding:1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--color-gray-200)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-gray-500)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}@media(max-width:768px){:root{--sidebar-width: 0px}.sidebar{transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar.open{transform:translate(0);width:240px}.main-wrapper{margin-left:0}.card-grid{grid-template-columns:1fr}}.planning-grid{display:grid;border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);overflow:auto}.planning-header{font-weight:600;padding:8px 12px;background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);text-align:center;position:sticky;top:0;z-index:1}.planning-docent{font-weight:500;padding:8px 12px;background:#fff;border-right:1px solid var(--color-gray-200);position:sticky;left:0;z-index:2;white-space:nowrap}.main-wrapper:has(.planning-scherm-wrapper){height:100vh;overflow:hidden}.main-content:has(.planning-scherm-wrapper){display:flex;flex-direction:column;overflow:hidden;min-height:0;padding-bottom:28px}.planning-scherm-wrapper{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.planning-grid-area{flex:1;min-height:0;overflow:hidden}.planning-onder-grid{flex-shrink:0;max-height:30vh;overflow-y:auto;padding-top:.5rem}.planning-bevestig-balk{display:flex;gap:.75rem;align-items:center;padding:.5rem 0}.cursus-preview-grid{display:grid;grid-template-columns:120px 1fr;gap:.3rem .75rem;font-size:.875rem;margin-bottom:1rem}.cursus-preview-datum{display:inline-block;padding:.1rem .4rem;margin-right:.3rem;background:#ede9fe;border-radius:var(--radius-sm);font-size:.8rem}.cursus-preview-sectie{border-top:1px solid var(--color-gray-200);padding-top:.75rem;margin-top:.5rem}.cursus-preview-sectie h4{margin:0 0 .5rem;font-size:.85rem}.cursus-preview-moment{display:flex;justify-content:space-between;padding:.2rem 0;font-size:.8rem}.cursus-preview-cursisten{margin:0;padding-left:1.2rem;font-size:.8rem}.cursus-preview-cursisten li{padding:.1rem 0}.cursus-preview-gecontroleerd{margin-top:.75rem;padding:.75rem;background:var(--color-gray-50, #f9fafb);border-radius:6px;border:1px solid var(--color-gray-200, #e5e7eb)}.cursus-preview-gecontroleerd-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}.cursus-preview-gecontroleerd-hint{font-size:.75rem;display:block;margin-top:.25rem}.cursus-preview-datums-lijst{list-style:none;margin:0;padding:0}.cursus-preview-datums-lijst li{padding:.1rem 0;font-size:.85rem}.cursus-preview-bewerk .form-group{margin-bottom:.75rem}.cursus-preview-acties{border-top:1px solid var(--color-gray-200);padding-top:.75rem;margin-top:.75rem;display:flex;gap:.5rem;justify-content:flex-end}.cursus-preview-bevestig{flex:1;background:#fef2f2;border:1px solid #fca5a5;border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.85rem}.cursus-preview-bevestig p{margin:0 0 .5rem}.cursus-preview-bevestig-acties{display:flex;gap:.5rem}.gewenste-datums-lijst{list-style:none;margin:0;padding:0}.gewenste-datums-lijst li{display:flex;align-items:center;gap:.25rem;padding:.25rem 0;font-size:.875rem;border-bottom:1px solid var(--color-gray-100)}.gewenste-datums-lijst li:last-child{border-bottom:none}.voorstellen-samenvatting{padding:0;margin-bottom:.5rem;overflow:hidden}.voorstellen-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .75rem;background:#eff6ff;border:none;border-bottom:1px solid #bfdbfe;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;color:var(--color-gray-700)}.voorstellen-toggle:hover{background:#dbeafe}.voorstellen-toggle-titel{display:flex;align-items:center;gap:.75rem}.voorstellen-conflict-count{font-weight:500;font-size:.8rem;color:var(--color-error)}.voorstellen-tabel th{text-align:left;font-weight:500;padding:.3rem .5rem;border-bottom:1px solid var(--color-gray-200);font-size:.75rem;color:var(--color-gray-500)}.voorstellen-tabel td{padding:.3rem .5rem;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.voorstellen-rij:hover{background:var(--color-gray-50)}.voorstellen-conflict-rij{background:#fef2f2}.voorstellen-docent-cel{color:var(--color-primary);font-size:.75rem}.voorstellen-moment-cel{font-size:.75rem;color:var(--color-gray-500)}.voorstellen-waarschuwing-badge{font-size:.7rem;color:#92400e;background:#fef3c7;padding:.1rem .4rem;border-radius:var(--radius-sm)}.voorstellen-conflict-badge{font-size:.7rem;color:var(--color-error)}.voorstellen-scheiding-rij td{font-size:.75rem;font-weight:600;color:var(--color-error);padding-top:.5rem;border-top:1px solid var(--color-gray-200)}.aangevraagd-lijst{padding:.5rem .75rem;margin-bottom:.5rem;border-left:3px solid #f59e0b}.aangevraagd-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;padding:.3rem 0;font-size:.85rem;font-weight:600;cursor:pointer;color:inherit}.aangevraagd-toggle:hover{color:var(--color-primary)}.aangevraagd-toggle-label{display:flex;align-items:center;gap:.5rem}.aangevraagd-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.4rem;height:1.4rem;padding:0 .3rem;border-radius:10px;background:#f59e0b;color:#fff;font-size:.7rem;font-weight:700}.werklijst{padding:0;margin-bottom:.5rem;flex-shrink:0;overflow:hidden}.werklijst-tabs{display:flex;gap:0;background:var(--color-gray-100, #f3f4f6);border-bottom:1px solid var(--color-gray-200);padding:0 .25rem}.werklijst-tab{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .65rem;background:transparent;border:none;border-bottom:2px solid transparent;font-size:.72rem;color:var(--color-gray-600, #4b5563);cursor:pointer;transition:background .15s,border-color .15s,color .15s;margin-bottom:-1px}.werklijst-tab:hover:not(:disabled):not(.is-actief){background:#0000000a;color:var(--color-gray-800, #1f2937)}.werklijst-tab.is-actief{background:#fff;border-bottom-color:var(--color-primary, #2563eb);color:var(--color-primary, #2563eb);font-weight:600}.werklijst-tab.is-leeg,.werklijst-tab:disabled{color:var(--color-gray-400, #9ca3af);cursor:default}.werklijst-tab-label{white-space:nowrap}.werklijst-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.15rem;height:1.15rem;padding:0 .3rem;border-radius:10px;background:var(--color-gray-200, #e5e7eb);color:var(--color-gray-700, #374151);font-size:.62rem;font-weight:700}.werklijst-tab.is-actief .werklijst-tab-badge{background:var(--color-primary, #2563eb);color:#fff}.werklijst-tab-conflicten-badge{display:inline-flex;align-items:center;padding:.08rem .35rem;border-radius:10px;background:#fee2e2;color:#b91c1c;font-size:.6rem;font-weight:700}.werklijst-leeg{padding:1rem .75rem;color:var(--color-gray-500, #6b7280);font-size:.85rem;text-align:center}.werklijst>.aangevraagd-tabel,.werklijst>.te-plannen-tabel,.werklijst>.ingepland-tabel,.werklijst>.afgewezen-tabel{margin:0}.werklijst-tab--afgewezen:not(:disabled) .werklijst-tab-badge{background:#fee2e2;color:#b91c1c}.werklijst-tab--afgewezen.is-actief{border-bottom-color:#b91c1c;color:#b91c1c}.werklijst-tab--afgewezen.is-actief .werklijst-tab-badge{background:#b91c1c;color:#fff}.werklijst-tab-body{max-height:28vh;overflow-y:auto}.factbox-klant-link{color:var(--color-gray-600, #4b5563);text-decoration:none;border-bottom:1px dotted currentColor;display:inline-block}.factbox-klant-link:hover{color:var(--color-primary, #2563eb);border-bottom-style:solid}.afgewezen-tabel{width:100%;border-collapse:collapse;font-size:.8rem}.afgewezen-tabel th{text-align:left;font-weight:500;color:var(--color-gray-600);padding:.5rem .6rem;border-bottom:1px solid var(--color-gray-200);background:#fafafa}.afgewezen-tabel td{padding:.5rem .6rem;border-bottom:1px solid var(--color-gray-100);vertical-align:top}.afgewezen-rij:hover{background:#fef2f2}.afgewezen-docenten{display:flex;flex-direction:column;gap:.3rem}.afgewezen-docent-rij{font-size:.78rem}.afgewezen-docent-naam{font-weight:500}.afgewezen-docent-reden{color:#991b1b;font-style:italic;font-size:.72rem;margin-top:.1rem}.werklijst>.te-plannen-filter-banner{margin:0;border-radius:0}.aangevraagd-tabel{width:100%;border-collapse:collapse;font-size:.8rem}.aangevraagd-tabel th{text-align:left;font-weight:500;padding:.3rem .5rem;border-bottom:1px solid var(--color-gray-200);font-size:.75rem;color:var(--color-gray-500)}.aangevraagd-tabel td{padding:.35rem .5rem;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.aangevraagd-rij:hover{background:#fffbeb}.aangevraagd-rij-klikbaar{cursor:pointer}.te-plannen-lijst{padding:.5rem .75rem;margin-bottom:.5rem;max-height:28vh;overflow-y:auto;flex-shrink:0}.te-plannen-tabel thead th{position:sticky;top:0;background:#fff;z-index:1}.te-plannen-toggle{all:unset;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;font-size:.9rem;font-weight:600;padding-bottom:.4rem}.te-plannen-toggle:hover{color:var(--color-primary)}.te-plannen-tabel{width:100%;border-collapse:collapse;font-size:.8rem}.te-plannen-tabel th{text-align:left;font-weight:500;padding:.3rem .5rem;border-bottom:1px solid var(--color-gray-200);font-size:.75rem;color:var(--color-gray-500)}.te-plannen-tabel td{padding:.35rem .5rem;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.te-plannen-rij:hover{background:var(--color-gray-50)}.te-plannen-rij.is-conflict{background:#fef2f2}.te-plannen-datum-cel{font-size:.75rem;color:#6366f1}.te-plannen-check-cel{width:1.75rem;text-align:center;padding:.35rem .25rem}.te-plannen-check-cel input[type=checkbox]{cursor:pointer;margin:0}.te-plannen-conflict-badge{display:inline-block;font-size:.7rem;font-weight:600;color:var(--color-error);background:#fef2f2;border:1px solid #fca5a5;padding:.1rem .4rem;border-radius:var(--radius-sm)}.te-plannen-conflict-badge--knop{cursor:pointer;font-family:inherit;line-height:1.2;transition:background .15s,border-color .15s}.te-plannen-conflict-badge--knop:hover{background:#fee2e2;border-color:var(--color-error)}.te-plannen-conflict-badge--knop:focus-visible{outline:2px solid var(--color-error);outline-offset:1px}.te-plannen-conflict-reden{font-size:.8rem;color:var(--color-error);max-width:250px}.te-plannen-conflict-cel{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;min-width:0}.te-plannen-conflict-reden-inline{font-size:.7rem;color:var(--color-gray-600, #4b5563);max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.voorstellen-tabel{width:100%;border-collapse:collapse;font-size:.8rem}.voorstellen-tabel thead th{text-align:left;padding:.4rem .5rem;border-bottom:1px solid var(--color-gray-200, #e5e7eb);font-weight:600;color:var(--color-gray-700, #374151);background:var(--color-gray-50, #f9fafb)}.voorstellen-tabel tbody td{padding:.4rem .5rem;border-bottom:1px solid var(--color-gray-100, #f3f4f6);vertical-align:middle}.voorstel-rij.is-uitgevinkt{background:var(--color-gray-50, #f9fafb);opacity:.6}.voorstel-rij.is-uitgevinkt td{text-decoration:line-through;text-decoration-color:var(--color-gray-400, #9ca3af)}.werklijst-cursusnummer-cel{display:inline-block;cursor:help;border-bottom:1px dotted var(--color-gray-400, #9ca3af)}.popup-concept-marker{margin-left:.4rem;font-size:.7rem;color:var(--color-primary, #2563eb);font-weight:500}.popup-concept-badge{display:inline-block;padding:.05rem .4rem;border-radius:4px;background:#dbeafe;color:#1e40af;font-size:.7rem;font-weight:600}.popup-laden{padding:.6rem .8rem;font-size:.8rem;color:var(--color-gray-600, #4b5563)}.planning-cell.heeft-afspraak{background:repeating-linear-gradient(-45deg,#fef3c7,#fef3c7 4px,#fde68a 4px,#fde68a 8px)}.afspraak-blok{display:inline-block;padding:.08rem .3rem;margin:1px;border-radius:3px;background:#fde68a;color:#78350f;font-size:.62rem;font-weight:500;border:1px solid #f59e0b;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:help}.te-plannen-alternatieven-rij td{background:var(--color-gray-50);padding:.5rem .75rem}.te-plannen-filter-banner{display:flex;align-items:center;justify-content:space-between;padding:.4rem .75rem;background:#fef3c7;border:1px solid #fcd34d;border-radius:var(--radius-sm);margin:.35rem 0;font-size:.8rem;color:#92400e}.planning-health-bar{display:flex;align-items:center;gap:.25rem;padding:.4rem .75rem;margin-bottom:.5rem;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:.82rem}.planning-health-bar .health-bar-item{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border:1px solid transparent;background:transparent;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:inherit;color:var(--color-gray-700);transition:background .15s,border-color .15s}.planning-health-bar .health-bar-item:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-200)}.planning-health-bar .health-bar-item:disabled{cursor:default;opacity:.5}.planning-health-bar .health-bar-item.is-actief{background:#fef3c7;border-color:#fcd34d;color:#92400e}.health-bar-icoon{font-size:.85rem}.health-bar-icoon.is-positief{color:#16a34a}.health-bar-icoon.is-waarschuwing{color:#d97706}.health-bar-icoon.is-conflict{color:var(--color-error)}.health-bar-icoon.is-afgewezen{color:#b91c1c}.health-bar-waarde{font-weight:700;color:var(--color-gray-900)}.health-bar-label{color:var(--color-gray-600)}.health-bar-scheider{color:var(--color-gray-300);-webkit-user-select:none;user-select:none}.te-plannen-diagnose-rij td{background:#fffbeb;padding:.5rem .75rem;border-top:1px dashed #fcd34d}.diagnose-uitklap{display:flex;flex-direction:column;gap:.5rem;font-size:.8rem}.diagnose-datum-rij{padding:.35rem .5rem;border-radius:var(--radius-sm);background:#fff;border:1px solid var(--color-gray-200)}.diagnose-datum-rij.is-haalbaar{border-color:#86efac;background:#f0fdf4}.diagnose-datum-rij.is-niet-haalbaar{border-color:#fca5a5}.diagnose-datum-knop{background:none;border:none;padding:0;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--color-gray-800);font-size:.82rem}.diagnose-datum-knop:hover{text-decoration:underline}.diagnose-datum-icoon{font-size:.85rem}.is-haalbaar .diagnose-datum-icoon{color:#16a34a}.is-niet-haalbaar .diagnose-datum-icoon{color:var(--color-error)}.diagnose-datum-prio{font-size:.7rem;font-weight:500;color:var(--color-gray-500)}.diagnose-datum-reden{margin-top:.2rem;margin-left:1.4rem;color:var(--color-error);font-size:.78rem}.diagnose-docenten-lijst{list-style:none;padding:0;margin:.3rem 0 0 1.4rem;display:flex;flex-direction:column;gap:.15rem}.diagnose-docent-item{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--color-gray-700)}.diagnose-docent-naam{font-weight:500;min-width:8rem}.diagnose-docent-badge{display:inline-block;padding:.05rem .35rem;border-radius:var(--radius-sm);font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.diagnose-status-beschikbaar .diagnose-docent-badge{background:#dcfce7;color:#15803d}.diagnose-status-niet_beschikbaar .diagnose-docent-badge{background:#f3f4f6;color:var(--color-gray-600)}.diagnose-status-al_ingepland .diagnose-docent-badge{background:#fef3c7;color:#92400e}.diagnose-status-geen_vaardigheid .diagnose-docent-badge{background:#fee2e2;color:#991b1b}.diagnose-docent-toelichting{color:var(--color-gray-500);font-style:italic}.te-plannen-alternatieven{font-size:.8rem}.alternatieven-lijst{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.375rem}.alternatief-chip{display:inline-block;padding:.15rem .5rem;border-radius:var(--radius-sm);background:#e8f5e9;color:#2e7d32;font-size:.75rem;white-space:nowrap}.te-plannen-verschuivingen-rij td{background:#fef3c7;padding:.5rem .75rem}.verschuivingen-lijst{font-size:.8rem}.verschuiving-suggestie{margin-top:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #fcd34d;border-left:3px solid #f59e0b;border-radius:var(--radius-sm);transition:background .1s}.verschuiving-suggestie:hover{background:#fffbeb}.verschuiving-header{margin-bottom:.25rem}.verschuiving-cursus-info{font-size:.8rem}.verschuiving-docenten{font-size:.75rem;color:var(--color-gray-500)}.verschuiving-detail{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--color-gray-600);flex-wrap:wrap;margin-bottom:.2rem}.verschuiving-momenten--huidig{color:#b91c1c;font-weight:500}.verschuiving-momenten--nieuw{color:#15803d;font-weight:500}.verschuiving-vrijkomend{font-size:.72rem;color:#15803d;margin-bottom:.2rem}.verschuiving-waarschuwingen{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.25rem}.verschuiving-waarschuwing{font-size:.72rem;color:#92400e;background:#fffbeb;border:1px solid #fcd34d;border-radius:var(--radius-sm);padding:.1rem .35rem}.verschuiving-acties{display:flex;align-items:center;gap:.5rem;margin-top:.35rem}.verschuiving-actie-knop{border-color:#86efac;color:#15803d}.verschuiving-actie-knop:hover{background:#f0fdf4}.verschuiving-bevestig-dialoog{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.75rem;color:var(--color-gray-700)}.verschuiving-label{font-weight:600;color:var(--color-gray-500);text-transform:uppercase;font-size:.65rem;letter-spacing:.03em}.verschuiving-pijl{color:#f59e0b;font-weight:700;font-size:1rem}.verschuiving-knop{border-color:#fcd34d;color:#92400e}.grid-verschuiving-huidig{background-color:#fee2e2!important;outline:2px solid #ef4444;outline-offset:-2px}.grid-verschuiving-nieuw{background-color:#dcfce7!important;outline:2px solid #22c55e;outline-offset:-2px}.conflict-oplossingen{display:flex;flex-direction:column;gap:.9rem;padding:.75rem 1rem;background:var(--color-gray-50, #f9fafb);border-radius:var(--radius-sm)}.oplossing-sectie{display:flex;flex-direction:column;gap:.4rem}.oplossing-sectie-titel{margin:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-gray-500, #6b7280)}.te-plannen-oplossingen-rij>td{background:var(--color-gray-50, #f9fafb);padding:0}.verschuiving-kaarten{display:flex;flex-direction:column;gap:.5rem}.verschuiving-kaart{display:grid;grid-template-rows:auto auto auto auto;gap:.45rem;padding:.6rem .8rem;background:#fff;border:1px solid var(--color-gray-200, #e5e7eb);border-left:3px solid #f59e0b;border-radius:var(--radius-sm);transition:background .1s,border-color .1s}.verschuiving-kaart:hover{background:#fffbeb;border-left-color:#d97706}.verschuiving-kaart-kop{font-size:.85rem}.verschuiving-kaart-cursus{font-weight:600;color:var(--color-gray-800, #1f2937)}.verschuiving-kaart-docenten{font-size:.75rem;color:var(--color-gray-600, #4b5563);margin-top:.15rem}.verschuiving-kaart-tijdlijn{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:.6rem;padding:.3rem 0}.verschuiving-kaart-kolom{display:flex;flex-direction:column;gap:.2rem}.verschuiving-kaart-label{font-size:.65rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-gray-500, #6b7280)}.verschuiving-kaart-momenten{list-style:none;padding:0;margin:0;font-size:.8rem;display:flex;flex-direction:column;gap:.15rem}.verschuiving-kaart-momenten--van{color:#b91c1c}.verschuiving-kaart-momenten--naar{color:#15803d}.verschuiving-kaart-pijl{align-self:center;font-size:1.25rem;color:#d97706;font-weight:700}.verschuiving-kaart-chips{display:flex;flex-wrap:wrap;gap:.3rem}.verschuiving-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .45rem;border-radius:10px;font-size:.72rem;font-weight:500;border:1px solid transparent}.verschuiving-chip--vrij{background:#f0fdf4;color:#15803d;border-color:#bbf7d0}.verschuiving-chip--waarschuwing{background:#fffbeb;color:#92400e;border-color:#fcd34d}.verschuiving-kaart-acties{display:flex;justify-content:flex-end;align-items:center;gap:.5rem;flex-wrap:wrap}.verschuiving-kaart-fout{font-size:.75rem;margin-right:auto}.verschuiving-kaart-knop{min-width:110px}.btn-icon{padding:.25rem .5rem;min-width:auto}.btn.is-actief{background:var(--color-primary, #2563eb);color:#fff;border-color:var(--color-primary, #2563eb)}.te-plannen-acties-cel{text-align:left;white-space:nowrap}.te-plannen-acties-cel .btn{padding:.15rem .5rem;font-size:.7rem}.te-plannen-acties-cel .btn+.btn{margin-left:.25rem}.inplanning-blok{font-size:.65rem;padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;letter-spacing:-.01em;box-shadow:0 1px 2px #00000014;cursor:pointer}.inplanning-blok:hover{box-shadow:0 2px 4px #00000026;filter:brightness(.95)}.inplanning-blok{position:relative}.akkoord-dot{position:absolute;top:2px;right:2px;width:7px;height:7px;border-radius:50%;border:1px solid rgba(255,255,255,.8);box-shadow:0 0 0 .5px #00000026;pointer-events:none}.akkoord-dot--geaccepteerd{background:#22c55e}.akkoord-dot--pending{background:#9ca3af}.akkoord-dot--afgewezen{background:#ef4444}.concept-blok{font-size:.65rem;padding:2px 6px;border-radius:4px;cursor:pointer;background:#dbeafe;border:1.5px dashed #3b82f6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;color:#1e40af;position:relative;box-shadow:0 1px 2px #2563eb1a}.concept-blok:hover{background:#bfdbfe;box-shadow:0 2px 4px #2563eb33}.concept-blok.heeft-waarschuwing{background:#fef3c7;border-color:#f59e0b;color:#92400e;box-shadow:0 1px 2px #f59e0b26}.concept-verwijder-btn{all:unset;cursor:pointer;font-size:.75rem;line-height:1;color:#94a3b8;padding:0 2px;margin-left:3px;border-radius:3px}.concept-verwijder-btn:hover{color:#ef4444;background:#ef44441a}.ingepland-lijst{margin-top:.5rem}.ingepland-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;padding:.4rem 0;font-size:.9rem;font-weight:600;cursor:pointer;color:inherit}.ingepland-toggle:hover{color:var(--color-primary)}.ingepland-tabel{width:100%;border-collapse:collapse;font-size:.8rem}.ingepland-tabel th{text-align:left;font-weight:500;padding:.3rem .5rem;border-bottom:1px solid var(--color-gray-200);font-size:.75rem;color:var(--color-gray-500)}.ingepland-tabel td{padding:.35rem .5rem;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.ingepland-tabel tbody tr{background:#f0fdf4}.ingepland-docenten{color:#059669;font-size:.75rem}.planning-scherm-wrapper.panel-open{margin-right:420px}.planning-panel{position:fixed;right:0;top:0;bottom:0;width:420px;max-width:90vw;background:#fff;z-index:50;display:flex;flex-direction:column;box-shadow:-4px 0 20px #00000026;animation:panelSlideIn .2s ease-out}@keyframes panelSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.planning-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200);flex-shrink:0}.planning-panel-header h3{margin:0;font-size:1rem}.planning-panel-content{flex:1;overflow-y:auto;padding:1rem 1.25rem}.planning-panel-sectie{margin-bottom:1.25rem}.planning-panel-label{display:block;font-weight:600;font-size:.85rem;margin-bottom:.4rem;color:var(--color-gray-700)}.planning-panel-sublabel{display:block;font-size:.75rem;font-weight:500;color:var(--color-gray-500);margin:.5rem 0 .25rem}.planning-panel-velden{padding:.5rem;background:var(--color-gray-50);border-radius:var(--radius-sm);margin-top:.3rem}.planning-panel-veld{display:flex;gap:.5rem;padding:.15rem 0;font-size:.85rem}.planning-panel-veld-label{font-weight:500;color:var(--color-gray-500);min-width:90px;flex-shrink:0}.planning-panel-cursustype-info{display:flex;gap:.75rem;margin-top:.4rem;font-size:.75rem;color:var(--color-gray-500)}.planning-panel-datum-row{display:flex;gap:.5rem}.planning-panel-datum-row .form-input{flex:1}.planning-panel-momenten{margin-top:.5rem}.planning-panel-moment{display:flex;gap:.5rem;align-items:center;padding:.2rem .4rem;font-size:.8rem;border-bottom:1px solid var(--color-gray-100)}.moment-status-feestdag{font-size:.7rem;color:#92400e;background:#fef3c7;padding:.1rem .3rem;border-radius:var(--radius-sm)}.planning-panel-moment-blok{padding:.2rem 0;border-bottom:1px solid var(--color-gray-100)}.planning-panel-moment-tijden{display:flex;gap:.25rem;align-items:center;margin-top:.15rem}.planning-panel-tijd-input{width:80px!important;padding:.15rem .25rem!important;font-size:.75rem!important}.planning-panel-fout{margin-top:.4rem;font-size:.8rem;color:var(--color-error);padding:.4rem;background:#fef2f2;border-radius:var(--radius-sm)}.planning-panel-docent-slot{margin-bottom:.5rem}.planning-panel-docent-row{display:flex;gap:.35rem;align-items:center}.planning-panel-docent-row .form-input{flex:1}.planning-panel-rol-select{width:110px!important;flex:none!important}.planning-panel-docent-conflicten{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.planning-panel-conflict-badge{font-size:.7rem;color:#92400e;background:#fef3c7;padding:.1rem .4rem;border-radius:var(--radius-sm)}.planning-panel-docent-vaardigheden{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.25rem}.vaardigheid-tag{font-size:.65rem;padding:.1rem .35rem;border-radius:var(--radius-sm);background:var(--color-gray-100);color:var(--color-gray-600)}.vaardigheid-tag.vaardigheid-match{background:#d1fae5;color:#065f46}.planning-panel-validatie-item{font-size:.8rem;padding:.3rem .5rem;margin-bottom:.25rem;border-radius:var(--radius-sm)}.planning-panel-validatie-item.validatie-hard{background:#fef2f2;color:var(--color-error)}.planning-panel-validatie-item.validatie-waarschuwing{background:#fef3c7;color:#92400e}.planning-panel-acties{display:flex;gap:.5rem;align-items:center;padding:1rem 1.25rem;border-top:1px solid var(--color-gray-200);flex-shrink:0}.planning-grid-scroll{overflow:auto;height:100%;border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.planning-grid-table{border-collapse:separate;border-spacing:0;min-width:100%}.grid-th-docent{position:sticky;left:0;top:0;z-index:3;background:var(--color-gray-50);min-width:110px;text-align:left;font-size:.75rem;font-weight:600;color:var(--color-gray-600);padding:6px 10px;border-bottom:1px solid var(--color-gray-200);border-right:2px solid var(--color-gray-200)}.grid-th-datum{position:sticky;top:0;z-index:2;text-align:center;background:var(--color-gray-50);font-size:.75rem;font-weight:600;color:var(--color-gray-700);padding:5px 4px 2px;border-bottom:none}.grid-th-dagdeel{position:sticky;top:26px;z-index:2;text-align:center;font-size:.65rem;font-weight:500;color:var(--color-gray-400);background:var(--color-gray-50);padding:0 4px 4px;border-bottom:1px solid var(--color-gray-200)}.grid-dag-scheiding{border-left:2px solid var(--color-gray-200)}.grid-feestdag-label{font-size:.6rem;font-weight:400;font-style:italic;color:#999}.grid-td-docent{position:sticky;left:0;z-index:1;background:#fff;font-weight:500;font-size:.75rem;white-space:nowrap;padding:3px 10px;border-right:2px solid var(--color-gray-200);border-bottom:1px solid var(--color-gray-100);cursor:help}.docent-vaardigheid-count{font-size:.6rem;color:var(--color-gray-400);margin-left:.25rem;font-weight:400}.grid-th-datum-klikbaar{cursor:pointer}.grid-th-datum-klikbaar:hover{background:#3b82f614}.grid-th-datum--hover{box-shadow:inset 0 -3px #f59e0b;background:#fbbf241f}.grid-highlight-cel{box-shadow:inset 0 0 0 2px #f59e0bb3}@keyframes datum-puls{0%{background:#ef444459;box-shadow:inset 0 0 0 2px var(--color-error)}60%{background:#ef444426;box-shadow:inset 0 0 0 2px #ef444480}to{background:transparent;box-shadow:inset 0 0 0 2px transparent}}.grid-th-datum--highlight{animation:datum-puls 1.2s ease-out}.werklijst-rij--focus-puls td{animation:datum-puls 1.5s ease-out}.dag-capaciteit-modal{max-width:600px}.dag-capaciteit-body{padding:1rem 1.25rem}.dag-capaciteit-dagdeel{margin-bottom:1rem}.dag-capaciteit-dagdeel:last-child{margin-bottom:0}.dag-capaciteit-dagdeel-titel{font-size:.85rem;font-weight:600;margin:0 0 .4rem;padding-bottom:.25rem;border-bottom:1px solid var(--color-gray-200);display:flex;justify-content:space-between;align-items:center}.dag-capaciteit-totaal{font-size:.75rem;font-weight:400;color:var(--color-gray-500)}.dag-capaciteit-rij{display:flex;gap:.5rem;font-size:.8rem;padding:.15rem 0}.dag-capaciteit-vaardigheid{font-weight:500;min-width:140px;flex-shrink:0}.dag-capaciteit-namen{color:var(--color-gray-600)}.dag-capaciteit-leeg{font-size:.8rem;margin:.25rem 0}.dag-capaciteit-niet-ingevuld{display:flex;gap:.5rem;font-size:.75rem;padding:.25rem 0;margin-top:.25rem;border-top:1px dashed var(--color-gray-200)}.planning-cell{position:relative;min-width:48px;height:30px;padding:2px;cursor:pointer;border-bottom:1px solid var(--color-gray-100);border-right:1px solid var(--color-gray-50);transition:background .1s}.planning-cell:hover{background:#3b82f60f}.planning-hover-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--color-gray-300);border-radius:var(--radius-md);padding:.5rem;box-shadow:var(--shadow-lg);z-index:100;min-width:200px;max-width:280px;font-size:.75rem;pointer-events:none;white-space:normal;font-weight:400;color:var(--color-gray-800)}.planning-hover-popup .popup-titel{font-weight:600;margin-bottom:.25rem;color:#1e40af}.planning-hover-popup .popup-grid{display:grid;grid-template-columns:70px 1fr;gap:.15rem .5rem}.planning-hover-popup .popup-hint{margin-top:.3rem;font-size:.7rem;color:var(--color-primary)}.planning-hover-popup .popup-origineel{margin-top:.25rem;padding:.2rem .4rem;background:#ede9fe;border-radius:var(--radius-sm);color:#5b21b6;font-size:.7rem;font-style:italic}.planning-hover-popup .popup-waarschuwing{margin-top:.25rem;padding:.2rem .4rem;background:#fef3c7;border-radius:var(--radius-sm);color:#92400e;font-size:.7rem}.planning-hover-popup .popup-docenten{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--color-gray-200)}.planning-hover-popup .popup-sectie-titel{font-weight:600;font-size:.7rem;color:var(--color-gray-700);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.02em}.planning-hover-popup .popup-docenten-lijst{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.planning-hover-popup .popup-docent-rij{display:flex;align-items:center;gap:.3rem;flex-wrap:wrap;font-size:.72rem}.planning-hover-popup .popup-docent-naam{font-weight:500}.planning-hover-popup .popup-akkoord-badge{margin-left:auto;font-size:.65rem;font-weight:600;padding:1px 6px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.planning-hover-popup .popup-akkoord-badge--geaccepteerd{background:#dcfce7;color:#166534}.planning-hover-popup .popup-akkoord-badge--pending{background:#f3f4f6;color:#4b5563}.planning-hover-popup .popup-akkoord-badge--afgewezen{background:#fee2e2;color:#991b1b}.planning-hover-popup .popup-docent-reden{flex-basis:100%;font-size:.68rem;color:#991b1b;font-style:italic;margin-left:.3rem}.planning-hover-popup .popup-momenten{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--color-gray-200)}.planning-hover-popup .popup-momenten-lijst{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.15rem}.planning-hover-popup .popup-moment-rij{display:grid;grid-template-columns:90px 40px 1fr;gap:.3rem;align-items:center;font-size:.72rem;padding:1px 4px;border-radius:3px}.planning-hover-popup .popup-moment-rij.is-huidig{background:#eff6ff;font-weight:600;color:#1e40af}.planning-hover-popup .popup-moment-dagdeel{color:var(--color-gray-700);font-size:.68rem;text-transform:uppercase}.planning-hover-popup .popup-moment-tijd{font-size:.68rem}.planning-hover-popup .popup-vaardigheden{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--color-gray-200)}.planning-hover-popup .popup-vaardigheden-chips{display:flex;flex-wrap:wrap;gap:.25rem}.planning-hover-popup .popup-vaardigheid-chip{font-size:.68rem;padding:1px 6px;border-radius:999px;font-weight:500}.planning-hover-popup .popup-vaardigheid-chip--dekt{background:#dcfce7;color:#166534}.planning-hover-popup .popup-vaardigheid-chip--mist{background:#fee2e2;color:#991b1b}.planning-cell.beschikbaar{background:#f0fdf4}.planning-cell.niet-beschikbaar{background:#fef2f2}.planning-cell.feestdag{background:#fafafa;cursor:default}.week-nav{display:flex;align-items:center;gap:16px;margin-bottom:16px}.week-nav h3{margin:0;min-width:200px;text-align:center}.beschikbaarheid-grid{display:grid;gap:2px}.beschikbaarheid-cell{padding:8px;text-align:center;cursor:pointer;border-radius:4px;font-size:.75rem;-webkit-user-select:none;user-select:none;transition:opacity .2s}.beschikbaarheid-cell:hover{opacity:.8}.beschikbaarheid-cell.niet-ingevuld{background:var(--color-gray-100);color:var(--color-gray-400)}.beschikbaarheid-cell.beschikbaar{background:#c8e6c9;color:#2e7d32}.beschikbaarheid-cell.niet-beschikbaar{background:#ffcdd2;color:#c62828}.beschikbaarheid-cell.ingepland{background:#bbdefb;color:#1565c0}.beschikbaarheid-cell.feestdag{background:#eee;color:#999;cursor:not-allowed}.tabs{display:flex;gap:0;border-bottom:2px solid var(--color-gray-200)}.tab{padding:.625rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;color:var(--color-gray-500);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast)}.tab:hover{color:var(--color-gray-700)}.tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.omgevings-footer{position:fixed;bottom:0;left:0;right:0;height:28px;display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--color-gray-50);border-top:1px solid var(--color-gray-200);font-size:.75rem;z-index:300}.footer-badge{display:inline-block;padding:.0625rem .5rem;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;color:#fff}.footer-dev{background-color:var(--color-success)}.footer-test{background-color:var(--color-warning)}.footer-prod{background-color:var(--color-error)}.footer-versie{color:var(--color-gray-400);font-size:.6875rem}.factbox-layout{display:flex;gap:0;min-height:calc(100vh - var(--header-height, 60px) - 2rem)}.factbox-main{flex:1;overflow:auto;min-width:0}.factbox-panel{width:280px;min-width:280px;background:var(--color-gray-50, #f9fafb);border-left:1px solid var(--color-gray-200, #e5e7eb);position:sticky;top:0;height:calc(100vh - var(--header-height, 60px) - 2rem);overflow-y:auto}.factbox-section{padding:.75rem 1rem;border-bottom:1px solid var(--color-gray-200, #e5e7eb)}.factbox-section-label{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500, #6b7280);margin-bottom:.375rem}.factbox-empty{padding:2rem 1rem;text-align:center;color:var(--color-gray-400, #9ca3af);font-size:.8125rem}.compact-table{width:100%;border-collapse:collapse;font-size:.8125rem}.compact-table thead th{padding:.375rem .5rem;text-align:left;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-gray-500, #6b7280);border-bottom:1px solid var(--color-gray-200, #e5e7eb);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.compact-table thead th:hover{color:var(--color-gray-700, #374151)}.compact-table thead th .sort-indicator{margin-left:.25rem;font-size:.625rem}.compact-table tbody tr{border-bottom:1px solid var(--color-gray-100, #f3f4f6);cursor:pointer;transition:background .15s}.compact-table tbody tr:hover{background:var(--color-gray-50, #f9fafb)}.compact-table tbody tr.selected{background:#c5a54e14;border-left:3px solid var(--color-accent, #c5a54e)}.compact-table tbody td{padding:.3125rem .5rem;vertical-align:middle}.info-bar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-gray-50, #f9fafb);border-radius:var(--radius-md, .375rem);margin-bottom:1rem;flex-wrap:wrap}.info-bar-item{display:flex;align-items:center;gap:.25rem;font-size:.8125rem}.info-bar-item label{color:var(--color-gray-500, #6b7280);font-size:.6875rem;font-weight:600;text-transform:uppercase}.info-bar-actions{margin-left:auto;display:flex;gap:.5rem}.presentielijst-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.presentielijst-header .terug-link{color:var(--color-gray-500, #6b7280);text-decoration:none;font-size:.875rem}.presentielijst-header .terug-link:hover{color:var(--color-gray-700, #374151)}.presentielijst-save-status{font-size:.75rem;padding:.25rem .75rem;border-radius:1rem}.presentielijst-save-status.opgeslagen{background:#16a34a1a;color:var(--color-success, #16a34a)}.presentielijst-save-status.opslaan{background:#f59e0b1a;color:var(--color-warning, #f59e0b)}.presentielijst-save-status.fout{background:#dc26261a;color:var(--color-error, #dc2626)}.presentielijst-bulk{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.presentielijst-bulk .info-tekst{font-size:.75rem;color:var(--color-gray-400, #9ca3af);margin-left:auto}.cursist-card{border:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-lg, .5rem);padding:1rem;margin-bottom:.5rem;transition:border-color .15s}.cursist-card.niet-ingecheckt{background:#f59e0b0d;border-color:var(--color-warning, #f59e0b)}.cursist-card.ingevuld{border-color:var(--color-success, #16a34a)}.cursist-card.negatief{border-color:var(--color-error, #dc2626)}.cursist-card.nieuw{border-color:var(--color-info, #3b82f6)}.cursist-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.cursist-card-naam{font-weight:600;font-size:.9375rem}.cursist-card-nummer{color:var(--color-gray-500, #6b7280);font-size:.75rem}.cursist-card-geboortedatum{color:var(--color-gray-500, #6b7280);font-size:.75rem;margin-left:auto}.cursist-card-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.cursist-card-field label{display:block;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-500, #6b7280);margin-bottom:.25rem}.toggle-aanwezig{width:48px;height:48px;border-radius:var(--radius-lg, .5rem);border:2px solid var(--color-gray-300, #d1d5db);background:var(--color-gray-50, #f9fafb);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .15s;color:var(--color-gray-400, #9ca3af)}.toggle-aanwezig.actief{background:#16a34a1a;border-color:var(--color-success, #16a34a);color:var(--color-success, #16a34a)}.presentielijst-select,.presentielijst-input{width:100%;padding:.625rem .5rem;border-radius:var(--radius-lg, .5rem);border:1px solid var(--color-gray-300, #d1d5db);font-size:.875rem;background:#fff}.presentielijst-select.ingevuld,.presentielijst-input.ingevuld{border-color:var(--color-success, #16a34a)}.presentielijst-select.negatief{border-color:var(--color-error, #dc2626);color:var(--color-error, #dc2626)}.nieuw-label{background:var(--color-info, #3b82f6);color:#fff;padding:.125rem .5rem;border-radius:1rem;font-size:.625rem;font-weight:600;text-transform:uppercase}.ondertekening-blok{margin-top:2rem;padding:1rem;border:1px solid var(--color-gray-200, #e5e7eb);border-radius:var(--radius-lg, .5rem);background:var(--color-gray-50, #f9fafb)}.ondertekening-blok.ondertekend{border-color:var(--color-success, #16a34a);background:#16a34a0d}.progress-bar{height:4px;background:var(--color-gray-200, #e5e7eb);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-accent, #c5a54e);border-radius:2px;transition:width .3s}.badge-aanwezigheid{padding:.125rem .5rem;border-radius:1rem;font-size:.6875rem;font-weight:600}.badge-aanwezigheid.volledig{background:#16a34a1a;color:var(--color-success, #16a34a)}.badge-aanwezigheid.gedeeltelijk{background:#f59e0b1a;color:var(--color-warning, #f59e0b)}.badge-aanwezigheid.leeg{background:var(--color-gray-100, #f3f4f6);color:var(--color-gray-500, #6b7280)}.aandachtspunt{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-left:3px solid var(--color-warning, #f59e0b);background:var(--color-gray-50, #f9fafb);border-radius:0 var(--radius-sm, .25rem) var(--radius-sm, .25rem) 0;margin-bottom:.5rem;font-size:.8125rem}.aandachtspunt-icon{font-size:1rem;flex-shrink:0}.aandachtspunt a{color:var(--color-accent, #c5a54e);text-decoration:none}.aandachtspunt a:hover{text-decoration:underline}.skip-link{position:absolute;top:-100%;left:1rem;z-index:9999;padding:.5rem 1rem;background:var(--color-primary, #1a3a2a);color:#fff;border-radius:var(--radius-md, 6px);text-decoration:none;font-weight:600}.skip-link:focus{top:.5rem}
