@import url("https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap");*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%}body{min-height:-webkit-fill-available}.app{display:flex;height:100vh;height:100dvh;font-family:Nunito,sans-serif;background:#F7F5FF;color:#1a1a2e}.sidebar{width:220px;background:#2D1B69;display:flex;flex-direction:column;padding:0;flex-shrink:0;transition:width .2s ease;overflow-x:hidden;overflow-y:hidden}.sidebar.collapsed{width:56px}.sidebar.collapsed .sidebar-logo{padding:10px 0;display:flex;justify-content:center;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar.collapsed .sidebar-logo>:not(.sidebar-logo-icon){display:none}.sidebar.collapsed .sidebar-logo-icon{display:flex;justify-content:center}.sidebar.collapsed .nav-badge,.sidebar.collapsed .nav-label,.sidebar.collapsed .nav-section,.sidebar.collapsed .sidebar-class-select{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%;display:flex;align-items:center;justify-content:center;padding:10px 0 max(10px,env(safe-area-inset-bottom,10px));background:none;border:none;border-top:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.45);cursor:pointer;font-size:16px;transition:color .15s;flex-shrink:0}.sidebar-collapse-btn:hover{color:#fff}.sidebar-logo{padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo-full{display:block}.sidebar-logo-icon{display:none}.sidebar-logo h1{font-size:16px;font-weight:800;color:#fff;line-height:1.3}.sidebar-logo span{font-size:11px;color:rgba(255,255,255,.5);font-weight:500}.sidebar-nav{padding:12px 0;flex:1 1;overflow-y:auto;min-height:0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-size:13px;font-weight:600;color:rgba(255,255,255,.6);cursor:pointer;border-left:3px solid transparent;transition:all .15s}.nav-item:hover{color:#fff;background:rgba(255,255,255,.06)}.nav-item.active{color:#fff;border-left-color:#A78BFA;background:rgba(167,139,250,.15)}.nav-icon{font-size:16px;width:20px;text-align:center}.nav-section{font-size:10px;font-weight:700;color:rgba(255,255,255,.3);padding:14px 20px 4px;letter-spacing:.08em;text-transform:uppercase}.main{flex:1 1;overflow-y:auto}.topbar{background:#fff;border-bottom:1px solid #ede9fe;padding:16px 28px;display:flex;align-items:center;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar h2{font-size:18px;font-weight:800;color:#1a1a2e}.topbar-sub{font-size:13px;color:#888;font-weight:500}.content{padding:24px 28px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:none;font-family:inherit;transition:all .15s}.btn-primary{background:#7C3AED;color:#fff}.btn-primary:hover{background:#6D28D9}.btn-secondary{background:#EDE9FE;color:#5B21B6}.btn-secondary:hover{background:#DDD6FE}.btn-sm{padding:5px 12px;font-size:12px}.btn-danger{background:#FEE2E2;color:#B91C1C}.card{background:#fff;border-radius:12px;border:1px solid #ede9fe;padding:20px}.student-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));grid-gap:8px;gap:8px;margin-top:16px}.student-tile{background:#fff;border:2px solid #ede9fe;border-radius:10px;padding:10px 8px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;gap:4px}.student-tile:hover{border-color:#A78BFA;transform:translateY(-2px);box-shadow:0 4px 16px rgba(124,58,237,.1)}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;background:#EDE9FE;color:#5B21B6;flex-shrink:0}.tile-name{font-size:11px;font-weight:700;text-align:center}.tile-status{font-size:9px;font-weight:600;padding:2px 6px;border-radius:20px;text-align:center;white-space:nowrap}.alert-icon{font-size:16px;cursor:pointer;opacity:.4;transition:all .15s}.alert-icon.active{opacity:1}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:16px;padding:24px;width:420px;max-width:90vw;max-height:85vh;overflow-y:auto}.modal h3{font-size:16px;font-weight:800;margin-bottom:16px}.status-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.status-option{padding:10px 14px;border-radius:8px;border:3px solid transparent;cursor:pointer;font-size:13px;font-weight:600;transition:all .12s}.status-option.selected{box-shadow:0 0 0 3px rgba(0,0,0,.35);transform:scale(1.02)}.comment-box{width:100%;padding:10px 12px;border:1.5px solid #ede9fe;border-radius:8px;font-size:13px;font-family:inherit;resize:vertical;min-height:72px;outline:none}.comment-box:focus{border-color:#A78BFA}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}.matrix-table{border-collapse:collapse;font-size:12px}.matrix-table thead tr{height:120px}.matrix-table th{padding:0 2px 6px;text-align:center;font-size:11px;font-weight:700;color:#666;vertical-align:bottom;width:32px;max-width:32px}.matrix-table th.lbl-th{width:auto;max-width:none;text-align:left;padding-right:10px;vertical-align:middle}.matrix-th-inner{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;display:block}.matrix-table td{padding:2px;text-align:center;border:none}.matrix-cell{width:26px;height:26px;border-radius:5px;display:inline-block;vertical-align:middle}.matrix-row-label{text-align:left!important;font-size:12px;font-weight:600;color:#333;padding:1px 8px 1px 0;white-space:nowrap}.objectives-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:12px;gap:12px;margin-top:16px}.objectives-col{background:#fff;border-radius:12px;border:1px solid #ede9fe;overflow:hidden}.objectives-col-header{padding:10px 12px;font-size:11px;font-weight:800;text-align:center;border-bottom:1px solid #ede9fe}.objectives-col-body{padding:8px;display:flex;flex-direction:column;gap:6px;min-height:60px}.obj-student-chip{font-size:11px;font-weight:700;padding:5px 8px;border-radius:8px;cursor:pointer;transition:all .12s}.obj-student-chip:hover{opacity:.8;transform:scale(1.02)}.alert-row{background:#fff;border:1px solid #ede9fe;border-radius:10px;padding:14px 16px;display:flex;align-items:flex-start;gap:14px}.form-group{margin-bottom:14px}.form-label{font-size:12px;font-weight:700;color:#555;margin-bottom:5px;display:block}.form-input{width:100%;padding:8px 12px;border:1.5px solid #ede9fe;border-radius:8px;font-size:13px;font-family:inherit;outline:none}.form-input:focus{border-color:#A78BFA}select.form-input{cursor:pointer}.table{width:100%;border-collapse:collapse;font-size:13px}.table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;color:#888;border-bottom:2px solid #ede9fe}.table td{padding:10px 12px;border-bottom:1px solid #f5f3ff;vertical-align:middle}.table tr:hover td{background:#FAFAFF}.empty-state{text-align:center;padding:48px 24px;color:#aaa;font-size:14px}.tab-row{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.tab{padding:7px 16px;border-radius:20px;font-size:13px;font-weight:700;cursor:pointer;border:1.5px solid #ede9fe;color:#666;background:#fff}.tab.active{background:#7C3AED;color:#fff;border-color:#7C3AED}.tooltip-popup{position:fixed;background:#1a1a2e;color:#fff;padding:8px 12px;font-size:12px;z-index:200;pointer-events:none;max-width:220px;line-height:1.4}.error-banner,.tooltip-popup{border-radius:8px;font-weight:600}.error-banner{background:#FEE2E2;color:#B91C1C;padding:12px 20px;font-size:13px;margin-bottom:16px}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;font-family:Nunito,sans-serif;font-size:16px;color:#7C3AED;font-weight:700;flex-direction:column;gap:12px;background:#F7F5FF}.spinner{width:36px;height:36px;border:4px solid #ede9fe;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.sidebar-toggle{display:none}@media (max-width:1024px){.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;z-index:200;transform:translateX(-100%);transition:transform .25s ease;width:230px!important;overflow-y:auto}.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199}.sidebar-overlay.open{display:block}.sidebar-toggle{display:flex;align-items:center;justify-content:center;position:fixed;top:12px;left:12px;z-index:198;width:40px;height:40px;border-radius:10px;background:#2D1B69;border:none;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.2)}.sidebar-toggle span{display:block;width:18px;height:2px;background:#fff;border-radius:2px;position:relative}.sidebar-toggle span:after,.sidebar-toggle span:before{content:"";position:absolute;width:18px;height:2px;background:#fff;border-radius:2px;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{display:flex;flex-wrap:wrap;gap:8px}.begrip-chip{display:inline-flex;flex-direction:column;align-items:flex-start;padding:8px 12px;border-radius:10px;border:2px solid #e5e7eb;background:#F9FAFB;color:#374151;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.begrip-chip:hover{border-color:#A78BFA;background:#F5F3FF}.begrip-chip.aangeboden{background:#D1FAE5;border-color:#34D399;color:#065F46}.begrip-chip.aangeboden:hover{background:#A7F3D0;border-color:#10B981}.begrip-sub{font-size:9px;font-weight:500;color:#9CA3AF;margin-top:2px}.begrip-chip.aangeboden .begrip-sub{color:#6EE7B7}.login-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:#F7F5FF}.login-card{background:#fff;border-radius:16px;border:1px solid #ede9fe;padding:36px 32px;width:420px;max-width:90vw;box-shadow:0 8px 32px rgba(124,58,237,.08)}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{font-size:36px;margin-bottom:8px}.login-logo h1{font-size:20px;font-weight:800;color:#2D1B69;margin-bottom:4px}.login-logo p{font-size:13px;color:#888;font-weight:500}