@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700&family=Poppins:wght@600;800&display=swap";.interstitial-wrapper{box-sizing:border-box;font-size:1em;line-height:1.6em;margin:50px auto 0;max-width:600px;width:100%}@media (max-width:700px){.interstitial-wrapper{padding:0 10%}}@media (max-height:600px){.interstitial-wrapper{margin-top:5px}}@media (max-width:400px){.interstitial-wrapper{padding:0 5%}}.hidden,html[subframe] #main-frame-error{display:none}html[subframe] body{overflow:hidden}#buttons:after{clear:both;content:"";display:block;width:100%}.offline .interstitial-wrapper{color:#2b2b2b;font-size:1em;line-height:1.55;margin:100px auto 0;max-width:600px;width:100%}.offline .runner-container{top:10px;width:44px;z-index:2}.offline .runner-canvas,.offline .runner-container{height:150px;max-width:600px;overflow:hidden;position:absolute}.offline .runner-canvas{opacity:1;top:0}.offline .controller{background:#f7f7f71a;height:100vh;left:0;position:absolute;top:0;width:100vw;z-index:1}#offline-resources{display:none}@media (max-height:350px){.interstitial-wrapper{margin-top:5%}}.td-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:#f8f9fb;overflow:hidden}.td-header{flex:0 0 auto;background:#fff;border-bottom:1px solid #e8eaed;box-shadow:0 1px 8px #0000000a}.td-header-content{max-width:960px;margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}.td-header-left{display:flex;align-items:center;gap:12px}.td-logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.td-header-text{display:flex;flex-direction:column;gap:0}.td-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#1e293b;letter-spacing:-.02em;line-height:1.2}.td-subtitle{font-size:.75rem;color:#94a3b8;line-height:1.3}.td-header-right{display:flex;align-items:center;gap:8px}.td-header-btn{width:36px;height:36px;border-radius:9px;border:1px solid #e8eaed;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.td-header-btn:hover{background:#f1f5f9;color:#334155;border-color:#cbd5e1}.td-header-btn--logout:hover{background:#fef2f2;color:#dc2626;border-color:#fecaca}.td-main{flex:1;overflow-y:auto;padding:32px 2rem 48px}.td-content{max-width:960px;margin:0 auto}.td-stats-row{display:flex;align-items:center;gap:24px;margin-bottom:32px;padding:20px 28px;background:#fff;border-radius:14px;border:1px solid #e8eaed;box-shadow:0 1px 4px #00000008}.td-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.td-stat-value{font-family:Poppins,sans-serif;font-size:1.75rem;font-weight:700;color:#1e293b;line-height:1}.td-stat-label{font-size:.78rem;color:#94a3b8;font-weight:500}.td-stat-divider{width:1px;height:36px;background:#e8eaed;flex-shrink:0}.td-class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.td-class-card{background:#fff;border-radius:14px;border:1px solid #e8eaed;overflow:hidden;box-shadow:0 1px 4px #00000008;transition:all .25s cubic-bezier(.34,1.56,.64,1)}.td-class-card:hover{border-color:#bae6fd;box-shadow:0 4px 16px #0ea5e91a;transform:translateY(-2px)}.td-class-card-main{display:flex;flex-direction:column;padding:20px 20px 16px;border:none;background:none;cursor:pointer;width:100%;text-align:left;font-family:inherit}.td-class-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.td-class-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);display:flex;align-items:center;justify-content:center;color:#0284c7}.td-class-chevron{color:#cbd5e1;transition:transform .2s,color .2s}.td-class-card:hover .td-class-chevron{color:#0ea5e9;transform:translate(2px)}.td-class-name{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1e293b;margin-bottom:6px;letter-spacing:-.01em}.td-class-meta{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#64748b}.td-class-meta-dot{width:3px;height:3px;border-radius:50%;background:#cbd5e1}.td-class-card-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#f8fafc;border-top:1px solid #f1f5f9}.td-class-code{display:flex;align-items:center;gap:6px;color:#94a3b8;font-size:.78rem}.td-class-code code{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:.78rem;color:#64748b;font-weight:500}.td-class-copy-btn{width:28px;height:28px;border-radius:7px;border:none;background:transparent;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.td-class-copy-btn:hover{background:#e0f2fe;color:#0284c7}.td-add-class-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 20px;border-radius:14px;border:2px dashed #d1d5db;background:transparent;cursor:pointer;transition:all .2s;font-family:inherit;min-height:180px}.td-add-class-card:hover{border-color:#0ea5e9;background:#0ea5e90a}.td-add-icon{width:48px;height:48px;border-radius:12px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:all .2s}.td-add-class-card:hover .td-add-icon{background:#e0f2fe;color:#0284c7}.td-add-label{font-size:.85rem;font-weight:600;color:#94a3b8;transition:color .2s}.td-add-class-card:hover .td-add-label{color:#0284c7}.td-add-form-card{background:#fff;border-radius:14px;border:1px solid #bae6fd;padding:20px;box-shadow:0 2px 12px #0ea5e914}.td-add-form{display:flex;flex-direction:column;gap:12px}.td-add-field{display:flex;flex-direction:column;gap:4px}.td-add-field-label{font-size:.75rem;font-weight:600;color:#64748b;letter-spacing:.02em}.td-add-input{padding:8px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;font-family:Inter,system-ui,sans-serif;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .2s,box-shadow .2s}.td-add-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a;background:#fff}.td-add-input::-moz-placeholder{color:#94a3b8}.td-add-input::placeholder{color:#94a3b8}.td-add-error{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#dc2626;background:#fef2f2;padding:6px 10px;border-radius:7px}.td-add-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.td-add-cancel{padding:7px 16px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:.82rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.td-add-cancel:hover{background:#f1f5f9}.td-add-submit{padding:7px 18px;border-radius:8px;border:none;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.td-add-submit:hover{background:linear-gradient(135deg,#0284c7,#0369a1);box-shadow:0 2px 8px #0ea5e94d}.td-add-submit:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.td-nav-section{margin-top:32px}.td-nav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.td-nav-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:22px 12px 18px;border-radius:14px;border:1px solid #e8eaed;background:#fff;cursor:pointer;font-family:inherit;transition:all .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 4px #00000008}.td-nav-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000014}.td-nav-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.td-nav-card:hover .td-nav-card-icon{transform:scale(1.08)}.td-nav-card-label{font-size:.8rem;font-weight:650;letter-spacing:-.01em;line-height:1}.td-nav-card--weektaak .td-nav-card-icon{background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:#0284c7}.td-nav-card--weektaak:hover{border-color:#bae6fd}.td-nav-card--weektaak .td-nav-card-label{color:#0369a1}.td-nav-card--planning .td-nav-card-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#b45309}.td-nav-card--planning:hover{border-color:#fde68a}.td-nav-card--planning .td-nav-card-label{color:#92400e}.td-nav-card--randomizer .td-nav-card-icon{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.td-nav-card--randomizer:hover{border-color:#bbf7d0}.td-nav-card--randomizer .td-nav-card-label{color:#166534}.td-nav-card--spaarpot .td-nav-card-icon{background:linear-gradient(135deg,#ffe4e6,#fecdd3);color:#be123c}.td-nav-card--spaarpot:hover{border-color:#fecdd3}.td-nav-card--spaarpot .td-nav-card-label{color:#9f1239}.td-nav-card--space .td-nav-card-icon{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4338ca}.td-nav-card--space:hover{border-color:#c7d2fe}.td-nav-card--space .td-nav-card-label{color:#3730a3}.td-nav-card--werkwoorden .td-nav-card-icon{background:linear-gradient(135deg,#fce7f3,#fbcfe8);color:#be185d}.td-nav-card--werkwoorden:hover{border-color:#fbcfe8}.td-nav-card--werkwoorden .td-nav-card-label{color:#9d174d}.td-tiles-section{margin-top:32px;background:#fff;border-radius:14px;border:1px solid #e8eaed;padding:18px 20px;box-shadow:0 1px 4px #00000008}.td-tiles-header{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:#475569;margin-bottom:14px;letter-spacing:-.01em}.td-tiles-row{display:flex;flex-wrap:wrap;gap:8px}.td-tile-toggle{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1.5px solid #e2e8f0;background:#f8fafc;color:#94a3b8;font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .18s}.td-tile-toggle:hover{border-color:#cbd5e1;background:#f1f5f9;color:#64748b}.td-tile-toggle--active{border-color:#bae6fd;background:#f0f9ff;color:#0284c7}.td-tile-toggle--active:hover{border-color:#7dd3fc;background:#e0f2fe;color:#0369a1}.td-tile-toggle-icon{display:flex;align-items:center}.td-tile-toggle-label{line-height:1}.tcd-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:#f8f9fb;overflow:hidden}.tcd-header{flex:0 0 auto;background:#fff;border-bottom:1px solid #e8eaed;box-shadow:0 1px 8px #0000000a}.tcd-header-content{max-width:720px;margin:0 auto;padding:0 2rem;height:60px;display:flex;align-items:center;gap:14px}.tcd-back-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e8eaed;background:#fff;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.tcd-back-btn:hover{background:#f1f5f9;color:#334155}.tcd-header-text{display:flex;align-items:baseline;gap:10px}.tcd-header-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#1e293b;letter-spacing:-.02em}.tcd-header-count{font-size:.78rem;color:#94a3b8;font-weight:500}.tcd-main{flex:1;overflow-y:auto;padding:24px 2rem 48px}.tcd-content{max-width:720px;margin:0 auto}.tcd-code-bar{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#fff;border-radius:12px;border:1px solid #e8eaed;margin-bottom:20px;flex-wrap:wrap}.tcd-code-label{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:#64748b;flex-shrink:0}.tcd-code-display{display:flex;align-items:center;gap:8px;flex:1}.tcd-code-value{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:.9rem;font-weight:600;color:#0c4a6e;background:#f0f9ff;padding:4px 10px;border-radius:6px}.tcd-code-action{width:30px;height:30px;border-radius:7px;border:none;background:transparent;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.tcd-code-action:hover{background:#e0f2fe;color:#0284c7}.tcd-code-edit-row{display:flex;align-items:center;gap:8px;flex:1}.tcd-code-input{padding:6px 10px;border:1.5px solid #bae6fd;border-radius:7px;font-family:JetBrains Mono,SF Mono,monospace;font-size:.85rem;color:#0c4a6e;background:#f0f9ff;outline:none;flex:1;min-width:0}.tcd-code-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 2px #0ea5e91f}.tcd-code-save{padding:5px 12px;border-radius:6px;border:none;background:#0ea5e9;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.tcd-code-save:hover{background:#0284c7}.tcd-code-cancel{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#94a3b8;cursor:pointer;display:flex;align-items:center;justify-content:center}.tcd-code-cancel:hover{background:#fee2e2;color:#dc2626}.tcd-code-error{display:flex;align-items:center;gap:5px;font-size:.75rem;color:#dc2626;width:100%;margin-top:4px}.tcd-tabs{display:flex;gap:4px;margin-bottom:16px;background:#fff;border-radius:10px;padding:4px;border:1px solid #e8eaed}.tcd-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:7px;border:none;background:transparent;color:#64748b;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s}.tcd-tab:hover{background:#f1f5f9;color:#334155}.tcd-tab--active{background:#0ea5e9;color:#fff;box-shadow:0 1px 4px #0ea5e940}.tcd-tab--active:hover{background:#0284c7;color:#fff}.tcd-tab-count{font-size:.72rem;font-weight:700;padding:1px 6px;border-radius:99px;background:#0000000f}.tcd-tab--active .tcd-tab-count{background:#ffffff40}.tcd-panel{background:#fff;border-radius:14px;border:1px solid #e8eaed;overflow:hidden}.tcd-panel-toolbar{padding:14px 18px;border-bottom:1px solid #f1f5f9}.tcd-search-wrap{position:relative}.tcd-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.tcd-search-input{width:100%;padding:8px 12px 8px 34px;border:1.5px solid #e8eaed;border-radius:8px;font-size:.85rem;font-family:inherit;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .2s,box-shadow .2s}.tcd-search-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e914;background:#fff}.tcd-search-input::-moz-placeholder{color:#94a3b8}.tcd-search-input::placeholder{color:#94a3b8}.tcd-add-row{display:flex;align-items:center;gap:8px;padding:12px 18px;border-bottom:1px solid #f1f5f9;background:#fafbfc}.tcd-add-row-icon{color:#94a3b8;flex-shrink:0}.tcd-add-input{flex:1;padding:7px 10px;border:1.5px solid #e2e8f0;border-radius:7px;font-size:.85rem;font-family:inherit;color:#1e293b;background:#fff;outline:none;transition:border-color .2s;min-width:0}.tcd-add-input:focus{border-color:#0ea5e9}.tcd-add-input::-moz-placeholder{color:#94a3b8}.tcd-add-input::placeholder{color:#94a3b8}.tcd-add-group-select{padding:7px 8px;border:1.5px solid #e2e8f0;border-radius:7px;font-size:.8rem;font-family:inherit;color:#64748b;background:#fff;outline:none;cursor:pointer}.tcd-add-btn{width:34px;height:34px;border-radius:8px;border:none;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.tcd-add-btn:hover{background:linear-gradient(135deg,#0284c7,#0369a1);box-shadow:0 2px 6px #0ea5e94d}.tcd-add-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.tcd-pupil-list{padding:0}.tcd-group-section{border-bottom:1px solid #f1f5f9}.tcd-group-section:last-child{border-bottom:none}.tcd-group-header{display:flex;align-items:center;gap:6px;padding:10px 18px;font-size:.75rem;font-weight:700;color:#0284c7;background:#f0f9ff;text-transform:uppercase;letter-spacing:.04em}.tcd-group-header--ungrouped{color:#94a3b8;background:#f8fafc}.tcd-group-header-count{font-size:.7rem;font-weight:600;background:#0000000f;padding:1px 6px;border-radius:99px}.tcd-group-empty{padding:12px 18px 12px 40px;font-size:.78rem;color:#94a3b8;font-style:italic}.tcd-pupil-row{display:flex;align-items:center;gap:12px;padding:10px 18px;border-bottom:1px solid #f8f9fa;transition:background .12s}.tcd-pupil-row:hover{background:#fafbfc}.tcd-pupil-row:last-child{border-bottom:none}.tcd-pupil-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);display:flex;align-items:center;justify-content:center;font-family:Poppins,sans-serif;font-size:.78rem;font-weight:700;color:#0284c7;flex-shrink:0}.tcd-pupil-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.tcd-pupil-name{font-size:.875rem;font-weight:600;color:#1e293b}.tcd-pupil-badges{display:flex;align-items:center;gap:4px}.tcd-badge{font-size:.65rem;font-weight:600;padding:1px 6px;border-radius:4px;line-height:1.5}.tcd-badge--linked{background:#dcfce7;color:#16a34a}.tcd-badge--email{background:#f1f5f9;color:#64748b;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tcd-pupil-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.tcd-pupil-group-select{padding:4px 6px;border:1px solid #e2e8f0;border-radius:6px;font-size:.75rem;font-family:inherit;color:#64748b;background:#fff;outline:none;cursor:pointer;max-width:120px}.tcd-pupil-delete-btn{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#cbd5e1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.tcd-pupil-delete-btn:hover{background:#fee2e2;color:#dc2626}.tcd-empty{display:flex;flex-direction:column;align-items:center;gap:6px;padding:40px 20px;color:#94a3b8;text-align:center}.tcd-empty p{font-size:.9rem;font-weight:600;color:#64748b}.tcd-empty span{font-size:.78rem;color:#94a3b8}.tcd-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:#64748b}.tcd-back-link{padding:8px 16px;border-radius:8px;border:none;background:#0ea5e9;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit}.tcd-group-list{padding:8px;display:flex;flex-direction:column;gap:4px}.tcd-group-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:#f8fafc;border:1px solid #f1f5f9;transition:background .12s}.tcd-group-card:hover{background:#f1f5f9}.tcd-group-card-icon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);display:flex;align-items:center;justify-content:center;color:#0284c7;flex-shrink:0}.tcd-group-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.tcd-group-card-name{font-size:.875rem;font-weight:600;color:#1e293b}.tcd-group-card-count{font-size:.75rem;color:#94a3b8}.tcd-group-card-delete{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#cbd5e1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.tcd-group-card-delete:hover{background:#fee2e2;color:#dc2626}.tcd-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.tcd-confirm-modal{background:#fff;border-radius:16px;padding:28px 24px 20px;max-width:360px;width:100%;box-shadow:0 20px 60px #00000026}.tcd-confirm-title{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1e293b;margin-bottom:6px}.tcd-confirm-text{font-size:.85rem;color:#64748b;line-height:1.5;margin-bottom:20px}.tcd-confirm-actions{display:flex;gap:8px;justify-content:flex-end}.tcd-confirm-cancel{padding:8px 16px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:.82rem;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s}.tcd-confirm-cancel:hover{background:#f1f5f9}.tcd-confirm-delete{padding:8px 16px;border-radius:8px;border:none;background:#dc2626;color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.tcd-confirm-delete:hover{background:#b91c1c}@media (max-width: 640px){.td-header-content{padding:0 1rem}.td-main{padding:20px 1rem 40px}.td-stats-row{padding:16px 20px;gap:16px}.td-stat-value{font-size:1.35rem}.td-class-grid{grid-template-columns:1fr;gap:12px}.td-nav-grid{grid-template-columns:repeat(3,1fr);gap:8px}.td-nav-card{padding:16px 8px 14px;gap:8px}.td-nav-card-icon{width:40px;height:40px;border-radius:10px}.td-nav-card-icon svg{width:18px;height:18px}.td-nav-card-label{font-size:.72rem}.tcd-header-content{padding:0 1rem}.tcd-main{padding:16px 1rem 40px}.tcd-pupil-actions{flex-direction:column;gap:4px}.tcd-pupil-group-select{max-width:100%}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.mx-4{margin-left:1rem;margin-right:1rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.-mt-0\.5{margin-top:-.125rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-0\.5{margin-left:.125rem}.ml-2{margin-left:.5rem}.mr-0\.5{margin-right:.125rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-2{height:.5rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-16{width:4rem}.w-44{width:11rem}.w-5{width:1.25rem}.w-7{width:1.75rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[140px\]{min-width:140px}.min-w-\[160px\]{min-width:160px}.min-w-\[500px\]{min-width:500px}.min-w-\[60px\]{min-width:60px}.max-w-2xl{max-width:42rem}.max-w-6xl{max-width:72rem}.max-w-\[80px\]{max-width:80px}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x: 100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-\[fadeIn_0\.3s_ease-out\]{animation:fadeIn .3s ease-out}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-none{border-radius:0}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-emerald-200{--tw-border-opacity: 1;border-color:rgb(167 243 208 / var(--tw-border-opacity, 1))}.border-emerald-200\/60{border-color:#a7f3d099}.border-emerald-500{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))}.border-sky-200{--tw-border-opacity: 1;border-color:rgb(186 230 253 / var(--tw-border-opacity, 1))}.border-sky-300{--tw-border-opacity: 1;border-color:rgb(125 211 252 / var(--tw-border-opacity, 1))}.border-sky-500{--tw-border-opacity: 1;border-color:rgb(14 165 233 / var(--tw-border-opacity, 1))}.border-slate-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-slate-200\/60{border-color:#e2e8f099}.border-slate-300{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.border-slate-50{--tw-border-opacity: 1;border-color:rgb(248 250 252 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.bg-black\/20{background-color:#0003}.bg-black\/30{background-color:#0000004d}.bg-emerald-100{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity, 1))}.bg-emerald-50{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.bg-emerald-50\/40{background-color:#ecfdf566}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-sky-100{--tw-bg-opacity: 1;background-color:rgb(224 242 254 / var(--tw-bg-opacity, 1))}.bg-sky-400{--tw-bg-opacity: 1;background-color:rgb(56 189 248 / var(--tw-bg-opacity, 1))}.bg-sky-50{--tw-bg-opacity: 1;background-color:rgb(240 249 255 / var(--tw-bg-opacity, 1))}.bg-sky-500{--tw-bg-opacity: 1;background-color:rgb(14 165 233 / var(--tw-bg-opacity, 1))}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.bg-slate-200{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity, 1))}.bg-slate-50{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity, 1))}.bg-slate-50\/30{background-color:#f8fafc4d}.bg-slate-50\/50{background-color:#f8fafc80}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/80{background-color:#fffc}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.from-slate-50{--tw-gradient-from: #f8fafc var(--tw-gradient-from-position);--tw-gradient-to: rgb(248 250 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-slate-100{--tw-gradient-to: #f1f5f9 var(--tw-gradient-to-position)}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-3{padding-bottom:.75rem}.pb-5{padding-bottom:1.25rem}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-tight{line-height:1.25}.tracking-wider{letter-spacing:.05em}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity, 1))}.text-emerald-500{--tw-text-opacity: 1;color:rgb(16 185 129 / var(--tw-text-opacity, 1))}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-emerald-600\/70{color:#059669b3}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-sky-500{--tw-text-opacity: 1;color:rgb(14 165 233 / var(--tw-text-opacity, 1))}.text-sky-600{--tw-text-opacity: 1;color:rgb(2 132 199 / var(--tw-text-opacity, 1))}.text-sky-700{--tw-text-opacity: 1;color:rgb(3 105 161 / var(--tw-text-opacity, 1))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.line-through{text-decoration-line:line-through}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-emerald-200{--tw-shadow-color: #a7f3d0;--tw-shadow: var(--tw-shadow-colored)}.shadow-sky-200{--tw-shadow-color: #bae6fd;--tw-shadow: var(--tw-shadow-colored)}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes floatUp{0%{opacity:1;transform:translateY(0) scale(1)}60%{opacity:.9;transform:translateY(-40px) scale(1.1)}to{opacity:0;transform:translateY(-80px) scale(.9)}}@keyframes piggyBounce{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.04) rotate(-1deg)}75%{transform:scale(1.04) rotate(1deg)}}@keyframes coinSpin{0%{transform:rotateY(0) scale(1.1)}to{transform:rotateY(360deg) scale(1)}}@keyframes headerShimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes totalPop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100svw;height:100svh;overflow:hidden;font-family:Inter,system-ui,sans-serif}.app-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 30%,#fff8ee,#fff0dc 40%,#ffe8cc);overflow:hidden;position:relative}.app-header{flex:0 0 auto;background:#ffffffeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(245,158,11,.15);box-shadow:0 2px 20px #00000012;z-index:10}.header-content{max-width:100%;padding:0 2rem;height:68px;display:flex;align-items:center;justify-content:space-between}.header-right{display:flex;align-items:center;gap:1rem}.app-title{font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,#d97706,#f59e0b,#fbbf24);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:headerShimmer 4s linear infinite;letter-spacing:-.02em}.total-display{display:flex;flex-direction:column;align-items:flex-end;gap:1px}.total-label{font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af}.total-amount{font-family:Poppins,sans-serif;font-size:1.7rem;font-weight:800;color:#1f2937;letter-spacing:-.03em;transition:all .3s ease}.app-main{flex:1 1 0;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.piggy-drop-zone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;width:min(520px,90vw);height:min(400px,70vh);cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none}.piggy-drop-zone--active{cursor:copy}.piggy-image-wrapper{position:relative;z-index:2;width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;filter:drop-shadow(0 0 0px transparent)}.piggy-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center bottom;object-position:center bottom;transition:transform .25s cubic-bezier(.34,1.56,.64,1),filter .25s ease;filter:drop-shadow(0 12px 30px rgba(255,150,130,.35));pointer-events:none}.piggy-image--hover{transform:scale(1.035);filter:drop-shadow(0 18px 40px rgba(255,150,130,.55)) brightness(1.05)}.piggy-image--dropped{animation:piggyBounce .5s ease}.piggy-total{position:absolute;bottom:22%;left:50%;transform:translate(-50%);font-family:Poppins,sans-serif;font-size:clamp(1rem,2.5vw,1.5rem);font-weight:800;color:#fffffff2;text-shadow:0 2px 8px rgba(180,60,40,.5),0 1px 3px rgba(0,0,0,.3);white-space:nowrap;pointer-events:none;transition:transform .2s ease;letter-spacing:-.02em}.piggy-total--pop{animation:totalPop .35s cubic-bezier(.34,1.56,.64,1)}.piggy-overlay,.piggy-overlay--drag-over,.piggy-overlay--dropped{display:none}.floating-amount{position:absolute;z-index:10;font-family:Poppins,sans-serif;font-size:1.4rem;font-weight:800;color:#059669;text-shadow:0 2px 8px rgba(0,0,0,.2),0 0 20px rgba(5,150,105,.4);pointer-events:none;animation:floatUp 1.2s ease-out forwards;transform:translate(-50%);white-space:nowrap}.app-footer{flex:0 0 auto;z-index:10}.money-tray{background:#ffffffe0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(245,158,11,.18);box-shadow:0 -4px 24px #00000014;padding:10px 0 12px}.tray-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#9ca3af;text-align:center;margin-bottom:8px}.tray-scroll-area{display:flex;align-items:center;justify-content:center;overflow-x:auto;overflow-y:hidden;padding:0 1.5rem;gap:0;scrollbar-width:thin;scrollbar-color:rgba(245,158,11,.3) transparent}.tray-scroll-area::-webkit-scrollbar{height:3px}.tray-scroll-area::-webkit-scrollbar-track{background:transparent}.tray-scroll-area::-webkit-scrollbar-thumb{background:#f59e0b66;border-radius:2px}.tray-section{display:flex;flex-direction:column;gap:5px;flex-shrink:0}.tray-section-label{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#d1d5db;text-align:center}.tray-row{display:flex;align-items:center;gap:10px}.tray-divider{width:1px;height:64px;background:linear-gradient(to bottom,transparent,rgba(245,158,11,.25),transparent);margin:16px 18px 0;flex-shrink:0;align-self:center}.coin-item{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:grab;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease;flex-shrink:0;position:relative}.coin-item:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:50%;border:1px solid rgba(255,255,255,.25);pointer-events:none}.coin-item:hover{transform:scale(1.14) translateY(-3px);cursor:grabbing}.coin-item:active{transform:scale(.95);cursor:grabbing}.coin-label{font-family:Poppins,sans-serif;font-size:.58rem;font-weight:700;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.5);letter-spacing:-.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bill-item{width:100px;height:54px;border-radius:6px;display:flex;align-items:center;justify-content:space-between;cursor:grab;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease;flex-shrink:0;position:relative;overflow:hidden}.bill-item:hover{transform:scale(1.08) translateY(-4px) rotate(-1deg);cursor:grabbing}.bill-item:active{transform:scale(.96);cursor:grabbing}.bill-watermark{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 60% 40%,rgba(255,255,255,.12) 0%,transparent 65%);pointer-events:none}.bill-left-stripe,.bill-right-stripe{width:8px;height:100%;flex-shrink:0;opacity:.7;filter:brightness(.7)}.bill-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bill-eu-symbol{font-family:Poppins,sans-serif;font-size:.6rem;font-weight:600;color:#ffffffbf;line-height:1}.bill-value{font-family:Poppins,sans-serif;font-size:1.25rem;font-weight:800;color:#fffffff7;text-shadow:0 1px 4px rgba(0,0,0,.35);line-height:1;letter-spacing:-.03em}.touch-drag-ghost{position:fixed;z-index:9999;pointer-events:none;transform:translate(-50%,-50%) scale(1.15);opacity:.9;transition:opacity .1s ease}.touch-ghost-coin{animation:coinSpin .4s ease-out}.touch-ghost-bill{transform:rotate(-3deg)}.header-history-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid rgba(245,158,11,.2);background:#f59e0b14;color:#d97706;cursor:pointer;transition:all .2s ease}.header-history-btn:hover{background:#f59e0b26;border-color:#f59e0b59;transform:scale(1.05)}.header-history-btn:active{transform:scale(.95)}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes drawerSlideOut{0%{transform:translate(0)}to{transform:translate(100%)}}.history-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000;pointer-events:none;transition:background .3s ease}.history-backdrop--open{background:#00000059;pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.history-drawer{position:fixed;top:0;right:0;bottom:0;width:min(400px,90vw);z-index:101;background:#fefefe;box-shadow:-8px 0 40px #0000001f;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.history-drawer--open{transform:translate(0)}.history-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.06)}.history-header-left{display:flex;align-items:center;gap:10px}.history-header-icon{color:#d97706}.history-title{font-family:Poppins,sans-serif;font-size:1.15rem;font-weight:700;color:#1f2937;letter-spacing:-.02em}.history-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.history-close:hover{background:#00000014;color:#1f2937}.history-summary{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;padding:20px 24px;background:linear-gradient(135deg,#f59e0b0f,#d977060a);border-bottom:1px solid rgba(0,0,0,.05)}.history-summary-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#9ca3af}.history-summary-amount{font-family:Poppins,sans-serif;font-size:1.6rem;font-weight:800;color:#1f2937;letter-spacing:-.03em}.history-summary-count{font-size:.75rem;color:#9ca3af}.history-list{flex:1 1 0;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(245,158,11,.2) transparent}.history-list::-webkit-scrollbar{width:4px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background:#f59e0b40;border-radius:2px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 24px;color:#9ca3af;text-align:center}.history-empty-icon{color:#d1d5db;margin-bottom:4px}.history-empty-sub{font-size:.8rem;color:#d1d5db}.history-group{margin-bottom:4px}.history-date-header{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#9ca3af;padding:12px 24px 6px;position:sticky;top:0;background:#fefefe;z-index:1}.history-row{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;transition:background .15s ease}.history-row:hover{background:#00000005}.history-row-left{display:flex;align-items:center;gap:12px}.history-row-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);flex-shrink:0;box-shadow:0 0 0 3px #f59e0b1f}.history-row-info{display:flex;flex-direction:column;gap:1px}.history-row-desc{font-size:.88rem;font-weight:500;color:#374151}.history-row-time{font-size:.72rem;color:#9ca3af}.history-row-right{display:flex;align-items:center;gap:8px}.history-row-amount{font-family:Poppins,sans-serif;font-size:.92rem;font-weight:700;color:#059669;letter-spacing:-.02em;white-space:nowrap}.history-row-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:#ef444414;color:#dc2626;cursor:pointer;transition:all .15s ease;opacity:0;transform:scale(.9)}.history-row:hover .history-row-delete{opacity:1;transform:scale(1)}.history-row-delete:hover{background:#ef444426;color:#b91c1c}.history-row-delete:disabled{opacity:.5;cursor:not-allowed}.history-row--deleting{opacity:.5;pointer-events:none}.history-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:102;background:#0006;display:flex;align-items:flex-end;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.history-confirm-modal{width:100%;max-width:380px;margin:auto;background:#fefefe;border-radius:16px;box-shadow:0 20px 60px #00000040;overflow:hidden;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.history-confirm-header{padding:20px 24px 12px;border-bottom:1px solid rgba(0,0,0,.05)}.history-confirm-header h3{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1f2937;margin:0;letter-spacing:-.02em}.history-confirm-body{padding:16px 24px;color:#6b7280;font-size:.9rem;line-height:1.5}.history-confirm-body strong{color:#1f2937;font-weight:600}.history-confirm-actions{display:flex;gap:12px;padding:12px 24px 20px;justify-content:flex-end}.history-confirm-cancel,.history-confirm-delete{padding:8px 20px;border-radius:8px;border:none;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease}.history-confirm-cancel{background:#0000000d;color:#6b7280}.history-confirm-cancel:hover:not(:disabled){background:#0000001a;color:#1f2937}.history-confirm-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.history-confirm-delete:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.history-confirm-delete:disabled,.history-confirm-cancel:disabled{opacity:.6;cursor:not-allowed}@keyframes onboardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes onboardPupilIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.onboard-root{width:100svw;height:100svh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0,#f1f5f9);font-family:Inter,system-ui,sans-serif;padding:1rem;position:relative}.onboard-header{position:absolute;top:1rem;right:1rem}.onboard-card{width:100%;max-width:460px;background:#fff;border-radius:20px;padding:2.5rem 2rem;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;display:flex;flex-direction:column;align-items:center;animation:onboardFadeIn .4s ease-out}.onboard-card--wide{max-width:520px}.onboard-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);display:flex;align-items:center;justify-content:center;color:#0284c7;margin-bottom:1.25rem}.onboard-icon--success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.onboard-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:700;color:#1e293b;text-align:center;margin-bottom:.375rem}.onboard-subtitle{font-size:.875rem;color:#64748b;text-align:center;margin-bottom:1.75rem;line-height:1.6;max-width:360px}.onboard-form{width:100%;display:flex;flex-direction:column;gap:1rem}.onboard-field{display:flex;flex-direction:column;gap:.375rem}.onboard-label{font-size:.8rem;font-weight:600;color:#475569;letter-spacing:.02em}.onboard-code-hint{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#94a3b8}.onboard-input{width:100%;padding:.75rem 1rem;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.95rem;font-family:Inter,system-ui,sans-serif;color:#1e293b;background:#f8fafc;transition:border-color .2s,box-shadow .2s;outline:none}.onboard-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f;background:#fff}.onboard-input::-moz-placeholder{color:#94a3b8}.onboard-input::placeholder{color:#94a3b8}.onboard-error{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#dc2626;background:#fef2f2;padding:.5rem .75rem;border-radius:8px}.onboard-btn{width:100%;padding:.75rem 1.25rem;border:none;border-radius:10px;font-size:.95rem;font-weight:600;font-family:Inter,system-ui,sans-serif;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:.5rem}.onboard-btn--primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff}.onboard-btn--primary:hover{background:linear-gradient(135deg,#0284c7,#0369a1);transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e94d}.onboard-btn--primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.onboard-btn-count{font-size:.75rem;font-weight:500;opacity:.8;padding:.125rem .5rem;background:#fff3;border-radius:99px}.onboard-code-display{width:100%;background:#f0f9ff;border:1.5px solid #bae6fd;border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.onboard-code-label{font-size:.75rem;font-weight:600;color:#0369a1;text-transform:uppercase;letter-spacing:.05em}.onboard-code-row{display:flex;align-items:center;gap:.75rem}.onboard-code-value{font-family:JetBrains Mono,SF Mono,Fira Code,monospace;font-size:1.25rem;font-weight:600;color:#0c4a6e;letter-spacing:.02em;flex:1}.onboard-code-copy{width:32px;height:32px;border:none;background:#e0f2fe;color:#0284c7;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.onboard-code-copy:hover{background:#bae6fd}.onboard-pupils-section{width:100%;margin-bottom:.5rem}.onboard-pupils-title{font-family:Poppins,sans-serif;font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:.25rem}.onboard-pupils-hint{font-size:.8rem;color:#64748b;margin-bottom:1rem;line-height:1.5}.onboard-add-pupil-form{display:flex;gap:.5rem;margin-bottom:.75rem}.onboard-add-pupil-form .onboard-input{flex:1}.onboard-add-pupil-btn{width:44px;height:44px;border:none;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.onboard-add-pupil-btn:hover{background:linear-gradient(135deg,#0284c7,#0369a1);transform:translateY(-1px);box-shadow:0 2px 8px #0ea5e94d}.onboard-add-pupil-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.onboard-pupil-list{display:flex;flex-direction:column;gap:.25rem;max-height:240px;overflow-y:auto;margin-bottom:.5rem}.onboard-pupil-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;animation:onboardPupilIn .25s ease-out both}.onboard-pupil-name{font-size:.875rem;font-weight:500;color:#334155}.onboard-pupil-delete{width:28px;height:28px;border:none;background:transparent;color:#94a3b8;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.onboard-pupil-delete:hover{background:#fee2e2;color:#dc2626}.onboard-pupil-empty{font-size:.8rem;color:#94a3b8;text-align:center;padding:1.5rem 0}@media (max-width: 480px){.onboard-card{padding:2rem 1.5rem;border-radius:16px}.onboard-title{font-size:1.25rem}}.dashboard-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);overflow:hidden}.dashboard-header{padding:24px 20px 16px;background:linear-gradient(135deg,#fffffff2,#ffffffd9);border-bottom:1px solid rgba(0,0,0,.06);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dashboard-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:800;color:#1f2937;text-align:center;letter-spacing:-.03em}.dashboard-main{flex:1;padding:32px 20px;overflow-y:auto;display:flex;justify-content:center;align-items:flex-start}.dashboard-layout{display:flex;flex-direction:column;gap:24px;width:100%;max-width:100%}.dashboard-widget-row{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;width:100%}.dashboard-tile-row{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;width:100%}.dashboard-section-label{display:flex;align-items:center;gap:7px;font-family:Poppins,sans-serif;font-size:.78rem;font-weight:700;color:#64748b;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}.dashboard-card--dino .dashboard-card-icon{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.dashboard-card{position:relative;aspect-ratio:1;border:none;border-radius:20px;background:#fff;box-shadow:0 8px 24px #0000001f;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden;padding:0}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000002e}.dashboard-card:active{transform:translateY(-2px);transition-duration:.1s}.dashboard-card-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#fef3c7,#fde68a)}.dashboard-icon-img{width:70%;height:70%;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.dashboard-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(180deg,#0000,#000000b3);display:flex;justify-content:center;align-items:center}.dashboard-card-label{font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;color:#fff;letter-spacing:-.01em;text-shadow:0 1px 3px rgba(0,0,0,.4)}.dashboard-card-icon--space{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}.dashboard-card-icon--werkwoorden{background:linear-gradient(135deg,#1e293b,#334155,#1e293b)}@keyframes sfPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes sfEntryIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes sfNewEntry{0%{background:#22c55e26}to{background:transparent}}.sf-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0a0f1e,#0d1b2a 40%,#091628);overflow:hidden}.sf-header{background:#0a0f1eeb!important;border-bottom:1px solid rgba(56,189,248,.15)!important;box-shadow:0 2px 20px #0000004d!important}.sf-header .app-title{background:linear-gradient(135deg,#38bdf8,#7dd3fc,#bae6fd)!important;background-size:200% auto!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.sf-header-left{display:flex;align-items:center;gap:12px}.sf-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(56,189,248,.2);background:#38bdf814;color:#7dd3fc;cursor:pointer;transition:all .2s ease;flex-shrink:0}.sf-back-btn:hover{background:#38bdf826;border-color:#38bdf866;transform:scale(1.05)}.sf-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;border:1px solid rgba(56,189,248,.3);background:#38bdf81a;color:#7dd3fc;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sf-add-btn:hover{background:#38bdf833;border-color:#38bdf880;transform:translateY(-1px);box-shadow:0 4px 12px #38bdf826}.sf-main{flex:1 1 0;overflow-y:auto;padding:24px 16px;scrollbar-width:thin;scrollbar-color:rgba(56,189,248,.2) transparent}.sf-main::-webkit-scrollbar{width:4px}.sf-main::-webkit-scrollbar-thumb{background:#38bdf833;border-radius:2px}.sf-content{max-width:600px;margin:0 auto}.sf-loading{display:flex;justify-content:center;align-items:center;padding:80px 0}.sf-spinner{width:36px;height:36px;border:3px solid rgba(56,189,248,.15);border-top-color:#38bdf8;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sf-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:80px 24px;text-align:center}.sf-empty-icon{color:#38bdf84d;margin-bottom:4px}.sf-empty-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:700;color:#ffffffb3;letter-spacing:-.02em}.sf-empty-sub{font-size:.88rem;color:#ffffff59}.sf-empty-btn{display:flex;align-items:center;gap:6px;margin-top:8px;padding:10px 20px;border-radius:10px;border:1px solid rgba(56,189,248,.3);background:#38bdf81a;color:#7dd3fc;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease}.sf-empty-btn:hover{background:#38bdf833;transform:translateY(-1px)}.sf-leaderboard{display:flex;flex-direction:column;gap:8px}.sf-entry{display:flex;align-items:center;gap:16px;padding:14px 18px;border-radius:14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);transition:all .2s ease;animation:sfEntryIn .3s ease}.sf-entry:hover{background:#ffffff12;border-color:#38bdf826}.sf-entry--new{animation:sfNewEntry 2s ease forwards}.sf-rank{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700;flex-shrink:0;background:#ffffff0f;color:#fff6}.sf-rank--gold{background:linear-gradient(135deg,#fbbf2433,#f59e0b1a);border:1px solid rgba(251,191,36,.35);color:#fcd34d}.sf-rank--silver{background:linear-gradient(135deg,#94a3b833,#64748b1a);border:1px solid rgba(148,163,184,.35);color:#cbd5e1}.sf-rank--bronze{background:linear-gradient(135deg,#b4530940,#92400e1a);border:1px solid rgba(180,83,9,.4);color:#fdba74}.sf-entry-info{flex:1;min-width:0}.sf-entry-name{font-family:Poppins,sans-serif;font-size:1rem;font-weight:600;color:#ffffffe6;letter-spacing:-.01em;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-entry-score{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex-shrink:0}.sf-score-value{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:800;color:#38bdf8;letter-spacing:-.03em;line-height:1}.sf-score-label{font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:#38bdf873}.sf-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:16px;animation:fadeIn .2s ease}.sf-modal{width:100%;max-width:460px;background:#0f172a;border:1px solid rgba(56,189,248,.15);border-radius:20px;box-shadow:0 24px 60px #00000080,0 0 0 1px #38bdf80d;overflow:hidden;animation:slideUp .3s cubic-bezier(.32,.72,0,1);margin-bottom:env(safe-area-inset-bottom,0)}.sf-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,.06)}.sf-modal-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#ffffffe6;letter-spacing:-.02em}.sf-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:#ffffff0f;color:#ffffff80;cursor:pointer;transition:all .15s ease}.sf-modal-close:hover{background:#ffffff1a;color:#fffc}.sf-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:20px}.sf-form-group{display:flex;flex-direction:column;gap:8px}.sf-form-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#38bdf8b3}.sf-form-input{padding:12px 16px;border-radius:10px;border:1px solid rgba(56,189,248,.2);background:#ffffff0d;color:#ffffffe6;font-size:1rem;font-family:Inter,system-ui,sans-serif;outline:none;transition:all .2s ease}.sf-form-input::-moz-placeholder{color:#ffffff40}.sf-form-input::placeholder{color:#ffffff40}.sf-form-input:focus{border-color:#38bdf880;background:#38bdf80f;box-shadow:0 0 0 3px #38bdf814}.sf-score-options{display:flex;gap:8px;flex-wrap:wrap}.sf-score-option{flex:1;min-width:60px;padding:10px 8px;border-radius:10px;border:1px solid rgba(56,189,248,.15);background:#ffffff0a;color:#ffffff8c;font-family:Poppins,sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease;text-align:center}.sf-score-option:hover{background:#38bdf814;border-color:#38bdf84d;color:#fffc}.sf-score-option--selected{background:#38bdf826;border-color:#38bdf880;color:#7dd3fc;box-shadow:0 0 0 2px #38bdf81a}.sf-form-error{font-size:.82rem;color:#f87171;padding:8px 12px;border-radius:8px;background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.sf-form-submit{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border-radius:12px;border:none;background:linear-gradient(135deg,#0ea5e9,#38bdf8);color:#0a0f1e;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:-.01em}.sf-form-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #0ea5e959}.sf-form-submit:active:not(:disabled){transform:translateY(0)}.sf-form-submit:disabled{opacity:.6;cursor:not-allowed}.dashboard-settings-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .2s ease}.dashboard-settings-btn:hover{background:#00000014;color:#374151;transform:rotate(30deg)}.dashboard-settings-btn:active{transform:rotate(30deg) scale(.95)}.dashboard-card-icon--randomizer{background:linear-gradient(135deg,#ecfdf5,#d1fae5,#a7f3d0)}.dashboard-card--randomizer .dashboard-icon-img{width:75%;height:75%}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0000;pointer-events:none;transition:background .3s ease}.settings-backdrop--open{background:#00000059;pointer-events:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.settings-drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);z-index:101;background:#fefefe;box-shadow:-8px 0 40px #0000001f;display:flex;flex-direction:column;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.settings-drawer--open{transform:translate(0)}.settings-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(0,0,0,.06)}.settings-header-left{display:flex;align-items:center;gap:10px}.settings-header-icon{color:#d97706}.settings-title{font-family:Poppins,sans-serif;font-size:1.15rem;font-weight:700;color:#1f2937;letter-spacing:-.02em}.settings-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.settings-close:hover{background:#00000014;color:#1f2937}.settings-body{flex:1 1 0;overflow-y:auto;padding:20px 24px;display:flex;flex-direction:column;gap:28px;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.1) transparent}.settings-section{display:flex;flex-direction:column;gap:12px}.settings-section-header{display:flex;align-items:center;gap:8px;font-family:Poppins,sans-serif;font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280}.settings-add-row{display:flex;gap:8px}.settings-input{flex:1;padding:10px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#00000005;color:#1f2937;font-size:.92rem;font-family:Inter,system-ui,sans-serif;outline:none;transition:all .2s ease}.settings-input::-moz-placeholder{color:#9ca3af}.settings-input::placeholder{color:#9ca3af}.settings-input:focus{border-color:#d97706;background:#fffbf0;box-shadow:0 0 0 3px #d9770614}.settings-add-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.settings-add-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.settings-add-btn:disabled{opacity:.4;cursor:not-allowed}.settings-class-list{display:flex;flex-direction:column;gap:4px}.settings-class-item{display:flex;align-items:center;border-radius:10px;transition:all .15s ease;overflow:hidden}.settings-class-item--active{background:#f59e0b14}.settings-class-name{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:none;background:none;color:#374151;font-size:.92rem;font-weight:500;cursor:pointer;text-align:left;transition:color .15s ease}.settings-class-item--active .settings-class-name{color:#d97706;font-weight:600}.settings-class-count{font-size:.75rem;font-weight:600;color:#9ca3af;background:#0000000d;padding:2px 8px;border-radius:10px}.settings-class-item--active .settings-class-count{background:#d977061f;color:#d97706}.settings-class-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#d1d5db;cursor:pointer;transition:all .15s ease;margin-right:6px}.settings-class-delete:hover{background:#ef44441a;color:#dc2626}.settings-pupil-list{display:flex;flex-direction:column;gap:2px}.settings-pupil-item{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-radius:8px;transition:background .15s ease}.settings-pupil-item:hover{background:#00000005}.settings-pupil-name{font-size:.92rem;color:#374151;font-weight:500}.settings-pupil-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#d1d5db;cursor:pointer;transition:all .15s ease;opacity:0}.settings-pupil-item:hover .settings-pupil-delete{opacity:1}.settings-pupil-delete:hover{background:#ef44441a;color:#dc2626}.settings-empty{font-size:.85rem;color:#9ca3af;text-align:center;padding:20px 0}.settings-tile-list{display:flex;flex-direction:column;gap:4px}.settings-tile-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.06);background:#00000005;color:#374151;font-size:.92rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s ease}.settings-tile-toggle:hover{border-color:#0000001a;background:#0000000a}.settings-tile-label{flex:1;text-align:left}.settings-tile-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:#d1d5db;transition:all .2s ease;flex-shrink:0;margin-left:8px}.settings-tile-icon--visible{color:#10b981}.settings-confirm-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#00000080;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .2s ease}.settings-confirm-modal{width:100%;max-width:380px;background:#fefefe;border-radius:16px;box-shadow:0 20px 60px #00000040;padding:24px;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}.settings-confirm-title{font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;color:#1f2937;margin:0 0 8px}.settings-confirm-text{font-size:.9rem;color:#6b7280;line-height:1.5;margin:0 0 20px}.settings-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.settings-confirm-cancel,.settings-confirm-delete{padding:8px 20px;border-radius:8px;border:none;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .15s ease}.settings-confirm-cancel{background:#0000000d;color:#6b7280}.settings-confirm-cancel:hover{background:#0000001a;color:#1f2937}.settings-confirm-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.settings-confirm-delete:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}@keyframes randReveal{0%{opacity:0;transform:scale(.6) translateY(10px)}60%{transform:scale(1.08) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes randGlow{0%,to{box-shadow:0 0 20px #10b9814d,0 0 60px #10b9811a}50%{box-shadow:0 0 40px #10b98180,0 0 80px #10b98133}}.rand-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#0f172a,#1e293b 40%,#334155);overflow:hidden}.rand-header{background:#0f172aeb!important;border-bottom:1px solid rgba(16,185,129,.15)!important;box-shadow:0 2px 20px #0000004d!important}.rand-header .app-title{background:linear-gradient(135deg,#10b981,#34d399,#6ee7b7)!important;background-size:200% auto!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.rand-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(16,185,129,.2);background:#10b98114;color:#6ee7b7;cursor:pointer;transition:all .2s ease;flex-shrink:0}.rand-back-btn:hover{background:#10b98126;border-color:#10b98166;transform:scale(1.05)}.rand-class-select{padding:8px 14px;border-radius:10px;border:1px solid rgba(16,185,129,.2);background:#10b98114;color:#6ee7b7;font-size:.88rem;font-weight:600;font-family:Inter,system-ui,sans-serif;outline:none;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none}.rand-class-select:disabled{opacity:.5;cursor:not-allowed}.rand-class-select option{background:#1e293b;color:#e2e8f0}.rand-class-select:hover:not(:disabled){border-color:#10b98166;background:#10b9811f}.rand-main{flex:1 1 0;display:flex;align-items:center;justify-content:center;padding:16px 24px 24px;overflow:hidden}.rand-empty{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:40px}.rand-empty-icon{color:#10b98140;margin-bottom:4px}.rand-empty-title{font-family:Poppins,sans-serif;font-size:1.2rem;font-weight:700;color:#ffffffb3}.rand-empty-sub{font-size:.88rem;color:#ffffff59;max-width:300px}.rand-center-layout{display:flex;flex-direction:column;align-items:center;gap:28px}.rand-wheel-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.wheel-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center;filter:drop-shadow(0 8px 32px rgba(0,0,0,.5))}.wheel-canvas{width:min(400px,84vw);height:min(400px,84vw);border-radius:50%;display:block}.wheel-pointer{position:absolute;top:-2px;left:50%;transform:translate(-50%);width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-top:28px solid #F59E0B;filter:drop-shadow(0 2px 6px rgba(245,158,11,.6));z-index:10}.rand-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:randReveal .45s cubic-bezier(.34,1.56,.64,1);pointer-events:none;z-index:20;gap:4px;padding:24px}.rand-overlay-label{font-family:Poppins,sans-serif;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#34d399}.rand-overlay-name{font-family:Poppins,sans-serif;font-size:clamp(1.8rem,7vw,3rem);font-weight:800;color:#fff;letter-spacing:-.03em;text-shadow:0 0 30px rgba(16,185,129,.7),0 2px 8px rgba(0,0,0,.5);text-align:center;word-break:break-word;line-height:1.1}.rand-spin-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:15px 40px;border-radius:16px;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-family:Poppins,sans-serif;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:-.01em;box-shadow:0 4px 20px #f59e0b59;white-space:nowrap}.rand-spin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 30px #f59e0b80}.rand-spin-btn:active:not(:disabled){transform:translateY(0)}.rand-spin-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard-card-icon--weektaak{background:linear-gradient(135deg,#fff8ee,#fff0dc,#ffe8cc);display:flex;align-items:center;justify-content:center}@keyframes wt-check-pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.wt-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#f0f7ff,#ebf4ff,#e6f0ff);overflow:hidden}.wt-header-left{display:flex;align-items:center;gap:12px}.wt-header-title-block{display:flex;align-items:center;gap:10px}.wt-class-badge{font-size:.78rem;font-weight:600;color:#2563eb;background:#2563eb1a;border:1px solid rgba(37,99,235,.2);padding:2px 10px;border-radius:20px}.wt-header-right{display:flex;align-items:center;gap:10px}.wt-class-selector{display:flex;gap:6px}.wt-class-tab{padding:5px 14px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:transparent;font-size:.82rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-class-tab--active{background:#2563eb1a;border-color:#2563eb4d;color:#2563eb;font-weight:600}.wt-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease;flex-shrink:0}.wt-back-btn:hover{background:#00000014;color:#374151}.wt-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-icon-btn:hover{background:#2563eb14;color:#2563eb;border-color:#2563eb33;transform:rotate(20deg)}.wt-main{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:20px;gap:16px}.wt-loading,.wt-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#6b7280;text-align:center}.wt-empty-icon{color:#93c5fd}.wt-empty h2{font-family:Poppins,sans-serif;font-size:1.3rem;font-weight:700;color:#1d4ed8}.wt-empty p{color:#6b7280;font-size:.9rem;max-width:280px}.wt-content{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:14px}.wt-week-nav{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 16px;box-shadow:0 2px 12px #0000000f;border:1px solid rgba(0,0,0,.06);flex-shrink:0}.wt-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:#00000008;color:#374151;cursor:pointer;transition:all .15s ease}.wt-nav-btn:hover:not(:disabled){background:#2563eb14;border-color:#2563eb33;color:#2563eb}.wt-nav-btn:disabled{opacity:.3;cursor:not-allowed}.wt-week-info{flex:1;display:flex;align-items:center;gap:10px}.wt-week-label{font-family:Poppins,sans-serif;font-weight:700;font-size:1rem;color:#1d4ed8}.wt-week-dates{font-size:.85rem;color:#6b7280;font-weight:500}.wt-new-week-btn{flex-shrink:0}.wt-table-scroll{flex:1;overflow:auto;border-radius:14px;box-shadow:0 2px 16px #00000012;border:1px solid rgba(0,0,0,.07);background:#fff}.wt-table{width:100%;border-collapse:collapse;font-size:.88rem;min-width:400px;table-layout:fixed}.wt-th-name{text-align:left;padding:12px 16px;font-family:Poppins,sans-serif;font-weight:700;font-size:.82rem;color:#1d4ed8;background:#eff6ff;border-bottom:2px solid #DBEAFE;width:150px;position:sticky;left:0;z-index:2}.wt-th-task{padding:8px 6px;text-align:center;background:#eff6ff;border-bottom:2px solid #DBEAFE;border-left:1px solid #DBEAFE;width:90px;vertical-align:bottom;height:120px}.wt-th-task-inner{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;padding:6px 2px;height:100%}.wt-th-task-name{font-weight:700;font-size:.8rem;color:#1e40af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px;display:inline-block;transform:rotate(45deg);transform-origin:center;line-height:1}.wt-th-empty-col{padding:12px;text-align:center;background:#eff6ff;border-bottom:2px solid #DBEAFE;border-left:1px solid #DBEAFE}.wt-th-empty-hint{font-size:.75rem;color:#93c5fd;font-style:italic}.wt-row{transition:background .2s ease}.wt-row:hover{background:#f8fbff}.wt-row--done .wt-td-name{background:linear-gradient(90deg,#f0fdf4,#dcfce7)}.wt-row--done .wt-pupil-name{color:#16a34a}.wt-td-name{padding:10px 16px;font-weight:600;color:#1f2937;border-bottom:1px solid #F1F5F9;background:#fafbff;position:sticky;left:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:8px;transition:background .2s ease}.wt-pupil-name{font-size:.88rem;font-weight:600}.wt-progress-badge{font-size:.7rem;font-weight:600;color:#6b7280;background:#f3f4f6;border-radius:20px;padding:1px 7px;flex-shrink:0}.wt-row--done .wt-progress-badge{background:#d1fae5;color:#059669}.wt-td-check{text-align:center;vertical-align:middle;border-bottom:1px solid #F1F5F9;border-left:1px solid #F1F5F9;cursor:pointer;transition:background .15s ease;height:44px;width:80px}.wt-td-check:hover{background:#eff6ff}.wt-td-check--done{background:#f0fdf4}.wt-td-check--done:hover{background:#dcfce7}.wt-td-empty{border-bottom:1px solid #F1F5F9;border-left:1px solid #F1F5F9}.wt-check-mark{display:flex;align-items:center;justify-content:center;color:#16a34a;animation:wt-check-pop .25s ease forwards}.wt-legend{background:#fff;border-radius:12px;padding:12px 16px;display:flex;flex-wrap:wrap;gap:8px 24px;box-shadow:0 2px 10px #0000000d;border:1px solid rgba(0,0,0,.06);flex-shrink:0}.wt-legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#374151}.wt-legend-name{font-weight:700;color:#1d4ed8}.wt-legend-desc{color:#6b7280}.wt-legend-link{color:#2563eb;font-size:.75rem;text-decoration:underline;cursor:pointer}.wt-empty-pupils{padding:16px;text-align:center;color:#9ca3af;font-size:.85rem;background:#fff;border-radius:12px;border:1px dashed #D1D5DB}.wt-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 3px 12px #2563eb4d}.wt-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb66}.wt-btn-primary:disabled{opacity:.55;cursor:not-allowed}.wt-btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:1px solid rgba(0,0,0,.12);background:#00000008;color:#374151;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease}.wt-btn-secondary:hover{background:#00000012}.wt-btn-danger{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:10px;border:none;background:linear-gradient(135deg,#dc2626,#ef4444);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 3px 10px #dc262640}.wt-btn-danger:hover{transform:translateY(-1px);box-shadow:0 6px 18px #dc262659}.wt-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.wt-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0003;width:100%;max-width:420px;overflow:hidden}.wt-settings-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0003;width:100%;max-width:520px;max-height:90svh;overflow:hidden;display:flex;flex-direction:column;position:relative}.wt-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #F1F5F9}.wt-modal-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#1e40af}.wt-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.1);background:transparent;color:#6b7280;cursor:pointer;transition:all .15s ease}.wt-modal-close:hover{background:#fef2f2;color:#ef4444;border-color:#ef444433}.wt-modal-form{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.wt-field-row{display:flex;gap:12px}.wt-field{flex:1;display:flex;flex-direction:column;gap:5px}.wt-label{font-size:.78rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.04em}.wt-required{color:#ef4444}.wt-input{padding:9px 12px;border-radius:10px;border:1.5px solid #E5E7EB;font-size:.88rem;color:#1f2937;background:#fff;transition:border-color .15s ease;outline:none;width:100%}.wt-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.wt-week-preview{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#eff6ff;border-radius:10px;border:1px solid #DBEAFE;font-size:.82rem;color:#374151;flex-wrap:wrap}.wt-week-preview-label{font-weight:700;color:#1d4ed8}.wt-week-preview-sep{color:#9ca3af}.wt-error{font-size:.82rem;color:#dc2626;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;padding:8px 12px}.wt-modal-actions{display:flex;gap:10px;justify-content:flex-end}.wt-settings-tabs{display:flex;gap:0;border-bottom:1px solid #F1F5F9;padding:0 24px;flex-shrink:0}.wt-settings-tab{display:flex;align-items:center;gap:6px;padding:12px 16px;border:none;background:transparent;font-size:.83rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease;margin-bottom:-1px}.wt-settings-tab:hover{color:#2563eb}.wt-settings-tab--active{color:#2563eb;font-weight:700;border-bottom-color:#2563eb}.wt-settings-body{flex:1;overflow-y:auto;padding:0}.wt-settings-section{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.wt-settings-hint{font-size:.82rem;color:#6b7280;line-height:1.5;background:#f8faff;border-radius:8px;padding:10px 12px;border:1px solid #E0EAFF}.wt-task-list{display:flex;flex-direction:column;gap:6px}.wt-empty-list{font-size:.82rem;color:#9ca3af;text-align:center;padding:12px;font-style:italic}.wt-task-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:#f8faff;border-radius:10px;border:1px solid #E0EAFF}.wt-task-item--default{background:#fffbeb;border-color:#fde68a}.wt-task-item-icon{color:#f59e0b;flex-shrink:0;margin-top:2px}.wt-task-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.wt-task-item-name{font-weight:600;font-size:.85rem;color:#1f2937}.wt-task-item-desc{font-size:.78rem;color:#6b7280}.wt-task-item-link{font-size:.75rem;color:#3b82f6;word-break:break-all}.wt-delete-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:none;background:transparent;color:#9ca3af;cursor:pointer;transition:all .15s ease;flex-shrink:0}.wt-delete-btn:hover{background:#fef2f2;color:#ef4444}.wt-add-task-form{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8faff;border-radius:12px;border:1px solid #E0EAFF}.wt-form-title{font-family:Poppins,sans-serif;font-size:.88rem;font-weight:700;color:#1e40af;margin-bottom:2px}.wt-add-btn{align-self:flex-start}.wt-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffeb;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:24px;border-radius:18px;z-index:10}.wt-confirm-box{background:#fff;border-radius:14px;padding:24px;box-shadow:0 8px 30px #0000001f;border:1px solid #E5E7EB;display:flex;flex-direction:column;gap:16px;max-width:320px;width:100%}.wt-confirm-text{font-size:.9rem;color:#374151;text-align:center;line-height:1.5}.wt-confirm-actions{display:flex;gap:10px;justify-content:center}.wt-day-picker{display:flex;gap:6px;flex-wrap:wrap}.wt-day-btn{padding:8px 14px;border-radius:10px;border:1.5px solid #E5E7EB;background:#fff;font-size:.83rem;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease}.wt-day-btn:hover:not(:disabled){border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.wt-day-btn--active{background:linear-gradient(135deg,#2563eb,#3b82f6);border-color:transparent;color:#fff;font-weight:700;box-shadow:0 3px 10px #2563eb4d}.wt-day-btn--active:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff}.wt-day-btn:disabled{opacity:.5;cursor:not-allowed}.wt-start-day-info{font-size:.82rem;color:#374151;background:#f0f9ff;border:1px solid #BAE6FD;border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:6px}.wt-start-day-hint{color:#9ca3af;font-size:.75rem}.wt-tooltip-wrap{position:relative;display:inline-flex;writing-mode:horizontal-tb}.wt-tooltip-wrap--inline{margin-left:4px}.wt-tooltip-trigger{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;border:1.5px solid #93C5FD;background:#eff6ff;color:#2563eb;font-size:.65rem;font-weight:800;cursor:pointer;transition:all .15s ease;transform:rotate(45deg);flex-shrink:0}.wt-tooltip-trigger:hover{background:#dbeafe}.wt-tooltip-box{background:#1e293b;color:#fff;border-radius:10px;padding:10px 12px;font-size:.78rem;min-width:160px;max-width:220px;box-shadow:0 8px 24px #0003;writing-mode:horizontal-tb}.wt-tooltip-desc{line-height:1.5;color:#e2e8f0;margin-bottom:6px}.wt-tooltip-link{display:inline-flex;align-items:center;gap:4px;color:#60a5fa;text-decoration:underline;font-size:.75rem;cursor:pointer}.wt-copy-section{margin-top:16px}.wt-copy-divider{height:1px;background:#e5e7eb;margin-bottom:16px}.wt-copy-title{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:#374151;margin:0 0 6px}.wt-copy-hint{font-size:.78rem;color:#6b7280;margin:0 0 8px}.wt-copy-success{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;color:#16a34a;font-weight:600;margin-top:8px}.wt-class-picker{margin-bottom:10px}.wt-class-picker-label{font-size:.78rem;color:#6b7280;font-weight:500;margin:0 0 6px}.wt-class-picker-options{display:flex;flex-wrap:wrap;gap:6px}.wt-class-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:20px;border:1.5px solid #E5E7EB;background:#fff;font-size:.8rem;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.wt-class-chip:hover{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}.wt-class-chip--active{background:#eff6ff;border-color:#2563eb;color:#1d4ed8;font-weight:600}.wt-btn-copy{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#f0fdf4;border:1.5px solid #86EFAC;border-radius:10px;color:#16a34a;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s ease;margin-top:4px}.wt-btn-copy:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.wt-btn-copy:disabled{opacity:.5;cursor:not-allowed}.dashboard-card--planning{aspect-ratio:unset;min-height:160px;background:#fff;cursor:pointer;text-align:left;align-items:flex-start;justify-content:flex-start}.dashboard-planning-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;padding:16px 18px;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.dashboard-planning-header{display:flex;align-items:center;gap:7px;margin-bottom:12px;color:#1d4ed8}.dashboard-planning-title{font-family:Poppins,sans-serif;font-size:.9rem;font-weight:700;color:#1d4ed8;letter-spacing:-.01em}.dashboard-planning-list{display:flex;flex-direction:column;gap:6px;flex:1}.dashboard-planning-row{display:flex;align-items:baseline;gap:8px;font-size:.82rem;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-planning-date{font-weight:700;color:#2563eb;min-width:38px;flex-shrink:0;font-size:.8rem}.dashboard-planning-event{flex:1;overflow:hidden;text-overflow:ellipsis;font-weight:500;color:#1e293b}.dashboard-planning-group{color:#64748b;font-size:.78rem;flex-shrink:0}.dashboard-planning-empty{font-size:.8rem;color:#94a3b8;font-style:italic}.dashboard-card--weektaak-widget{aspect-ratio:unset;min-height:160px;background:#fff;text-align:left;cursor:default;padding:0;overflow:visible;z-index:10}.pw-widget{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;padding:16px 18px;overflow:hidden}.pw-widget--pick{overflow:visible;align-items:center;justify-content:center;gap:8px;padding:24px}.pw-pick-icon{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#f0fdfa,#ccfbf1);display:flex;align-items:center;justify-content:center;color:#0d9488;margin-bottom:2px;flex-shrink:0}.pw-pick-label{font-family:Poppins,sans-serif;font-size:1rem;font-weight:700;color:#0f172a;letter-spacing:-.01em}.pw-header{display:flex;align-items:center;gap:7px;margin-bottom:10px;color:#0d9488}.pw-title{font-family:Poppins,sans-serif;font-size:.9rem;font-weight:700;color:#0d9488;letter-spacing:-.01em}.pw-progress{margin-left:auto;font-size:.75rem;font-weight:600;color:#0d9488;background:#f0fdfa;border:1px solid #CCFBF1;border-radius:10px;padding:1px 8px;transition:all .3s ease}.pw-progress--done{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6);border-color:#0d9488}.pw-selector-wrap{position:relative;margin-bottom:10px}.pw-selector-wrap--pick{width:100%;margin-bottom:0}.pw-selector{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 10px;border:1.5px solid #E2E8F0;border-radius:8px;background:#f8fafc;font-size:.8rem;cursor:pointer;transition:border-color .15s,box-shadow .15s}.pw-selector--pick{padding:10px 14px;font-size:.88rem;border-radius:10px;border:2px solid #E2E8F0;background:#fff}.pw-selector--pick:hover,.pw-selector:hover{border-color:#0d9488}.pw-selector:focus{outline:none;border-color:#0d9488;box-shadow:0 0 0 2px #0d948826}.pw-selector-name{font-weight:600;color:#1e293b}.pw-selector-placeholder{color:#94a3b8;font-weight:400}.pw-chevron{color:#94a3b8;transition:transform .2s;flex-shrink:0}.pw-chevron--open{transform:rotate(180deg)}.pw-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1.5px solid #E2E8F0;border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:200;max-height:180px;overflow-y:auto;padding:4px}.pw-dropdown--pick{max-height:220px;border-radius:10px;border:2px solid #E2E8F0;box-shadow:0 12px 32px #00000029}.pw-dropdown-item{display:block;width:100%;text-align:left;padding:6px 10px;border:none;background:none;font-size:.8rem;color:#334155;border-radius:6px;cursor:pointer;transition:background .12s}.pw-dropdown-item:hover{background:#f0fdfa;color:#0d9488}.pw-dropdown-item--active{background:#f0fdfa;color:#0d9488;font-weight:600}.pw-dropdown-empty{display:block;padding:8px 10px;color:#94a3b8;font-size:.8rem;font-style:italic}.pw-empty{font-size:.8rem;color:#94a3b8;font-style:italic}.pw-tasks{display:flex;flex-direction:column;flex:1;overflow-y:auto;border:1px solid #E2E8F0;border-radius:8px;background:#fff}.pw-task-row{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .12s;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-bottom:1px solid #F1F5F9}.pw-task-row:last-child{border-bottom:none}.pw-task-row:hover{background:#f8fafc}.pw-task-row--done{background:#f8fffe}.pw-task-row--done:hover{background:#f0fdfa}.pw-checkbox{width:18px;height:18px;min-width:18px;border-radius:4px;border:2px solid #CBD5E1;display:flex;align-items:center;justify-content:center;transition:all .15s;background:#fff}.pw-checkbox--checked{background:#0d9488;border-color:#0d9488;color:#fff}.pw-task-name{font-size:.8rem;font-weight:500;color:#334155;flex:1;line-height:1.3}.pw-task-name--done{text-decoration:line-through;color:#94a3b8}.pw-task-link{color:#94a3b8;flex-shrink:0;display:flex;align-items:center;transition:color .15s}.pw-task-link:hover{color:#0d9488}.dino-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:#f8fafc;overflow:hidden}.dino-header{background:#fff!important;border-bottom:1px solid #E2E8F0!important;box-shadow:0 2px 8px #0000000f!important}.dino-header-left{display:flex;align-items:center;gap:12px}.dino-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:10px;background:#f1f5f9;color:#475569;cursor:pointer;transition:background .2s}.dino-back-btn:hover{background:#e2e8f0;color:#1e293b}.dino-add-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;border:none;border-radius:10px;background:#16a34a;color:#fff;font-family:Poppins,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.dino-add-btn:hover{background:#15803d;transform:translateY(-1px)}.dino-main{flex:1;overflow-y:auto;padding:24px 20px}.dino-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;max-width:1200px;margin:0 auto;height:100%}.dino-game-section{display:flex;flex-direction:column;gap:12px}.dino-game-wrapper{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;position:relative;width:100%;overflow:hidden}.dino-game-wrapper .interstitial-wrapper{margin:0!important;max-width:100%!important;width:100%!important;position:relative!important}.dino-game-wrapper .runner-container{left:0!important;width:100%!important;max-width:100%!important}.dino-game-wrapper .runner-canvas{max-width:100%!important}.dino-game-wrapper .controller,.dino-game-wrapper #offline-resources{display:none!important}.dino-board-section{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:20px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}.dino-board-header{display:flex;align-items:center;gap:8px;font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;color:#1e293b;padding-bottom:10px;border-bottom:2px solid #F1F5F9}.dino-loading{display:flex;justify-content:center;padding:40px 0}.dino-spinner{width:28px;height:28px;border:3px solid #E2E8F0;border-top-color:#16a34a;border-radius:50%;animation:spin .8s linear infinite}.dino-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 16px;text-align:center}.dino-empty-icon{color:#cbd5e1}.dino-empty-title{font-family:Poppins,sans-serif;font-size:.95rem;font-weight:700;color:#475569;margin:0}.dino-empty-sub{font-size:.82rem;color:#94a3b8;margin:0}.dino-entries{display:flex;flex-direction:column;gap:6px}.dino-entry{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid #F1F5F9;transition:background .2s}.dino-entry--new{background:#dcfce7;border-color:#86efac;animation:dino-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes dino-pop{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.dino-rank{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-size:.8rem;font-weight:700;flex-shrink:0;background:#f1f5f9;color:#64748b}.dino-rank--gold{background:#fef9c3}.dino-rank--silver{background:#f1f5f9}.dino-rank--bronze{background:#fef3c7}.dino-entry-name{flex:1;font-size:.88rem;font-weight:600;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dino-entry-score{font-family:Poppins,sans-serif;font-size:.85rem;font-weight:700;color:#16a34a;flex-shrink:0}.dino-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dino-modal{background:#fff;border-radius:20px;padding:28px;width:100%;max-width:400px;box-shadow:0 20px 60px #0003;animation:modal-in .25s cubic-bezier(.34,1.56,.64,1)}.dino-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dino-modal-title{font-family:Poppins,sans-serif;font-size:1.1rem;font-weight:700;color:#1e293b;margin:0}.dino-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:#f1f5f9;color:#64748b;cursor:pointer;transition:background .2s}.dino-modal-close:hover{background:#e2e8f0;color:#1e293b}.dino-form{display:flex;flex-direction:column;gap:16px}.dino-form-group{display:flex;flex-direction:column;gap:6px}.dino-form-label{font-size:.82rem;font-weight:600;color:#475569}.dino-form-input,.dino-form-select{padding:10px 14px;border:1.5px solid #E2E8F0;border-radius:10px;font-size:.9rem;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .2s;font-family:inherit}.dino-form-input:focus,.dino-form-select:focus{border-color:#16a34a;background:#fff}.dino-form-error{font-size:.82rem;color:#dc2626;margin:0}.dino-form-submit{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:12px;background:#16a34a;color:#fff;font-family:Poppins,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s,transform .15s}.dino-form-submit:hover:not(:disabled){background:#15803d;transform:translateY(-1px)}.dino-form-submit:disabled{opacity:.6;cursor:not-allowed}.planning-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 50% 30%,#eff6ff,#dbeafe 40%,#bfdbfe);overflow:hidden}.planning-header-left{display:flex;align-items:center;gap:12px}.planning-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:10px;background:#2563eb1a;color:#2563eb;cursor:pointer;transition:background .15s ease}.planning-back-btn:hover{background:#2563eb2e}.planning-add-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:10px;background:#2563eb;color:#fff;cursor:pointer;transition:background .15s ease;box-shadow:0 2px 8px #2563eb59}.planning-add-btn:hover{background:#1d4ed8}.planning-main{flex:1;overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;gap:16px}.planning-form{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 16px #2563eb1a;display:flex;flex-direction:column;gap:14px}.planning-form-row{display:flex;flex-direction:column;gap:5px}.planning-form-label{font-size:.78rem;font-weight:600;color:#374151;letter-spacing:.01em}.planning-form-input{padding:9px 12px;border:1.5px solid #DBEAFE;border-radius:10px;font-size:.88rem;color:#1e293b;background:#f8faff;outline:none;transition:border-color .15s ease;font-family:Inter,system-ui,sans-serif}.planning-form-input:focus{border-color:#2563eb;background:#fff}.planning-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.planning-form-cancel{padding:9px 18px;border:1.5px solid #E5E7EB;border-radius:10px;background:#fff;color:#6b7280;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;font-family:Inter,system-ui,sans-serif}.planning-form-cancel:hover{border-color:#d1d5db;color:#374151}.planning-form-submit{padding:9px 20px;border:none;border-radius:10px;background:#2563eb;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s ease;font-family:Inter,system-ui,sans-serif}.planning-form-submit:hover:not(:disabled){background:#1d4ed8}.planning-form-submit:disabled{opacity:.6;cursor:not-allowed}.planning-list-wrap{flex:1}.planning-list{list-style:none;display:flex;flex-direction:column;gap:8px}.planning-item{display:flex;align-items:center;gap:12px;background:#fff;border-radius:12px;padding:12px 16px;box-shadow:0 2px 8px #0000000f;transition:box-shadow .15s ease}.planning-item:hover{box-shadow:0 4px 12px #2563eb1f}.planning-item-date{font-size:.82rem;font-weight:700;color:#2563eb;min-width:42px;flex-shrink:0}.planning-item-title{flex:1;font-size:.88rem;font-weight:500;color:#1e293b}.planning-item-group{font-size:.8rem;color:#64748b;flex-shrink:0}.planning-item-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:#cbd5e1;cursor:pointer;transition:all .15s ease;flex-shrink:0}.planning-item-delete:hover{background:#fee2e2;color:#dc2626}.planning-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;color:#94a3b8;font-size:.9rem}.ww-pw-backdrop{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.ww-pw-card{width:100%;max-width:380px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #00000014,0 2px 8px #0000000a;border:1px solid rgba(14,165,233,.1);padding:40px 32px 32px;display:flex;flex-direction:column;align-items:center;gap:8px;animation:wwCardIn .4s ease}.ww-pw-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);display:flex;align-items:center;justify-content:center;color:#0284c7;margin-bottom:8px}.ww-pw-title{font-size:1.3rem;font-weight:800;color:#0f172a;margin:0}.ww-pw-subtitle{font-size:.85rem;color:#64748b;margin:0 0 12px;text-align:center;line-height:1.4}.ww-pw-form{width:100%;display:flex;flex-direction:column;gap:12px}.ww-pw-input-wrap{position:relative;width:100%}.ww-pw-input{width:100%;padding:12px 44px 12px 16px;border:2px solid #E2E8F0;border-radius:12px;font-size:.95rem;font-family:inherit;color:#1e293b;background:#fafbfc;outline:none;transition:all .2s ease}.ww-pw-input:focus{border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e91a}.ww-pw-input--error{border-color:#ef4444;animation:wwIncorrectShake .4s ease}.ww-pw-input--error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.ww-pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s ease}.ww-pw-eye:hover{color:#475569;background:#0000000a}.ww-pw-error{font-size:.82rem;color:#ef4444;font-weight:500;text-align:center}.ww-pw-submit{width:100%;padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;font-size:.92rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0ea5e940}.ww-pw-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #0ea5e94d}.ww-pw-submit:active:not(:disabled){transform:translateY(0)}.ww-pw-submit:disabled{opacity:.5;cursor:not-allowed}.ww-pw-back{display:flex;align-items:center;gap:6px;margin-top:8px;padding:8px 16px;border:none;border-radius:8px;background:transparent;color:#94a3b8;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s ease}.ww-pw-back:hover{color:#475569;background:#0000000a}.ww-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border:2px solid #E2E8F0;border-radius:12px;background:#fff;color:#1e293b;font-size:.92rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0000000f}.ww-google-btn:hover{border-color:#cbd5e1;background:#f8fafc;box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.ww-google-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000000f}.ww-google-icon{flex-shrink:0}.ww-login-loader{width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:#0284c7}.ww-spin{animation:wwSpin 1s linear infinite}@keyframes wwSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ww-link-card{width:100%;max-width:420px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #00000014,0 2px 8px #0000000a;border:1px solid rgba(14,165,233,.1);padding:40px 32px 32px;display:flex;flex-direction:column;align-items:center;gap:8px;animation:wwCardIn .4s ease;max-height:80vh}.ww-link-class-select{width:100%;display:flex;flex-direction:column;gap:6px;margin-top:4px}.ww-link-label{font-size:.78rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.ww-link-dropdown{width:100%;padding:10px 14px;border:2px solid #E2E8F0;border-radius:10px;font-size:.9rem;font-family:inherit;color:#1e293b;background:#fafbfc;outline:none;cursor:pointer;transition:border-color .2s ease}.ww-link-dropdown:focus{border-color:#0ea5e9}.ww-link-pupil-list{width:100%;display:flex;flex-direction:column;gap:6px;margin-top:8px;max-height:300px;overflow-y:auto;padding-right:4px}.ww-link-pupil-list::-webkit-scrollbar{width:4px}.ww-link-pupil-list::-webkit-scrollbar-track{background:transparent}.ww-link-pupil-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.ww-link-pupil-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:2px solid #E2E8F0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;font-family:inherit}.ww-link-pupil-btn:hover:not(:disabled){border-color:#0ea5e9;background:#f0f9ff}.ww-link-pupil-btn:disabled{opacity:.6;cursor:not-allowed}.ww-link-pupil-name{font-size:.92rem;font-weight:600;color:#1e293b}.ww-link-pupil-check{color:#cbd5e1;transition:color .2s ease}.ww-link-pupil-btn:hover:not(:disabled) .ww-link-pupil-check{color:#0ea5e9}.ww-link-empty{text-align:center;color:#94a3b8;font-size:.85rem;padding:20px 0}.ww-link-error{display:flex;align-items:center;gap:6px;padding:10px 14px;border-radius:10px;background:#fef2f2;color:#dc2626;font-size:.82rem;font-weight:500;width:100%}.ww-user-indicator{display:flex;align-items:center;gap:8px;padding:4px 6px 4px 12px;background:#ffffff26;border-radius:20px;border:1px solid rgba(255,255,255,.2)}.ww-user-name{font-size:.82rem;font-weight:600;color:#fff;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ww-signout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:#ffffff26;color:#fffc;cursor:pointer;transition:all .15s ease}.ww-signout-btn:hover{background:#ffffff40;color:#fff}@keyframes wwCardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes wwCorrectFlash{0%{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 12px #10b98100}to{box-shadow:0 0 #10b98100}}@keyframes wwIncorrectShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.ww-root{width:100svw;height:100svh;display:flex;flex-direction:column;background:linear-gradient(160deg,#f0f9ff,#e0f2fe 40%,#f0f9ff);overflow:hidden}.ww-header{background:#fffffff2!important;border-bottom:1px solid rgba(14,165,233,.15)!important;box-shadow:0 2px 20px #0000000f!important}.ww-header .app-title{background:linear-gradient(135deg,#0369a1,#0ea5e9,#38bdf8)!important;background-size:200% auto!important;-webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;background-clip:text!important}.ww-header-left{display:flex;align-items:center;gap:12px}.ww-header-right{display:flex;align-items:center;gap:8px}.ww-back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(14,165,233,.2);background:#0ea5e90f;color:#0ea5e9;cursor:pointer;transition:all .2s ease;flex-shrink:0}.ww-back-btn:hover{background:#0ea5e91f;border-color:#0ea5e959;transform:scale(1.05)}.ww-info-btn,.ww-sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1px solid rgba(14,165,233,.15);background:#0ea5e90a;color:#0ea5e9;cursor:pointer;transition:all .2s ease}.ww-info-btn:hover,.ww-sidebar-toggle:hover{background:#0ea5e91a;border-color:#0ea5e94d}.ww-main{flex:1 1 0;overflow:hidden}.ww-layout{height:100%;display:flex}.ww-layout--sidebar .ww-content{flex:1 1 0}.ww-sidebar{width:300px;min-width:300px;height:100%;background:#fffc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-right:1px solid rgba(14,165,233,.1);display:flex;flex-direction:column;overflow:hidden}.ww-sidebar-tabs{display:flex;border-bottom:1px solid rgba(14,165,233,.1);flex-shrink:0}.ww-sidebar-tab{flex:1;padding:12px;font-size:.82rem;font-weight:600;color:#64748b;background:transparent;border:none;cursor:pointer;transition:all .2s ease;border-bottom:2px solid transparent}.ww-sidebar-tab--active{color:#0ea5e9;border-bottom-color:#0ea5e9;background:#0ea5e90a}.ww-sidebar-tab:hover:not(.ww-sidebar-tab--active){color:#334155;background:#00000005}.ww-content{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;overflow-y:auto;gap:16px}.ww-card{width:100%;max-width:580px;background:#fff;border-radius:16px;border:1px solid rgba(14,165,233,.12);box-shadow:0 4px 24px #0000000f,0 1px 4px #0000000a;padding:28px;display:flex;flex-direction:column;gap:20px;animation:wwCardIn .3s ease;transition:border-color .3s ease,box-shadow .3s ease}.ww-card--correct{border-color:#10b9814d;animation:wwCorrectFlash .6s ease}.ww-card--incorrect{border-color:#ef44444d;animation:wwIncorrectShake .4s ease}.ww-card--empty{align-items:center;justify-content:center;padding:48px 28px;text-align:center}.ww-card-empty-text{font-size:.95rem;color:#64748b}.ww-card-top{display:flex;align-items:center;gap:8px}.ww-card-counter{font-size:.75rem;font-weight:600;color:#94a3b8;background:#f1f5f9;padding:3px 10px;border-radius:20px}.ww-card-cat{font-size:.72rem;font-weight:500;color:#0ea5e9;background:#0ea5e914;padding:3px 10px;border-radius:20px;flex:1;text-align:center}.ww-card-copy{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#94a3b8;cursor:pointer;transition:all .2s ease}.ww-card-copy:hover{background:#f1f5f9;color:#475569}.ww-card-question{font-size:1.1rem;line-height:1.65;color:#1e293b;text-align:center;padding:8px 0}.ww-card-q-blank{display:inline-block;font-weight:700;color:#0ea5e9;border-bottom:2px dashed #0EA5E9;padding:0 4px;margin:0 2px}.ww-card-input-row{display:flex;align-items:center;gap:8px}.ww-card-input{flex:1;padding:12px 16px;border:2px solid #E2E8F0;border-radius:12px;font-size:1rem;font-family:inherit;color:#1e293b;background:#fafbfc;transition:all .2s ease;outline:none}.ww-card-input:focus{border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e91f}.ww-card-input--correct{border-color:#10b981;background:#10b9810a;color:#065f46}.ww-card-input--incorrect{border-color:#ef4444;background:#ef44440a;color:#991b1b}.ww-card-check-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:none;background:#0ea5e9;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.ww-card-check-btn:hover:not(:disabled){background:#0284c7;transform:scale(1.05)}.ww-card-check-btn:disabled{opacity:.4;cursor:not-allowed}.ww-card-result-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;flex-shrink:0}.ww-card-result-icon--correct{background:#10b9811f;color:#10b981}.ww-card-result-icon--incorrect{background:#ef44441f;color:#ef4444}.ww-card-correct-answer{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ef44440f;border-radius:10px;font-size:.88rem;color:#991b1b}.ww-card-correct-answer strong{color:#dc2626}.ww-card-reveal{display:flex;align-items:center;gap:6px;align-self:center;padding:4px 12px;border:none;background:transparent;color:#94a3b8;font-size:.78rem;cursor:pointer;transition:all .2s ease;border-radius:6px}.ww-card-reveal:hover{color:#64748b;background:#00000008}.ww-card-reveal--active{color:#0ea5e9;font-weight:600}.ww-card-streak{display:flex;align-items:center;justify-content:center;gap:12px;font-size:.78rem}.ww-streak-current{color:#f59e0b;font-weight:700}.ww-streak-best{color:#94a3b8;font-weight:500}.ww-card-nav{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:4px;border-top:1px solid #F1F5F9}.ww-nav-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;border:1px solid #E2E8F0;background:#fff;color:#475569;cursor:pointer;transition:all .2s ease}.ww-nav-btn:hover:not(:disabled){border-color:#0ea5e9;color:#0ea5e9;background:#0ea5e90a;transform:scale(1.05)}.ww-nav-btn:disabled{opacity:.3;cursor:not-allowed}.ww-nav-btn--next{background:#0ea5e9;border-color:#0ea5e9;color:#fff}.ww-nav-btn--next:hover:not(:disabled){background:#0284c7;border-color:#0284c7;color:#fff}.ww-item-debug{display:flex;align-items:center;gap:8px;font-size:.7rem;color:#94a3b8;background:#fff9;padding:6px 14px;border-radius:8px;max-width:580px;width:100%}.ww-debug-label{font-weight:600;color:#cbd5e1}.ww-debug-value{font-family:monospace;margin-right:8px}.ww-debug-status--correct{color:#10b981}.ww-debug-status--incorrect{color:#ef4444}.ww-debug-status--skipped{color:#f59e0b}.ww-debug-status--unanswered{color:#94a3b8}.ww-filter{flex:1 1 0;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:rgba(14,165,233,.15) transparent}.ww-filter-header{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:#334155;text-transform:uppercase;letter-spacing:.04em}.ww-filter-search{position:relative}.ww-filter-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#94a3b8}.ww-filter-search-input{width:100%;padding:9px 12px 9px 34px;border:1px solid #E2E8F0;border-radius:10px;font-size:.85rem;font-family:inherit;color:#1e293b;background:#fff;outline:none;transition:all .2s ease}.ww-filter-search-input:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e914}.ww-filter-toggles{display:flex;gap:8px}.ww-filter-toggle{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border:1px solid #E2E8F0;border-radius:10px;background:#fff;color:#64748b;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .2s ease}.ww-filter-toggle:hover{border-color:#0ea5e9;color:#0ea5e9}.ww-filter-toggle--active{background:#0ea5e914;border-color:#0ea5e9;color:#0ea5e9;font-weight:600}.ww-filter-cats{display:flex;flex-direction:column;gap:4px}.ww-filter-cats-title{font-size:.72rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;padding-bottom:4px}.ww-filter-cat{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid transparent;border-radius:8px;background:transparent;color:#475569;font-size:.8rem;cursor:pointer;transition:all .15s ease;text-align:left}.ww-filter-cat:hover{background:#0ea5e90a}.ww-filter-cat--active{background:#0ea5e914;border-color:#0ea5e933;color:#0ea5e9;font-weight:600}.ww-filter-cat-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ww-filter-cat-count{font-size:.7rem;font-weight:600;color:#94a3b8;background:#f1f5f9;padding:2px 8px;border-radius:12px;flex-shrink:0;margin-left:8px}.ww-filter-cat--active .ww-filter-cat-count{background:#0ea5e91f;color:#0ea5e9}.ww-filter-reset{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border:1px solid rgba(239,68,68,.2);border-radius:10px;background:transparent;color:#ef4444;font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:auto}.ww-filter-reset:hover{background:#ef44440f;border-color:#ef444459}.ww-progress{flex:1 1 0;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:rgba(14,165,233,.15) transparent}.ww-progress-header{display:flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:#334155;text-transform:uppercase;letter-spacing:.04em}.ww-progress-bar-wrap{display:flex;align-items:center;gap:10px}.ww-progress-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.ww-progress-bar-fill{height:100%;background:linear-gradient(90deg,#0ea5e9,#38bdf8);border-radius:4px;transition:width .4s ease}.ww-progress-pct{font-size:.82rem;font-weight:700;color:#0ea5e9;min-width:36px;text-align:right}.ww-progress-stats{display:flex;gap:12px}.ww-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;background:#f8fafc;border-radius:10px}.ww-stat-icon{flex-shrink:0}.ww-stat-icon--correct{color:#10b981}.ww-stat-icon--incorrect{color:#ef4444}.ww-stat-icon--skipped{color:#f59e0b}.ww-stat-value{font-size:1.1rem;font-weight:700;color:#1e293b}.ww-stat-label{font-size:.68rem;font-weight:500;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.ww-progress-summary{font-size:.82rem;color:#64748b;text-align:center}.ww-mistakes{display:flex;flex-direction:column;gap:8px}.ww-mistakes-title{font-size:.75rem;font-weight:600;color:#ef4444;text-transform:uppercase;letter-spacing:.04em}.ww-mistakes-list{display:flex;flex-direction:column;gap:4px}.ww-mistake-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:none;border-radius:8px;background:#ef44440a;cursor:pointer;transition:all .15s ease;text-align:left}.ww-mistake-item:hover{background:#ef444414}.ww-mistake-answer{font-size:.82rem;font-weight:600;color:#1e293b}.ww-mistake-cat{font-size:.68rem;color:#94a3b8}.ww-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.ww-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:480px;width:100%;max-height:80vh;overflow-y:auto}.ww-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #F1F5F9}.ww-modal-title{display:flex;align-items:center;gap:8px;font-size:1.05rem;font-weight:700;color:#1e293b}.ww-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s ease}.ww-modal-close:hover{background:#f1f5f9;color:#475569}.ww-modal-body{padding:20px 24px 24px;display:flex;flex-direction:column;gap:20px}.ww-modal-section h3{font-size:.88rem;font-weight:700;color:#334155;margin-bottom:6px}.ww-modal-section p{font-size:.82rem;color:#64748b;line-height:1.5;margin:0}.ww-modal-note{margin-top:8px!important;padding:10px 12px;background:#fffbeb;border-radius:8px;border:1px solid rgba(245,158,11,.15);font-size:.78rem!important;color:#92400e!important}@media (max-width: 768px){.ww-sidebar{display:none}.ww-content{padding:20px 16px}.ww-card{padding:20px}.ww-card-question{font-size:1rem}}@media (max-width: 480px){.ww-card{padding:16px;gap:14px}.ww-card-nav{gap:6px}.ww-nav-btn{width:36px;height:36px}}@keyframes loginSpinner{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-root{width:100svw;height:100svh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0,#f1f5f9);font-family:Inter,system-ui,sans-serif;padding:1rem}.login-card{width:100%;max-width:420px;background:#fff;border-radius:16px;padding:2.5rem 2rem;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;display:flex;flex-direction:column;gap:0}.login-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,#0ea5e9,#0284c7);display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1.25rem}.login-icon--success{background:linear-gradient(135deg,#10b981,#059669)}.login-title{font-family:Poppins,sans-serif;font-size:1.5rem;font-weight:700;color:#1e293b;text-align:center;margin-bottom:.375rem}.login-subtitle{font-size:.875rem;color:#64748b;text-align:center;margin-bottom:1.5rem;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-field{display:flex;flex-direction:column;gap:.25rem}.login-input-wrap{display:flex;align-items:center;gap:.625rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;padding:0 .875rem;transition:border-color .2s,box-shadow .2s}.login-input-wrap:focus-within{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91a}.login-input-icon{color:#94a3b8;flex-shrink:0}.login-input{flex:1;border:none;outline:none;background:transparent;font-size:.9375rem;padding:.75rem 0;color:#1e293b;font-family:inherit}.login-input::-moz-placeholder{color:#94a3b8}.login-input::placeholder{color:#94a3b8}.login-input--code{font-family:SF Mono,Fira Code,monospace;letter-spacing:.05em}.login-error{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.8125rem;line-height:1.4}.login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem;border-radius:10px;border:none;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.login-btn--primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;margin-top:.25rem}.login-btn--primary:hover{background:linear-gradient(135deg,#0284c7,#0369a1);transform:translateY(-1px);box-shadow:0 4px 12px #0ea5e94d}.login-btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.login-btn--google{background:#fff;color:#374151;border:1.5px solid #e2e8f0}.login-btn--google:hover{background:#f8fafc;border-color:#cbd5e1}.login-google-icon{flex-shrink:0}.login-spinner{animation:loginSpinner .8s linear infinite}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-divider span{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.login-switch{text-align:center;margin-top:.25rem}.login-switch p{font-size:.8125rem;color:#64748b}.login-switch-btn{background:none;border:none;color:#0ea5e9;font-weight:600;cursor:pointer;font-size:inherit;font-family:inherit;display:inline-flex;align-items:center;gap:.25rem}.login-switch-btn:hover{color:#0284c7;text-decoration:underline}.login-pupil-link{text-align:center;margin-top:1rem;padding-top:1rem;border-top:1px solid #f1f5f9}.join-card{width:100%;max-width:480px;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 24px #00000014,0 1px 4px #0000000a;display:flex;flex-direction:column;gap:0}.join-back{display:inline-flex;align-items:center;gap:.375rem;background:none;border:none;color:#64748b;font-size:.8125rem;font-family:inherit;cursor:pointer;margin-bottom:1rem;padding:0}.join-back:hover{color:#0ea5e9}.join-class-badge{display:inline-flex;align-items:center;gap:.375rem;background:#ecfdf5;color:#059669;border:1px solid #a7f3d0;border-radius:8px;padding:.375rem .75rem;font-size:.8125rem;font-weight:600;margin:0 auto 1rem}.join-pupil-list{display:flex;flex-direction:column;gap:.375rem;max-height:280px;overflow-y:auto;margin-bottom:.75rem}.join-pupil-btn{display:flex;align-items:center;gap:.625rem;width:100%;padding:.75rem 1rem;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.9375rem;font-family:inherit;color:#1e293b;cursor:pointer;transition:all .15s}.join-pupil-btn:hover{background:#eff6ff;border-color:#93c5fd}.join-pupil-btn:disabled{opacity:.5;cursor:wait}.join-empty{text-align:center;color:#64748b;font-size:.875rem;padding:1rem}.settings-add-class-form{display:flex;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.settings-add-class-form .settings-input{flex:1;min-width:100px}.settings-add-pupil-form{display:flex;gap:.5rem;margin-bottom:.75rem}.settings-add-pupil-form .settings-input{flex:1}.settings-input--code{font-family:SF Mono,Fira Code,monospace;font-size:.8rem;letter-spacing:.03em}.settings-code-section{background:#f8fafc;border-radius:10px;padding:.875rem;margin-bottom:.75rem}.settings-code-display{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.settings-code-value{flex:1;font-family:SF Mono,Fira Code,monospace;font-size:.9rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:.5rem .75rem;color:#0ea5e9;font-weight:600;letter-spacing:.03em}.settings-code-copy{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;transition:all .15s}.settings-code-copy:hover{color:#0ea5e9;border-color:#93c5fd}.settings-code-edit-btn{font-size:.75rem;color:#64748b;background:none;border:none;cursor:pointer;font-family:inherit;font-weight:500}.settings-code-edit-btn:hover{color:#0ea5e9}.settings-code-edit{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}.settings-code-save{font-size:.75rem;color:#fff;background:#0ea5e9;border:none;border-radius:6px;padding:.375rem .75rem;cursor:pointer;font-family:inherit;font-weight:600}.settings-code-cancel{font-size:.75rem;color:#64748b;background:none;border:none;cursor:pointer;font-family:inherit}.settings-code-error{color:#dc2626;font-size:.75rem;margin-top:.375rem}.settings-tabs{display:flex;gap:0;border-bottom:1.5px solid #e2e8f0;margin-bottom:.75rem}.settings-tab{display:flex;align-items:center;gap:.375rem;flex:1;padding:.625rem .5rem;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-size:.8125rem;font-weight:500;font-family:inherit;cursor:pointer;justify-content:center;transition:all .15s}.settings-tab:hover{color:#1e293b}.settings-tab--active{color:#0ea5e9;border-bottom-color:#0ea5e9}.settings-group-select{font-size:.8rem;padding:.375rem .5rem;border:1px solid #e2e8f0;border-radius:6px;background:#fff;color:#1e293b;font-family:inherit;min-width:100px}.settings-pupil-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.settings-pupil-email{font-size:.6875rem;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-pupil-linked{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;background:#dbeafe;color:#2563eb;font-size:.625rem;font-weight:700;flex-shrink:0}.settings-pupil-actions{display:flex;align-items:center;gap:.375rem}.settings-pupil-group-select{font-size:.75rem;padding:.25rem .375rem;border:1px solid #e2e8f0;border-radius:4px;background:#fff;color:#1e293b;font-family:inherit;max-width:100px}.settings-pupil-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .625rem;border-radius:6px;transition:background .1s}.settings-pupil-item:hover{background:#f8fafc}.settings-group-list{display:flex;flex-direction:column;gap:.25rem}.settings-group-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;border-radius:6px;transition:background .1s}.settings-group-item:hover{background:#f8fafc}.settings-group-name{flex:1;font-size:.875rem;font-weight:500;color:#1e293b}.settings-group-count{font-size:.75rem;color:#94a3b8}.settings-group-delete{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s}.settings-group-delete:hover{background:#fef2f2;color:#ef4444}.settings-pupil-group-tag{font-size:.6875rem;background:#f1f5f9;color:#64748b;padding:.125rem .375rem;border-radius:4px}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.join-card{padding:1.5rem}.settings-add-class-form{flex-direction:column}}.last\:border-0:last-child{border-width:0px}.hover\:border-slate-300:hover{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity, 1))}.hover\:bg-emerald-100:hover{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity, 1))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:bg-red-600:hover{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.hover\:bg-sky-50:hover{--tw-bg-opacity: 1;background-color:rgb(240 249 255 / var(--tw-bg-opacity, 1))}.hover\:bg-sky-600:hover{--tw-bg-opacity: 1;background-color:rgb(2 132 199 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-100:hover{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-200:hover{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-50:hover{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity, 1))}.hover\:bg-white:hover{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.hover\:text-red-500:hover{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.hover\:text-sky-500:hover{--tw-text-opacity: 1;color:rgb(14 165 233 / var(--tw-text-opacity, 1))}.hover\:text-slate-400:hover{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.hover\:text-slate-500:hover{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.hover\:text-slate-600:hover{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.hover\:text-slate-700:hover{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-sm:hover{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-sky-400:focus{--tw-border-opacity: 1;border-color:rgb(56 189 248 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-sky-400:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(56 189 248 / var(--tw-ring-opacity, 1))}.focus\:ring-sky-400\/30:focus{--tw-ring-color: rgb(56 189 248 / .3)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:border-slate-400{--tw-border-opacity: 1;border-color:rgb(148 163 184 / var(--tw-border-opacity, 1))}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width: 640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
