:root{color-scheme:light dark;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;line-height:1.5;--bg: #fafafa;--fg: #18181b;--muted: #6b7280;--border: #e4e4e7;--accent: #4338ca;--accent-fg: #ffffff;--good: #16a34a;--bad: #dc2626}@media(prefers-color-scheme:dark){:root{--bg: #09090b;--fg: #fafafa;--muted: #a1a1aa;--border: #27272a;--accent: #818cf8;--accent-fg: #0b0b13}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--fg)}.app{max-width:720px;margin:0 auto;padding:32px 20px 80px}header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:12px}header h1{margin:0;font-size:1.5rem;letter-spacing:-.01em}header .tagline{color:var(--muted);font-size:.875rem}header{flex-wrap:wrap;gap:12px}.intro{margin-top:0;margin-bottom:16px}.small{font-size:.875rem}.actions{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}.actions button{min-width:12rem}main section{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}main section h2{margin-top:0;font-size:1.1rem}select,input,button{font:inherit;color:var(--fg);background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:6px 10px}button{cursor:pointer;background:var(--accent);color:var(--accent-fg);border-color:transparent}button:disabled{opacity:.55;cursor:not-allowed}button.secondary{background:transparent;color:var(--fg);border-color:var(--border)}.muted{color:var(--muted)}.bad{color:var(--bad)}.good{color:var(--good)}.auth-card{max-width:420px;margin:48px auto 0}.auth-form{display:flex;flex-direction:column;gap:14px}.form-field{display:flex;flex-direction:column;gap:6px;font-size:.875rem}.form-field label{color:var(--muted);font-weight:500}.form-field input,.form-field select{width:100%}.form-field .field-error{color:var(--bad);font-size:.8rem;margin:0}.auth-submit{width:100%;margin-top:4px;padding:10px;font-size:1rem}.auth-footer{text-align:center;font-size:.875rem;color:var(--muted);margin-top:8px}.auth-footer a,.auth-link{color:var(--accent);background:none;border:none;cursor:pointer;font:inherit;text-decoration:underline;padding:0}.auth-back{margin:0 0 14px;text-align:left}.t-dashboard{max-width:860px;margin:0 auto}.t-profile-bar{margin-bottom:0;border-bottom:none!important;border-radius:12px 12px 0 0!important}.t-tab-nav{display:flex;gap:2px;padding:0 1px;background:var(--border);border-radius:0;overflow-x:auto;scrollbar-width:none}.t-tab-nav::-webkit-scrollbar{display:none}.t-tab{flex-shrink:0;padding:10px 20px;border:none;border-radius:0;background:color-mix(in srgb,var(--bg) 96%,var(--border));color:var(--muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.t-tab:first-child{border-radius:0}.t-tab:hover:not(.t-tab--active){background:var(--bg);color:var(--fg)}.t-tab--active{background:var(--bg);color:var(--accent);font-weight:600;box-shadow:inset 0 -2px 0 var(--accent)}.t-tab-content{border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;padding:24px;margin-bottom:0!important;background:var(--bg)}.t-section-title{margin:0 0 18px;font-size:1.05rem}.t-badge{display:inline-block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:6px;background:color-mix(in srgb,var(--bg) 85%,var(--border));color:var(--muted)}.t-badge--ok{background:color-mix(in srgb,var(--good) 18%,var(--bg));color:var(--good)}.t-badge--warn{background:color-mix(in srgb,#f59e0b 18%,var(--bg));color:#b45309}.t-badge--info{background:color-mix(in srgb,var(--accent) 18%,var(--bg));color:var(--accent)}.t-badge--muted{background:color-mix(in srgb,var(--muted) 12%,var(--bg));color:var(--muted)}.t-empty{padding:28px 0;text-align:center;color:var(--muted);font-size:.9rem}.t-toolbar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}.t-field{display:flex;flex-direction:column;gap:4px;font-size:.875rem}.t-field-row{display:flex;gap:12px;flex-wrap:wrap}.t-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;opacity:.55}.t-roster{display:flex;flex-direction:column;gap:12px}.t-roster-toolbar{display:flex;flex-direction:column;gap:0}.t-input--search{max-width:340px;padding:7px 12px;outline:none}.t-input--search:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 20%,transparent)}.t-roster-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.t-roster-card{border:1px solid var(--border);border-radius:10px;padding:14px 16px;background:var(--bg);display:flex;flex-direction:column;gap:10px}.t-roster-card:hover{border-color:color-mix(in srgb,var(--border) 60%,var(--accent))}.t-roster-header{display:flex;align-items:center;gap:12px}.t-roster-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:var(--accent-fg);font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.03em}.t-roster-identity{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.t-roster-name{font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-roster-meta{display:flex;flex-wrap:wrap;gap:4px}.t-roster-expand{background:transparent;border:1px solid var(--border);border-radius:6px;padding:3px 8px;cursor:pointer;font-size:.75rem;color:var(--muted);flex-shrink:0;transition:background .1s,color .1s}.t-roster-expand:hover{background:color-mix(in srgb,var(--bg) 80%,var(--border));color:var(--fg)}.t-roster-stats{display:flex;flex-wrap:wrap;gap:16px;font-size:.8rem;color:var(--muted);padding:2px 0}.t-roster-stats span{white-space:nowrap}.t-roster-subjects{border-top:1px solid var(--border);padding-top:10px}.t-roster-subject-table{width:100%;border-collapse:collapse;font-size:.84rem}.t-roster-subject-table th{text-align:left;font-weight:500;color:var(--muted);padding:4px 8px 6px 0;border-bottom:1px solid var(--border)}.t-roster-subject-table td{padding:5px 8px 5px 0;border-bottom:1px solid var(--border);vertical-align:middle}.t-roster-subject-table tr:last-child td{border-bottom:none}.t-roster-actions{display:flex;gap:6px;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:10px}.t-btn--sm{padding:4px 12px;font-size:.8rem;border-radius:6px}.t-btn--secondary{background:transparent;color:var(--fg);border:1px solid var(--border)}.t-btn--secondary:hover{background:color-mix(in srgb,var(--bg) 80%,var(--border))}.t-student-list{list-style:none;margin:0;padding:0}.t-student-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.t-student-row:last-child{border-bottom:none}.t-student-name{font-weight:500;flex:1}.t-student-grade{font-size:.82rem;color:var(--muted)}.t-progress-body{margin-top:4px}.t-skill-table{width:100%;border-collapse:collapse;font-size:.875rem;margin-top:16px}.t-skill-table th,.t-skill-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}.t-skill-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;opacity:.55;font-weight:600}.t-skill-table tbody tr:last-child td{border-bottom:none}.t-severity{font-size:.8rem;color:var(--muted)}.t-filter-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.t-filter-btn{padding:5px 14px;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--fg);font-size:.82rem;cursor:pointer;transition:background .1s,border-color .1s}.t-filter-btn:hover:not(.t-filter-btn--active){border-color:var(--accent);color:var(--accent)}.t-filter-btn--active{background:var(--accent);color:var(--accent-fg);border-color:transparent}.t-q-list{list-style:none;margin:0;padding:0}.t-q-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.t-q-row:last-child{border-bottom:none}.t-q-row-info{display:flex;flex-direction:column;gap:2px}.t-q-severity{font-weight:500;font-size:.875rem}.t-q-row-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.t-q-detail{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:16px}.t-q-detail-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:color-mix(in srgb,var(--bg) 94%,var(--border));border-bottom:1px solid var(--border);font-size:.9rem}.t-q-detail-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.t-q-body{padding:16px}.t-q-prompt{font-size:1.1rem;font-weight:500;line-height:1.55;margin:0 0 4px}.t-q-student-card{background:color-mix(in srgb,var(--accent) 4%,var(--bg));border:1px solid var(--border);border-radius:10px;padding:18px 18px 14px;margin-bottom:16px}.t-q-opts-student{display:flex;flex-direction:column;gap:8px}.t-q-opt-row{display:flex;align-items:center;gap:10px;padding:9px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:.925rem;background:var(--bg);transition:border-color .15s,background .15s}.t-q-opt-row--correct{border-color:var(--good);background:color-mix(in srgb,var(--good) 8%,var(--bg))}.t-q-opt-marker{font-size:1rem;opacity:.45;flex-shrink:0}.t-q-opt-label{flex:1}.t-q-correct-badge{font-size:.75rem;font-weight:600;color:var(--good);background:color-mix(in srgb,var(--good) 12%,var(--bg));padding:2px 7px;border-radius:20px;white-space:nowrap;flex-shrink:0}.t-q-open-answer{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1.5px solid var(--good);border-radius:8px;background:color-mix(in srgb,var(--good) 8%,var(--bg));font-size:.925rem;font-weight:500;margin:0}.t-q-preview-panel{background:color-mix(in srgb,var(--accent) 6%,var(--bg));border:1px dashed var(--accent);border-radius:8px;padding:12px 14px}.t-q-section{border-top:1px solid var(--border);padding-top:14px;margin-bottom:14px}.t-q-hints-list{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--fg)}.t-q-hints-list li{line-height:1.45}.t-q-explanation-text{font-size:.9rem;line-height:1.5;margin:0;background:color-mix(in srgb,var(--bg) 94%,var(--border));border-radius:8px;padding:10px 12px}.t-q-prev-comment{font-size:.875rem;line-height:1.45;margin:0;padding:8px 12px;border-left:3px solid var(--border);color:var(--muted)}.t-textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font:inherit;background:var(--bg);color:var(--fg);resize:vertical}.t-review-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.t-btn-approve{background:var(--good);color:#fff;border-color:transparent;padding:7px 16px;font-size:.875rem}.t-btn-correct{background:var(--accent);color:var(--accent-fg);border-color:transparent;padding:7px 16px;font-size:.875rem}.t-btn-reject{background:var(--bad);color:#fff;border-color:transparent;padding:7px 16px;font-size:.875rem}.t-assignment-list{list-style:none;margin:0;padding:0}.t-assignment-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.t-assignment-row:last-child{border-bottom:none}.t-assignment-info{display:flex;flex-direction:column;gap:3px;flex:1}.t-assignment-title{font-weight:500}.t-assignment-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.t-session-list{list-style:none;margin:0;padding:0}.t-session-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.t-session-row:last-child{border-bottom:none}.t-session-info{display:flex;flex-direction:column;gap:3px;flex:1}.t-session-title{font-weight:500}.t-session-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.t-create-form{border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:18px;display:flex;flex-direction:column;gap:12px;background:color-mix(in srgb,var(--bg) 97%,var(--border))}.t-create-form-title{margin:0;font-weight:600;font-size:.95rem}.t-create-form .t-field input,.t-create-form .t-field select,.t-create-form .t-field .t-textarea{width:100%}.t-form-actions{display:flex;gap:8px;flex-wrap:wrap}.t-student-checkboxes{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.t-student-check-label{display:flex;align-items:center;gap:6px;font-size:.875rem;padding:5px 10px;border:1px solid var(--border);border-radius:7px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:border-color .1s,background .1s}.t-student-check-label:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--bg))}.t-student-check-label input[type=checkbox]{margin:0;width:auto;accent-color:var(--accent)}.strategy-config{display:flex;flex-direction:column;gap:12px;margin-top:12px}.strategy-toggle{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.strategy-toggle input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.strategy-toggle-label{display:flex;flex-direction:column;gap:3px}.strategy-toggle-label strong{font-size:.95rem}.strategy-toggle-label span{font-size:.82rem;color:var(--muted)}.window-tabs{display:flex;gap:4px}.window-tab{padding:4px 12px;border-radius:16px;border:1px solid var(--border);background:transparent;font:inherit;font-size:.82rem;cursor:pointer;transition:background .1s,border-color .1s}.window-tab--active{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.activity-totals{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.stat-pill{display:flex;flex-direction:column;padding:8px 14px;border-radius:10px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 96%,var(--border));min-width:80px}.stat-pill--good{border-color:color-mix(in srgb,var(--good) 40%,transparent);background:color-mix(in srgb,var(--good) 8%,var(--bg))}.stat-value{font-size:1.4rem;font-weight:700;line-height:1.2}.stat-label{font-size:.72rem;opacity:.6;margin-top:2px}.activity-chart{display:flex;align-items:flex-end;gap:4px;height:80px;padding-bottom:20px;position:relative}.activity-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;position:relative}.activity-bar{width:100%;min-height:2px;border-radius:3px 3px 0 0;background:var(--border);transition:height .2s}.activity-bar--active{background:var(--accent)}.activity-label{position:absolute;bottom:-18px;font-size:.62rem;opacity:.55;white-space:nowrap}.subject-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.subject-card{border:1px solid var(--border);border-radius:12px;padding:16px 18px;background:var(--bg)}.subject-card-header{margin-bottom:10px}.subject-card-header h3{margin:0 0 2px;font-size:1rem}.tag-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:5px}.tag{font-size:.78rem;padding:2px 8px;border-radius:6px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 92%,var(--border))}.tag--good{border-color:color-mix(in srgb,var(--good) 35%,transparent);background:color-mix(in srgb,var(--good) 8%,var(--bg));color:var(--good)}.tag--bad{border-color:color-mix(in srgb,var(--bad) 35%,transparent);background:color-mix(in srgb,var(--bad) 8%,var(--bg));color:var(--bad)}.report-section{margin-bottom:28px}.report-section h3{margin:0 0 14px;font-size:1rem}.report-section-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:14px}.report-section-head h3{margin:0}.section-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 5px;font-weight:600;opacity:.65}.section-label.good{color:var(--good);opacity:1}.section-label.bad{color:var(--bad);opacity:1}.session-timeout-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#0000008c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:20px;animation:timeout-fade-in .18s ease-out both}@keyframes timeout-fade-in{0%{opacity:0}to{opacity:1}}.session-timeout-card{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:32px 28px 24px;width:100%;max-width:380px;box-shadow:0 20px 60px #00000040;animation:timeout-slide-up .18s ease-out both}@keyframes timeout-slide-up{0%{transform:translateY(12px)}to{transform:translateY(0)}}.session-timeout-title{margin:0 0 12px;font-size:1.15rem}.session-timeout-body{margin:0 0 8px;font-size:1rem}.session-timeout-actions{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}.session-timeout-actions button{flex:1;min-width:0}
