:root{font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;color:#24302f;background:#f4f6f4;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button,.button{border:0;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 12px;text-decoration:none}button:disabled{cursor:not-allowed;opacity:.55}a{color:#276a9f}.app-shell{min-height:100vh}.topbar{display:flex;justify-content:space-between;gap:24px;padding:24px 32px;background:#fff;border-bottom:1px solid #dfe6e2;position:sticky;top:0;z-index:5}.topbar h1,.panel h2,.compact-form h3{margin:0;letter-spacing:0}.topbar h1{font-size:22px}.topbar p,.muted{color:#65716e;margin:6px 0 0}.nav-tabs{display:flex;align-items:center;gap:8px}.nav-tabs button,.filters button{background:#edf2ef;color:#43504d}.nav-tabs button.active,.filters button.active{background:#24302f;color:#fff}.workspace{padding:24px 32px 40px}.workspace.admin-layout{padding-top:18px}.workspace.narrow{max-width:560px;margin:0 auto}.student-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:20px}.admin-layout{display:grid;grid-template-columns:292px minmax(0,1fr);gap:18px;align-items:start}.panel{background:#fff;border:1px solid #dfe6e2;border-radius:8px;padding:18px;box-shadow:0 10px 24px #172c260f}.section-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2{font-size:18px}.details,.receipt{display:grid;gap:12px;margin:16px 0 0}.details div,.receipt div{display:grid;grid-template-columns:90px 1fr;gap:12px}dt{color:#687572}dd{margin:0;font-weight:600}.notice{margin-top:16px;padding:12px;border-radius:6px;background:#fff8e8;border:1px solid #ead59c}.form-grid,.compact-form,.score-form{display:grid;gap:12px}.captcha-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}.captcha-question{display:inline-flex;align-items:center;min-height:38px;border:1px solid #dfe6e2;border-radius:6px;padding:8px 10px;background:#f8faf9;color:#24302f;font-weight:700;letter-spacing:0}label{display:grid;gap:6px;color:#52605d;font-size:14px}input,select,textarea{width:100%;min-height:38px;border:1px solid #ccd8d3;border-radius:6px;padding:8px 10px;background:#fff;color:#24302f}textarea{min-height:82px;resize:vertical}.primary{background:#287c6f;color:#fff}.ghost{background:#edf2ef;color:#2f3d3a}.icon-label{white-space:nowrap}.status{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;font-size:13px}.status.ok{background:#e7f5ef;color:#287c6f}.status.danger{background:#fbebeb;color:#b54646}.message{margin:10px 0 0}.ok-text{color:#287c6f}.error-text{color:#b54646}.upload-box{border:1px dashed #aebeb8;border-radius:8px;padding:18px;display:grid;gap:12px;background:#f8faf9}.success-panel{border-color:#a8d5c8}.grading-sidebar{position:sticky;top:104px;max-height:calc(100vh - 120px);overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:18px;background:#fff;border:1px solid #dfe6e2;border-radius:8px;box-shadow:0 10px 24px #172c260f}.sidebar-header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid #edf2ef}.sidebar-header select{flex:1;min-height:32px}.sidebar-filters{display:flex;flex-wrap:wrap;gap:4px;padding:4px 0}.sidebar-filters button{padding:4px 8px;font-size:12px;min-height:28px}.sidebar-toggle{width:100%;justify-content:space-between;font-size:13px;padding:6px 10px;background:#edf2ef;color:#43504d;border-radius:6px}.sidebar-toggle:hover{background:#dfe6e2}.student-list{display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1;min-height:0;padding:4px 0}.student-row{display:grid;grid-template-columns:1fr auto;gap:2px 8px;align-items:center;padding:9px 10px;border-radius:6px;cursor:pointer;font-size:13px;border-left:3px solid transparent;min-height:54px}.student-row:hover{background:#eef6f3}.student-row.selected{background:#d4ede6;border-left-color:#287c6f;font-weight:600}.student-row.dirty .student-name:after{content:" *";color:#b54646}.student-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-meta{font-size:11px;color:#6b7774;grid-column:1 / -1}.student-score{font-size:12px;font-weight:600;text-align:right}.student-status-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;vertical-align:middle}.student-status-dot.graded{background:#287c6f}.student-status-dot.submitted{background:#d8a23a}.student-status-dot.unsubmitted{background:#ccd8d3}.sidebar-footer{border-top:1px solid #edf2ef;padding-top:8px;display:flex;flex-wrap:wrap;gap:6px}.sidebar-footer .compact-form{border-top:none;padding-top:8px;margin-top:4px;width:100%}.compact-form{border-top:1px solid #edf2ef;padding-top:16px;margin-top:16px}.actions,.filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filters{padding:12px 0 16px;border-top:1px solid #edf2ef}.filters select{width:150px}.table-wrap{overflow:auto;border:1px solid #dfe6e2;border-radius:8px}table{width:100%;border-collapse:collapse;min-width:760px}th,td{text-align:left;padding:12px;border-bottom:1px solid #edf2ef;vertical-align:middle}th{color:#60706c;background:#f8faf9;font-size:13px}td span{display:block;color:#6b7774;font-size:13px;margin-top:3px}tbody tr{cursor:pointer}tbody tr:hover,tbody tr.selected{background:#eef6f3}.empty{color:#78837f;text-align:center}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat-grid div{border:1px solid #e3ebe7;border-radius:6px;padding:10px;background:#f8faf9}.stat-grid strong{display:block;font-size:22px}.stat-grid span{color:#697672;font-size:13px}.chart-row{margin:8px 0}.rubric-list{display:grid;gap:12px;margin-bottom:16px}.rubric-row{display:grid;grid-template-columns:minmax(180px,1fr) 120px minmax(240px,1.4fr);gap:12px}.rubric-editor{padding:4px 0 0}.rubric-editor-actions{display:flex;justify-content:flex-end;gap:8px}.modal-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:24px;background:#1f2b2a52}.modal-panel{width:min(860px,100%);max-height:min(720px,calc(100vh - 48px));overflow:auto;background:#fff;border:1px solid #dfe6e2;border-radius:8px;padding:20px;box-shadow:0 24px 72px #172c2638}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid #edf2ef}.modal-header h2{margin:0;font-size:20px}.video-preview{width:100%;aspect-ratio:16 / 9;background:#15201d;border-radius:8px;margin-bottom:14px}.video-controls-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-top:8px}.video-size-controls{display:flex;gap:4px;align-items:center}.video-size-controls span{font-size:12px;color:#6b7774;margin-right:4px}.video-size-controls button{padding:3px 10px;font-size:12px;min-height:26px;background:#edf2ef;color:#43504d;border-radius:4px}.video-size-controls button.active{background:#287c6f;color:#fff}.grading-main{min-height:60vh}.grading-main--active{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:16px;align-items:start}.grading-main--active.video-mode-small{grid-template-columns:minmax(0,.82fr) 410px}.grading-main--active.video-mode-large{grid-template-columns:1fr}.grading-main--active .video-section,.grading-main--active .scoring-section{margin-bottom:0}.grading-main .video-section{margin-bottom:20px}.video-small~.scoring-section,.video-medium~.scoring-section{margin-top:0}.empty-grading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;color:#6b7774;text-align:center;gap:8px}.empty-grading .shortcuts-hint{font-size:13px;color:#999;margin-top:8px}.video-section{margin-bottom:20px;background:#fff;border:1px solid #dfe6e2;border-radius:8px;padding:16px;box-shadow:0 10px 24px #172c260f}.video-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:12px}.video-header h2{margin:0;font-size:18px}.video-header .student-number{color:#65716e;font-weight:400;font-size:14px;margin-left:8px}.speed-controls{display:flex;gap:4px;margin-top:8px;align-items:center}.speed-controls span{font-size:12px;color:#6b7774;margin-right:4px}.speed-controls button{padding:3px 10px;font-size:12px;min-height:26px;background:#edf2ef;color:#43504d;border-radius:4px}.speed-controls button.active{background:#287c6f;color:#fff}.scoring-section{background:#fff;border:1px solid #dfe6e2;border-radius:8px;padding:18px;box-shadow:0 10px 24px #172c260f}.grading-main--active .scoring-section{position:sticky;top:104px}.scoring-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}.scoring-header h3{margin:0;font-size:16px}.scoring-header .spacer{flex:1}.rubric-scores{display:grid;gap:8px;margin-bottom:14px}.score-slider-row{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"label value" "track action";gap:8px 10px;align-items:center;padding:10px;border:1px solid #edf2ef;border-radius:6px;background:#fbfcfb}.slider-label{grid-area:label;display:flex;flex-direction:column;min-width:0}.slider-label .name{font-size:14px;font-weight:600;line-height:1.35;white-space:normal;overflow-wrap:anywhere}.slider-track-wrapper{grid-area:track;position:relative;height:12px;background:#edf2ef;border-radius:999px;overflow:hidden}.slider-fill{position:absolute;top:0;left:0;height:100%;border-radius:10px;transition:width .1s ease,background-color .2s ease}.fill-max-btn{grid-area:action;justify-self:end;font-size:11px;padding:2px 6px;min-height:24px}.score-slider{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2;margin:0;min-height:auto;border:none}.slider-value{grid-area:value;display:flex;align-items:center;justify-content:flex-end;gap:4px}.slider-value input{width:50px;min-height:32px;text-align:center;padding:4px}.rubric-desc{font-size:11px;color:#6b7774;line-height:1.35;overflow-wrap:anywhere}.max-label{color:#6b7774;font-size:13px;text-align:center}.running-total{font-size:22px;font-weight:700;padding:12px;border:1px solid #dfe6e2;border-radius:6px;background:#f8faf9;margin-bottom:12px;display:flex;align-items:baseline;gap:4px}.running-total .total-num{font-size:28px}.running-total .max-num{font-size:16px;color:#6b7774;font-weight:400}.running-total.over-max .total-num{color:#b54646}.auto-advance-toggle{display:flex;align-items:center;gap:4px;font-size:13px;cursor:pointer;color:#52605d;white-space:nowrap}.auto-advance-toggle input{width:auto;min-height:auto}.scoring-actions{display:flex;align-items:center;gap:12px;margin-top:14px}.save-message{color:#287c6f;font-size:13px}.nav-buttons{display:flex;gap:4px;align-items:center}.nav-buttons button{padding:4px 8px;font-size:12px;min-height:28px}@media(max-width:1180px){.admin-layout{grid-template-columns:248px minmax(0,1fr)}.grading-main--active,.grading-main--active.video-mode-small{grid-template-columns:1fr}.grading-main--active .scoring-section{position:static}}@media(max-width:760px){.topbar,.student-grid,.admin-layout{display:grid;grid-template-columns:1fr}.topbar,.workspace{padding:18px}.grading-sidebar{position:static;max-height:none}.score-slider-row{grid-template-columns:1fr;grid-template-areas:"label" "value" "track" "action"}.slider-value{justify-content:flex-start}.fill-max-btn{justify-self:start}.modal-backdrop{padding:12px;place-items:stretch}.modal-panel{max-height:calc(100vh - 24px);padding:16px}.modal-header{align-items:center}.rubric-row{grid-template-columns:1fr}.details div,.receipt div{grid-template-columns:1fr;gap:4px}}.roster-workspace{max-width:1280px;margin:0 auto}.roster-panel{padding:20px}.roster-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:18px}.roster-title{margin-bottom:4px}.roster-title h2{display:flex;align-items:center;gap:8px}.roster-stats{display:grid;grid-template-columns:repeat(3,116px);gap:8px}.roster-stats div{border:1px solid #e3ebe7;border-radius:6px;padding:10px 12px;background:#f8faf9}.roster-stats strong{display:block;font-size:24px;line-height:1}.roster-stats span{display:block;margin-top:6px;color:#697672;font-size:12px}.roster-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.roster-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.roster-import-form{display:flex;align-items:center;gap:8px}.roster-import-form input[type=file]{width:auto;min-height:auto;padding:4px;font-size:13px}.roster-search-field{width:min(320px,100%);display:flex;grid-template-columns:unset;align-items:center;gap:8px;min-height:40px;border:1px solid #ccd8d3;border-radius:6px;padding:0 10px;background:#fff;color:#697672}.roster-search{min-width:0;border:0;padding:0;min-height:34px}.roster-search:focus{outline:none}.roster-format-info{background:#f8faf9;border:1px solid #dfe6e2;border-radius:6px;padding:12px;margin-bottom:16px;font-size:13px;line-height:1.6}.roster-format-info code{background:#edf2ef;padding:2px 6px;border-radius:4px;font-size:12px}.roster-table-wrap{overflow-x:auto;border:1px solid #dfe6e2;border-radius:8px;background:#fff}.roster-table-wrap tbody tr{cursor:default}.roster-table-wrap td,.roster-table-wrap th{padding:14px 12px}.roster-count{margin-top:12px;font-size:13px;color:#6b7774;text-align:right}.danger-btn{color:#b54646}.danger-btn:hover{background:#fbebeb}
