:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--surface:#fafafa;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#7c3aed;--accent-light:#a78bfa;--accent-bg:#7c3aed14;--accent-border:#7c3aed59;--social-bg:#f4f3ec80;--shadow:#00000014 0 4px 6px -1px, #0000000a 0 2px 4px -1px;--shadow-md:#0000001f 0 10px 20px -4px, #0000000f 0 4px 8px -2px;--radius:12px;--radius-sm:8px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/1.5 var(--sans);letter-spacing:.1px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}:root:not([data-theme=light]){--text:#9ca3af;--text-h:#f3f4f6;--bg:#0f0f13;--surface:#16171d;--border:#2a2b35;--code-bg:#1e1f27;--accent:#a78bfa;--accent-light:#c4b5fd;--accent-bg:#a78bfa1f;--accent-border:#a78bfa66;--social-bg:#2f303a80;--shadow:#00000080 0 4px 12px -2px, #0000004d 0 2px 6px -2px;--shadow-md:#0009 0 12px 24px -4px, #00000059 0 6px 10px -3px}:root:not([data-theme=light]) #social .button-icon{filter:invert()brightness(2)}}:root[data-theme=dark]{--text:#9ca3af;--text-h:#f3f4f6;--bg:#0f0f13;--surface:#16171d;--border:#2a2b35;--code-bg:#1e1f27;--accent:#a78bfa;--accent-light:#c4b5fd;--accent-bg:#a78bfa1f;--accent-border:#a78bfa66;--social-bg:#2f303a80;--shadow:#00000080 0 4px 12px -2px, #0000004d 0 2px 6px -2px;--shadow-md:#0009 0 12px 24px -4px, #00000059 0 6px 10px -3px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{letter-spacing:-.5px;margin:0 0 20px;font-size:28px}h2{letter-spacing:-.2px;margin:0 0 8px;font-size:20px;line-height:1.3}p{margin:0}code{font-family:var(--mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:2px 6px;font-size:14px;line-height:1.4}.app-shell{flex-direction:column;min-height:100svh;display:flex}.app-header{border-bottom:1px solid var(--border);background:var(--bg);z-index:10;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.app-header-logo{width:auto;height:160px;padding-top:12px;display:block}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .app-header-logo,:root:not([data-theme=light]) .auth-logo-img{filter:invert()}}:root[data-theme=dark] .app-header-logo,:root[data-theme=dark] .auth-logo-img{filter:invert()}.app-header-right{align-items:center;gap:4px;display:flex}.app-main{flex:1;padding:24px 16px 48px}.page-status{text-align:center;color:var(--text);padding:48px 0;font-size:15px}.page-error{color:#dc2626}.back-btn{color:var(--accent);cursor:pointer;opacity:.8;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:20px;padding:0;font-size:15px;font-weight:500;transition:opacity .15s;display:flex}.back-btn:hover{opacity:1}.units-page{max-width:540px;margin:0 auto}.page-title{letter-spacing:-.4px;text-align:left;color:var(--text-h);margin:0 0 20px;font-size:24px;font-weight:700}.unit-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.unit-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;align-items:center;gap:14px;width:100%;padding:16px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.unit-card:hover:not(:disabled){border-color:var(--accent-border);box-shadow:var(--shadow);transform:translateY(-1px)}.unit-card:active:not(:disabled){transform:translateY(0)}.unit-number{background:var(--accent-bg);width:32px;height:32px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.unit-title{color:var(--text-h);flex:1;font-size:16px;font-weight:600;line-height:1.3}.unit-arrow{color:var(--text);flex-shrink:0;font-size:20px}.chapter-page{max-width:640px;margin:0 auto;padding-bottom:48px}.chapter-type-label{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:6px;font-size:11px;font-weight:700}.chapter-passed-banner{color:#15803d;border-radius:var(--radius-sm);background:#dcfce7;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}@media (prefers-color-scheme:dark){.chapter-passed-banner{color:#4ade80;background:#15803d26}}.chapter-video{border-radius:var(--radius);background:#000;height:0;margin-bottom:24px;padding-bottom:56.25%;position:relative;overflow:hidden}.chapter-video iframe{border:none;width:100%;height:100%;position:absolute;inset:0}.chapter-body{color:var(--text-h);white-space:pre-wrap;margin-bottom:28px;font-size:16px;line-height:1.75}.chapter-pdf-wrap{margin-bottom:28px}.chapter-pdf-frame{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;height:500px;margin-bottom:8px;display:block}@media (width<=600px){.chapter-pdf-frame{height:360px}}.chapter-doc-link{color:var(--accent);border:1px solid var(--accent-border);background:var(--accent-bg);border-radius:99px;align-items:center;gap:6px;margin-bottom:28px;padding:8px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:opacity .15s;display:inline-flex}.chapter-doc-link:hover{opacity:.8}.chapter-section-title{color:var(--text-h);margin:0 0 12px;font-size:17px;font-weight:600}.chapter-checklist{margin-bottom:32px}.checklist-item{border-bottom:1px solid var(--border);cursor:pointer;color:var(--text-h);align-items:flex-start;gap:12px;padding:12px 0;font-size:15px;display:flex}.checklist-item input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0;margin-top:2px}.checklist-item:last-child{border-bottom:none}.chapter-quiz{margin-bottom:32px}.quiz-form{flex-direction:column;gap:20px;display:flex}.quiz-step{flex-direction:column;gap:12px;display:flex}.quiz-step-counter{text-transform:uppercase;letter-spacing:.06em;color:var(--text);margin:0;font-size:12px;font-weight:600}.quiz-fr-confirmed{color:var(--text-h);border-left:3px solid var(--accent);background:var(--surface);border-radius:0 8px 8px 0;margin:0;padding:14px 16px;font-size:15px}.quiz-question{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.quiz-prompt{color:var(--text-h);margin:0 0 12px;font-size:15px;font-weight:600;line-height:1.4}.quiz-choices{flex-direction:column;gap:8px;display:flex}.quiz-choice{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-h);align-items:center;gap:10px;min-height:44px;padding:12px 14px;font-size:15px;transition:border-color .15s,background .15s;display:flex}.quiz-choice:has(input:checked){border-color:var(--accent);background:var(--accent-bg)}.quiz-choice input{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0}.quiz-result{text-align:center;border-radius:var(--radius);flex-direction:column;align-items:center;gap:12px;padding:32px 20px;display:flex}.quiz-pass{background:#f0fdf4;border:1.5px solid #bbf7d0}@media (prefers-color-scheme:dark){.quiz-pass{background:#15803d1f;border-color:#4ade804d}}.quiz-fail{background:#fff1f2;border:1.5px solid #fecdd3}@media (prefers-color-scheme:dark){.quiz-fail{background:#dc26261a;border-color:#fca5a54d}}.quiz-pending{background:#fffbeb;border:1.5px solid #fde68a}@media (prefers-color-scheme:dark){.quiz-pending{background:#eab3081a;border-color:#fde68a4d}}.quiz-free-response{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--text-h);resize:vertical;box-sizing:border-box;border-radius:8px;margin-top:6px;padding:10px 12px;font-family:inherit;font-size:15px}.quiz-free-response:focus{border-color:var(--accent);outline:none}.badge-pending{color:#92400e;cursor:pointer;background:#fef9c3}@media (prefers-color-scheme:dark){.badge-pending{color:#fde68a;background:#eab30833}}.review-overlay{z-index:200;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.review-panel{background:var(--surface);border-radius:16px;flex-direction:column;gap:16px;width:100%;max-width:560px;max-height:80vh;padding:24px;display:flex;overflow-y:auto}.review-panel-header{justify-content:space-between;align-items:flex-start;display:flex}.review-panel-title{color:var(--text-h);margin:0;font-size:18px;font-weight:700}.review-panel-sub{color:var(--text);margin:2px 0 0;font-size:13px}.review-mc-score{color:var(--text);background:var(--bg);border-radius:8px;margin:0;padding:8px 12px;font-size:13px}.review-answers{flex-direction:column;gap:12px;display:flex}.review-answer{background:var(--bg);border-radius:8px;padding:12px 14px}.review-answer-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text);margin:0 0 6px;font-size:11px;font-weight:600}.review-answer-text{color:var(--text-h);white-space:pre-wrap;margin:0;font-size:15px}.review-answer-grade{gap:8px;margin-top:10px;display:flex}.review-grade-btn{border:1.5px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:600;transition:background .15s,border-color .15s,color .15s}.review-grade-btn:hover{border-color:var(--accent)}.review-grade-btn.grade-pass{color:#fff;background:#16a34a;border-color:#16a34a}.review-grade-btn.grade-fail{color:#fff;background:#dc2626;border-color:#dc2626}.review-panel-actions{justify-content:flex-end;gap:10px;padding-top:4px;display:flex}.quiz-result-score{letter-spacing:-2px;color:var(--text-h);margin:0;font-size:52px;font-weight:800}.quiz-result-msg{color:var(--text-h);margin:0;font-size:15px;font-weight:500}.unit-card-locked{opacity:.45;cursor:not-allowed}.unit-card-locked:hover{border-color:var(--border);box-shadow:none;transform:none}.unit-card-reflection{border-style:dashed;border-color:var(--accent-border);background:var(--accent-bg)}.unit-number-done{color:#15803d;background:#dcfce7}@media (prefers-color-scheme:dark){.unit-number-done{color:#4ade80;background:#15803d33}}.unit-lock-hint{color:var(--text);margin:6px 0 0 46px;font-size:12px}.auth-link{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:14px;font-weight:500;transition:color .15s,background .15s}.auth-link:hover{color:var(--text-h);background:var(--accent-bg)}.auth-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;width:100%;min-height:48px;padding:13px 20px;font-size:16px;font-weight:600;transition:opacity .2s,transform .15s}.auth-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.auth-btn:active:not(:disabled){transform:translateY(0)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-wrap{box-sizing:border-box;background:var(--bg);justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex}.auth-card{background:var(--bg);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow-md);border-radius:16px;padding:36px 28px}.auth-logo-img{width:auto;height:200px;margin:0 auto 24px;display:block}.auth-title{letter-spacing:-.5px;color:var(--text-h);text-align:left;margin:0 0 4px;font-size:24px;font-weight:700}.auth-subtitle{color:var(--text);text-align:left;margin-bottom:28px;font-size:14px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-field{text-align:left;color:var(--text-h);text-transform:uppercase;letter-spacing:.04em;flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.auth-field input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-h);min-height:48px;font-size:16px;font-family:var(--sans);outline:none;padding:12px 14px;transition:border-color .2s,box-shadow .2s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.auth-error{color:#dc2626;text-transform:none;letter-spacing:0;margin:0;font-size:13px;font-weight:500}.auth-success{color:#16a34a;text-transform:none;letter-spacing:0;margin:16px 0 0;font-size:14px;font-weight:500}.auth-forgot-btn{color:var(--text);cursor:pointer;text-align:center;opacity:.7;background:0 0;border:none;margin-top:-4px;padding:0;font-size:13px;text-decoration:underline}.auth-forgot-btn:hover{opacity:1}.auth-switch{color:var(--text);text-align:center;margin-top:20px;font-size:14px}.auth-switch button{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;font-weight:600;text-decoration:underline}.admin-tabs{border-bottom:1.5px solid var(--border);gap:0;margin-bottom:28px;display:flex}.admin-tab{cursor:pointer;color:var(--text);letter-spacing:.02em;background:0 0;border:none;border-bottom:2.5px solid #0000;margin-bottom:-1.5px;padding:10px 20px;font-size:14px;font-weight:600;transition:color .15s,border-color .15s}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-tab:hover:not(.active){color:var(--text-h)}.admin-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:6px;min-height:36px;padding:8px 16px;font-size:14px;font-weight:600;transition:opacity .2s,transform .15s}.admin-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.admin-btn:active:not(:disabled){transform:translateY(0)}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-ghost{color:var(--text-h);border:1.5px solid var(--border);background:0 0}.admin-btn-ghost:hover:not(:disabled){background:var(--surface);opacity:1;transform:none}.admin-field{color:var(--text-h);text-align:left;text-transform:uppercase;letter-spacing:.04em;flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.admin-field-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-h);font-size:15px;font-family:var(--sans);outline:none;width:100%;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.admin-field input,.admin-field textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-h);font-size:15px;font-family:var(--sans);resize:vertical;text-transform:none;letter-spacing:0;outline:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s}:is(.admin-field input,.admin-field textarea):focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.admin-field-row{text-transform:none;letter-spacing:0;flex-direction:row;align-items:center;gap:8px;font-size:14px;font-weight:500}.admin-field-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.cm-wrap{flex-direction:column;gap:20px;display:flex}.cm-header{justify-content:space-between;align-items:center;display:flex}.cm-section-title{color:var(--text-h);margin:0;font-size:18px;font-weight:700}.cm-unit-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.cm-unit{border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden}.cm-drag-handle{cursor:grab;color:var(--text);opacity:.35;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 4px;font-size:16px}.cm-drag-handle:active{cursor:grabbing}.cm-unit-row{background:var(--surface);align-items:center;gap:4px;padding:4px 8px 4px 0;display:flex}.cm-unit[draggable]:hover>.cm-unit-row .cm-drag-handle,.cm-chapter-row[draggable]:hover .cm-drag-handle{opacity:.7}.cm-unit-toggle{cursor:pointer;text-align:left;color:var(--text-h);background:0 0;border:none;flex:1;align-items:center;gap:12px;min-height:48px;padding:12px 14px;font-size:15px;font-weight:600;display:flex}.cm-icon-btn{cursor:pointer;color:var(--text);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:6px 8px;font-size:15px;line-height:1;transition:background .15s,color .15s;display:flex}.cm-icon-btn:hover{background:var(--accent-bg);color:var(--accent)}.cm-danger:hover{color:#dc2626;background:#fee2e2}.cm-chapter-list{flex-direction:column;gap:6px;padding:12px 14px 16px;display:flex}.cm-chapter-row{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);align-items:center;gap:10px;min-height:48px;padding:10px 12px;display:flex}.cm-chapter-num{color:var(--text);min-width:18px;font-size:12px;font-weight:600}.cm-chapter-title{color:var(--text-h);flex:1;font-size:14px;font-weight:500}.cm-add-chapter-btn{border:1.5px dashed var(--accent-border);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;background:0 0;width:100%;min-height:44px;padding:10px;font-size:14px;font-weight:600;transition:background .15s}.cm-add-chapter-btn:hover{background:var(--accent-bg)}.cm-form-overlay{border:1.5px solid var(--accent-border);border-radius:var(--radius);background:var(--bg);margin-top:12px;padding:20px}.cm-form{flex-direction:column;gap:16px;display:flex}.cm-form-title{color:var(--text-h);margin:0;font-size:16px;font-weight:700}.cm-form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.cm-doc-link{color:var(--accent);font-size:13px;font-weight:500}.cm-badge{background:var(--accent-bg);color:var(--accent);letter-spacing:.02em;text-transform:uppercase;border-radius:99px;margin-left:auto;margin-right:4px;padding:2px 8px;font-size:11px;font-weight:700}.cm-badge-reflection{color:#92400e;background:#fef3c7}@media (prefers-color-scheme:dark){.cm-badge-reflection{color:#fbbf24;background:#92400e33}}.cm-reflection-row{background:#fffbeb;border-color:#fde68a}@media (prefers-color-scheme:dark){.cm-reflection-row{background:#92400e14;border-color:#fbbf244d}}.cm-add-row{display:flex}.cm-add-choice{align-items:center;gap:8px;padding:8px 0;display:flex}.cm-questions{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);flex-direction:column;gap:16px;padding:16px;display:flex}.cm-questions-header{justify-content:space-between;align-items:center;display:flex}.cm-question{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);flex-direction:column;gap:10px;padding:14px;display:flex}.cm-question-header{justify-content:space-between;align-items:center;display:flex}.courses-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.courses-empty{color:var(--text);flex-direction:column;align-items:center;gap:16px;padding:48px 20px;display:flex}.course-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.course-card{background:var(--surface);border-radius:var(--radius);cursor:pointer;border:1.5px solid var(--border);align-items:center;gap:12px;padding:16px 18px;transition:border-color .15s,box-shadow .15s;display:flex}.course-card:hover{border-color:var(--accent);box-shadow:0 2px 12px #0000000f}.course-card-body{flex-direction:column;flex:1;gap:4px;display:flex}.course-dept-logo{object-fit:contain;border-radius:8px;flex-shrink:0;width:48px;height:48px}.course-dept-name{color:var(--text);opacity:.55;margin-top:2px;font-size:12px}.course-card-title{color:var(--text-h);font-size:16px;font-weight:600}.course-card-desc{color:var(--text);font-size:13px}.course-badge-required{background:rgba(var(--accent-rgb,99,102,241), .12);color:var(--accent);border-radius:99px;width:fit-content;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.course-unenroll-btn{color:var(--text);cursor:pointer;text-align:right;background:0 0;border:none;padding:4px 8px;font-size:12px;text-decoration:underline}.catalog-course-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);align-items:center;gap:16px;padding:16px 18px;display:flex}.catalog-course-info{flex-direction:column;flex:1;gap:4px;display:flex}.catalog-course-depts{color:var(--text);margin-top:2px;font-size:12px}.catalog-course-action{flex-shrink:0}.catalog-enrolled-badge{color:#16a34a;font-size:13px;font-weight:600}.leader-dept-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.leader-logo-section{margin-top:16px}.admin-field-label{color:var(--text);margin-bottom:10px;font-size:13px;font-weight:600;display:block}.leader-logo-preview{flex-direction:column;align-items:flex-start;display:flex}.leader-logo-img{object-fit:contain;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);max-width:240px;max-height:120px;padding:12px}.leader-logo-upload{cursor:pointer;display:block}.leader-logo-placeholder{border:2px dashed var(--border);border-radius:var(--radius);width:240px;height:140px;color:var(--text);flex-direction:column;justify-content:center;align-items:center;gap:6px;font-size:14px;transition:border-color .2s,background .2s;display:flex}.leader-logo-upload:hover .leader-logo-placeholder{border-color:var(--accent);background:var(--surface)}.leader-members-list{flex-direction:column;gap:12px;margin-top:8px;display:flex}.leader-member-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 16px}.leader-member-header{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.leader-member-name{color:var(--text-h);font-size:15px;font-weight:600}.leader-member-courses{flex-direction:column;gap:6px;margin-top:10px;display:flex}.leader-enrollment-row{align-items:center;gap:8px;font-size:14px;display:flex}.leader-enrollment-title{color:var(--text-h);flex:1}.leader-assign-select{border:1.5px solid var(--border);background:var(--surface);color:var(--text-h);cursor:pointer;border-radius:8px;width:100%;margin-top:4px;padding:6px 10px;font-size:13px}.badge-dept-leader{color:#92400e;background:#eab30826;border-radius:99px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}@media (prefers-color-scheme:dark){.badge-dept-leader{color:#fde68a;background:#eab30833}}.dashboard-wrap{flex-direction:column;gap:20px;display:flex}.dashboard-scroll{border:1.5px solid var(--border);border-radius:var(--radius);overflow-x:auto}.dashboard-table{border-collapse:collapse;min-width:100%;font-size:14px}.dashboard-table th,.dashboard-table td{border-bottom:1px solid var(--border);text-align:center;white-space:nowrap;padding:12px 14px}.dashboard-table th{background:var(--surface);color:var(--text-h);font-size:13px;font-weight:600}.dashboard-table tr:last-child td{border-bottom:none}.dashboard-name-col{color:var(--text-h);background:inherit;min-width:150px;font-weight:600;position:sticky;left:0;text-align:left!important}.coach-name-btn{font-weight:600;font-size:inherit;color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;-webkit-text-decoration:underline #0000;text-decoration:underline #0000;transition:text-decoration-color .15s}.coach-name-btn:hover{-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.coach-info-grid{flex-direction:column;gap:10px;margin:16px 0;display:flex}.coach-info-row{justify-content:space-between;align-items:center;gap:12px;font-size:14px;display:flex}.coach-info-label{color:var(--text);opacity:.65;flex-shrink:0;font-weight:500}.coach-info-value{color:var(--text-h);text-align:right;font-weight:500}.dashboard-action-col{text-align:center;width:40px}.reset-coach-btn{color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:color .15s,background .15s}.reset-coach-btn:hover{color:#e09a25;background:#e09a251a}.reset-coach-btn:disabled{opacity:.4;cursor:default}.badge-clickable{cursor:pointer;transition:opacity .15s}.badge-clickable:hover{opacity:.65}.delete-coach-btn{color:var(--text-muted,#888);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:14px;transition:color .15s,background .15s}.delete-coach-btn:hover{color:#e05555;background:#e055551a}.delete-coach-btn:disabled{opacity:.4;cursor:default}.dashboard-ch-header{flex-direction:column;gap:2px;max-width:120px;display:flex}.dashboard-ch-unit{color:var(--text);text-overflow:ellipsis;text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:500;overflow:hidden}.dashboard-ch-title{text-overflow:ellipsis;font-size:12px;overflow:hidden}.badge{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:inline-flex}.badge-pass{color:#15803d;background:#dcfce7}.badge-fail{color:#dc2626;background:#fee2e2}.badge-none{color:var(--border);background:0 0;font-size:18px}.header-settings-btn{align-items:center;gap:6px;display:flex}.header-settings-name{font-size:14px;font-weight:500}.settings-form{flex-direction:column;gap:0;display:flex}.settings-section{border-bottom:1px solid var(--border);padding:24px 0}.settings-section:last-child{border-bottom:none}.settings-section-title{color:var(--text-h);letter-spacing:-.2px;margin:0 0 4px;font-size:15px;font-weight:700}.settings-hint{color:var(--text);margin:0;font-size:13px;line-height:1.5}.settings-actions{justify-content:flex-start;padding:20px 0 0;display:flex}.settings-success{color:#15803d;margin:0;font-size:13px;font-weight:500}:root[data-theme=dark] .settings-success{color:#4ade80}.settings-info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;display:flex}.settings-info-row:last-child{border-bottom:none}.settings-info-label{color:var(--text)}.settings-info-value{color:var(--text-h);font-weight:500}.settings-danger-title{color:#dc2626}.theme-options{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px;display:grid}.theme-option{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;transition:border-color .15s,background .15s,transform .15s;display:flex}.theme-option:hover{border-color:var(--accent-border);transform:translateY(-1px)}.theme-option-active{border-color:var(--accent);background:var(--accent-bg)}.theme-option-icon{font-size:24px;line-height:1}.theme-option-label{color:var(--text-h);font-size:14px;font-weight:600}.theme-option-desc{color:var(--text);text-align:center;font-size:11px}.notif-subscribe-row{border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:14px 16px;display:flex}.notif-subscribe-status{margin:0;font-size:14px;font-weight:500}.notif-group{margin-top:12px}.notif-group-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text);opacity:.5;margin:12px 0 6px;font-size:11px;font-weight:700}.notif-pref-row{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;display:flex}.notif-pref-label{flex:1;font-size:14px}.notif-pref-check{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.cm-badge-published{color:#16a34a;background:#22c55e22;border:1px solid #16a34a44}.cm-badge-draft{background:var(--border);color:var(--text);opacity:.6}.ping-message-input{box-sizing:border-box;border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);resize:vertical;border-radius:8px;margin:12px 0;padding:10px 12px;font-family:inherit;font-size:14px}.ping-message-input:focus{border-color:var(--accent);outline:none}@media (width<=480px){.app-main{padding:16px 12px 40px}.page-title{font-size:22px}.unit-card{gap:12px;padding:14px 12px}.unit-title{font-size:15px}.auth-card{border-radius:14px;padding:28px 20px}.quiz-choice{padding:13px 12px}.chapter-page{padding-bottom:32px}.cm-form-overlay{padding:16px}}
