@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap";
*{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{height:100%;min-height:-webkit-fill-available}.app{color:#1a1a2e;background:#f7f5ff;height:100dvh;font-family:Nunito,sans-serif;display:flex}.sidebar{background:#2d1b69;flex-direction:column;flex-shrink:0;width:220px;padding:0;transition:width .2s;display:flex;overflow:hidden}.sidebar.collapsed{width:56px}.sidebar.collapsed .sidebar-logo{border-bottom:1px solid #ffffff1a;justify-content:center;padding:10px 0;display:flex}.sidebar.collapsed .sidebar-logo>:not(.sidebar-logo-icon){display:none}.sidebar.collapsed .sidebar-logo-icon{justify-content:center;display:flex}.sidebar.collapsed .sidebar-class-select,.sidebar.collapsed .nav-section,.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-badge{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:12px 0}.sidebar.collapsed .sidebar-footer{display:none}.sidebar-footer{flex-shrink:0}.sidebar-collapse-btn{width:100%;padding:10px 0;padding-bottom:max(10px, env(safe-area-inset-bottom,10px));color:#ffffff73;cursor:pointer;background:0 0;border:none;border-top:1px solid #ffffff1a;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:color .15s;display:flex}.sidebar-collapse-btn:hover{color:#fff}.sidebar-logo{border-bottom:1px solid #ffffff1a;padding:12px 20px}.sidebar-logo-full{display:block}.sidebar-logo-icon{display:none}.sidebar-logo h1{color:#fff;font-size:16px;font-weight:800;line-height:1.3}.sidebar-logo span{color:#ffffff80;font-size:11px;font-weight:500}.sidebar-nav{flex:1;min-height:0;padding:12px 0;overflow-y:auto}.nav-item{color:#fff9;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff0f}.nav-item.active{color:#fff;background:#a78bfa26;border-left-color:#a78bfa}.nav-icon{text-align:center;width:20px;font-size:16px}.nav-section{color:#ffffff4d;letter-spacing:.08em;text-transform:uppercase;padding:14px 20px 4px;font-size:10px;font-weight:700}.main{flex:1;overflow-y:auto}.topbar{z-index:10;background:#fff;border-bottom:1px solid #ede9fe;justify-content:space-between;align-items:center;padding:16px 28px;display:flex;position:sticky;top:0}.topbar h2{color:#1a1a2e;font-size:18px;font-weight:800}.topbar-sub{color:#888;font-size:13px;font-weight:500}.content{padding:24px 28px}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:700;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:#7c3aed}.btn-primary:hover{background:#6d28d9}.btn-secondary{color:#5b21b6;background:#ede9fe}.btn-secondary:hover{background:#ddd6fe}.btn-sm{padding:5px 12px;font-size:12px}.btn-danger{color:#b91c1c;background:#fee2e2}.card{background:#fff;border:1px solid #ede9fe;border-radius:12px;padding:20px}.student-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-top:16px;display:grid}.student-tile{cursor:pointer;background:#fff;border:2px solid #ede9fe;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;transition:all .15s;display:flex}.student-tile:hover{border-color:#a78bfa;transform:translateY(-2px);box-shadow:0 4px 16px #7c3aed1a}.avatar{color:#5b21b6;background:#ede9fe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:800;display:flex}.tile-name{text-align:center;font-size:11px;font-weight:700}.tile-status{text-align:center;white-space:nowrap;border-radius:20px;padding:2px 6px;font-size:9px;font-weight:600}.alert-icon{cursor:pointer;opacity:.4;font-size:16px;transition:all .15s}.alert-icon.active{opacity:1}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:460px;max-width:92vw;max-height:88dvh;padding:24px;overflow-y:auto}.modal h3{margin-bottom:16px;font-size:16px;font-weight:800}.status-options{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.status-option{cursor:pointer;border:3px solid #0000;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;transition:all .12s}.status-option.selected{transform:scale(1.02);box-shadow:0 0 0 3px #00000059}.comment-box{resize:vertical;border:1.5px solid #ede9fe;border-radius:8px;outline:none;width:100%;min-height:72px;padding:10px 12px;font-family:inherit;font-size:13px}.comment-box:focus{border-color:#a78bfa}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.matrix-table{border-collapse:collapse;font-size:12px}.matrix-table thead tr{height:160px}.matrix-table th{text-align:center;color:#666;vertical-align:bottom;width:32px;max-width:32px;padding:0;font-size:11px;font-weight:700;position:relative;overflow:visible}.matrix-table th.lbl-th{text-align:left;vertical-align:middle;width:auto;max-width:none;padding-right:10px;position:static;overflow:hidden}.matrix-th-inner{white-space:nowrap;transform-origin:0 100%;display:block;position:absolute;bottom:8px;left:16px;transform:rotate(-65deg)}.matrix-table td{text-align:center;border:none;padding:2px}.matrix-cell{vertical-align:middle;border-radius:5px;width:26px;height:26px;display:inline-block}.matrix-row-label{color:#333;white-space:nowrap;padding:1px 8px 1px 0;font-size:12px;font-weight:600;text-align:left!important}.objectives-grid{gap:12px;margin-top:16px;display:grid}.objectives-col{background:#fff;border:1.5px solid #ede9fe;border-radius:12px;overflow:hidden;box-shadow:0 1px 4px #0000000d}.objectives-col-header{text-align:center;letter-spacing:.01em;border-bottom:2px solid #00000014;padding:12px 14px;font-size:13px;font-weight:800}.objectives-col-body{flex-direction:column;gap:6px;min-height:60px;padding:8px;display:flex}.obj-student-chip{color:#1f2937;background:#fff;border:1.5px solid #ede9fe;border-radius:10px;padding:6px 8px;font-size:12px;font-weight:600;transition:all .12s}.obj-student-chip[title]:hover{border-color:#a78bfa;transform:scale(1.02);box-shadow:0 1px 4px #7c3aed1a}.alert-row{background:#fff;border:1px solid #ede9fe;border-radius:10px;align-items:flex-start;gap:14px;padding:14px 16px;display:flex}.form-group{margin-bottom:14px}.form-label{color:#555;margin-bottom:5px;font-size:12px;font-weight:700;display:block}.form-input{border:1.5px solid #ede9fe;border-radius:8px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13px}.form-input:focus{border-color:#a78bfa}select.form-input{cursor:pointer}.table{border-collapse:collapse;width:100%;font-size:13px}.table th{text-align:left;color:#888;border-bottom:2px solid #ede9fe;padding:10px 12px;font-size:11px;font-weight:700}.table td{vertical-align:middle;border-bottom:1px solid #f5f3ff;padding:10px 12px}.table tr:hover td{background:#fafaff}.empty-state{text-align:center;color:#aaa;padding:48px 24px;font-size:14px}.tab-row{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.tab{cursor:pointer;color:#666;background:#fff;border:1.5px solid #ede9fe;border-radius:20px;padding:7px 16px;font-size:13px;font-weight:700}.tab.active{color:#fff;background:#7c3aed;border-color:#7c3aed}.tooltip-popup{color:#fff;z-index:200;pointer-events:none;background:#1a1a2e;border-radius:8px;max-width:220px;padding:8px 12px;font-size:12px;font-weight:600;line-height:1.4;position:fixed}.error-banner{color:#b91c1c;background:#fee2e2;border-radius:8px;margin-bottom:16px;padding:12px 20px;font-size:13px;font-weight:600}.loading-screen{color:#7c3aed;background:#f7f5ff;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:100vh;font-family:Nunito,sans-serif;font-size:16px;font-weight:700;display:flex}.spinner{border:4px solid #ede9fe;border-top-color:#7c3aed;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes input-pulse{0%{border-color:#c4b5fd;box-shadow:0 0 #7c3aed40}40%{border-color:#7c3aed;box-shadow:0 0 0 4px #7c3aed2e}to{border-color:#c4b5fd;box-shadow:0 0 #7c3aed00}}.input-highlight{animation:.9s 2 input-pulse}.sidebar-toggle{display:none}@media (max-width:1024px){.sidebar{z-index:200;height:100dvh;transition:transform .25s;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);width:230px!important}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:199;background:#0006;display:none;position:fixed;inset:0}.sidebar-overlay.open{display:block}.sidebar-toggle{z-index:198;cursor:pointer;background:#2d1b69;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:fixed;top:12px;left:12px;box-shadow:0 2px 8px #0003}.sidebar-toggle span{background:#fff;border-radius:2px;width:18px;height:2px;display:block;position:relative}.sidebar-toggle span:before,.sidebar-toggle span:after{content:"";background:#fff;border-radius:2px;width:18px;height:2px;position:absolute;left:0}.sidebar-toggle span:before{top:-5px}.sidebar-toggle span:after{top:5px}.topbar{padding-left:64px}.sidebar-logo-full{display:none}.sidebar-logo-icon{display:block}}.begrippen-chip-grid{flex-wrap:wrap;gap:8px;display:flex}.begrip-chip{color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;flex-direction:column;align-items:flex-start;padding:8px 12px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.begrip-chip:hover{background:#f5f3ff;border-color:#a78bfa}.begrip-chip.aangeboden{color:#065f46;background:#d1fae5;border-color:#34d399}.begrip-chip.aangeboden:hover{background:#a7f3d0;border-color:#10b981}.begrip-sub{color:#9ca3af;margin-top:2px;font-size:9px;font-weight:500}.begrip-chip.aangeboden .begrip-sub{color:#6ee7b7}.login-screen{background:linear-gradient(135deg,#1e1245 0%,#3b0764 60%,#2d1b69 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{border-radius:20px;width:420px;max-width:90vw;overflow:hidden;box-shadow:0 24px 64px #00000059}.login-card-header{text-align:center;background:linear-gradient(135deg,#2d1b69 0%,#4c1d95 100%);border-bottom:1px solid #ffffff14;padding:36px 32px 32px}.login-card-body{background:#fff;padding:32px 32px 36px}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{margin-bottom:8px;font-size:36px}.login-logo h1{color:#2d1b69;margin-bottom:4px;font-size:20px;font-weight:800}.login-logo p{color:#888;font-size:13px;font-weight:500}.table-scroll-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-scroll-wrap .table{width:auto;min-width:100%}@media (max-width:640px){.content{padding:16px}.student-obs-table{table-layout:auto!important}.student-obs-table th:nth-child(3),.student-obs-table td:nth-child(3),.student-obs-table th:nth-child(4),.student-obs-table td:nth-child(4),.student-obs-table th:nth-child(5),.student-obs-table td:nth-child(5){display:none}.objectives-grid{grid-template-columns:repeat(2,1fr)!important}}
