:root{font-family:"Source Sans 3",Segoe UI,Arial,sans-serif;color:#111827;background:#eef3f9;line-height:1.25}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}button,input,select,textarea{font:inherit}.app-shell{height:100%;display:grid;grid-template-columns:300px 1fr;background:radial-gradient(circle at top left,#f8fbff,#eef3f9 48%,#e6edf6);position:relative;overflow:hidden}.revision-badge{position:fixed;top:.6rem;right:.7rem;z-index:200;background:#fde047;color:#111827;border:2px solid #ca8a04;border-radius:8px;padding:.18rem .45rem;font-size:.72rem;font-weight:700;letter-spacing:.02em}.sidebar{background:#fff;border-right:1px solid #dbe3ef;display:flex;flex-direction:column;min-width:0;min-height:0}.sidebar-header{padding:.95rem 1rem;border-bottom:1px solid #edf1f7}.teacher-line{display:inline-flex;align-items:center;gap:.5rem;width:100%}.logout-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:.75rem;padding:.2rem .4rem;border-radius:4px;line-height:1}.logout-btn:hover{background:#f1f5f9;color:#475569}.teacher-icon{width:1rem;height:1rem;color:#94a3b8;display:inline-flex}.teacher-icon svg{width:100%;height:100%;fill:currentColor}.label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.teacher-name{margin-top:.2rem;font-weight:700}.filters{padding:.75rem;display:grid;gap:.55rem;border-bottom:1px solid #edf1f7}.input{border:1px solid #cbd5e1;border-radius:8px;padding:.52rem .65rem;background:#fff}.student-list{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding:.45rem}.empty-hint{color:#6b7280;font-size:.85rem;padding:.65rem}.student-item{display:block;width:100%;border:1px solid transparent;border-radius:10px;text-align:left;padding:.5rem .65rem;margin-bottom:.4rem;background:#fff;cursor:pointer}.student-item:hover{background:#f8fafc;border-color:#dbe4f4}.student-item.selected{background:#e8f0ff;border-color:#bfd3ff}.student-entry{display:grid;grid-template-columns:2rem 1fr;gap:.55rem;align-items:center}.student-entry-body{min-width:0}.student-thumb{width:2rem;height:2rem;border-radius:999px;overflow:hidden;border:1px solid #cbd5e1;background:#e2e8f0;color:#334155;display:grid;place-items:center;font-size:.62rem;font-weight:700;letter-spacing:.02em}.student-thumb img{width:100%;height:100%;object-fit:cover;display:block}.student-main{font-size:.88rem;font-weight:700;color:#0f172a}.student-meta{margin-top:.2rem;font-size:.72rem;color:#64748b;display:flex;justify-content:space-between;gap:.5rem}.profile{flex:1;border-top:1px solid #edf1f7;padding:1.1rem .95rem;display:grid;gap:.62rem;align-content:start;justify-items:center;text-align:center;overflow:auto}.profile-avatar{width:3.4rem;height:3.4rem;border-radius:999px;overflow:hidden;display:grid;place-items:center;font-weight:700;letter-spacing:.08em;color:#1d4ed8;background:#dbeafe;border:2px solid #bfdbfe}.profile-avatar-stack{display:grid;justify-items:center;margin-bottom:.12rem}.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.profile-name{margin-top:.2rem;font-weight:700}.profile-sub{font-size:.8rem;color:#64748b}.sidebar-tech-footer{border-top:1px solid #edf1f7;background:#fff;padding:.38rem .7rem max(.32rem,env(safe-area-inset-bottom));display:grid;gap:.2rem}.profile-tech-row{display:inline-flex;align-items:center;justify-content:center;gap:.32rem;font-size:.66rem;line-height:1.2;color:#94a3b8}.sync-status-compact[data-sync-status=synced]{color:#16a34a}.sync-status-compact[data-sync-status=pending]{color:#b45309}.sync-status-compact[data-sync-status=failed]{color:#dc2626}.sync-status-compact[data-sync-status=local-only]{color:#64748b}.sync-retry-btn{border:1px solid #fca5a5;border-radius:999px;background:#fff1f2;color:#b91c1c;font-size:.72rem;font-weight:700;padding:.12rem .5rem;cursor:pointer}.sync-retry-btn:hover{border-color:#ef4444;background:#ffe4e6}.sync-retry-btn.compact{font-size:.64rem;padding:.08rem .4rem}.status-badge{width:fit-content;padding:.3rem .62rem;border-radius:999px;background:#fef3c7;color:#92400e;font-size:.72rem;font-weight:700}.status-badge.finalized{background:#dcfce7;color:#166534}.workspace{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.tab-bar{display:flex;gap:.45rem;padding:.65rem .95rem;overflow-x:auto;background:#fff;border-bottom:1px solid #dde6f3}.tab{border:3px solid color-mix(in oklab,var(--tab-accent) 60%,white);color:#334155;background:#fff;border-radius:999px;padding:.4rem .9rem;font-size:.84rem;font-weight:700;cursor:pointer;white-space:nowrap}.tab:hover{background:var(--tab-soft)}.tab.active{color:#fff;background:var(--tab-accent);border-color:var(--tab-accent)}.content-grid{flex:1;min-height:0;display:grid;grid-template-columns:minmax(320px,.38fr) 1fr;overflow:hidden}.comment-panel{display:flex;flex-direction:column;min-height:0;overflow:auto;padding:.75rem .55rem .9rem .8rem;gap:.75rem}.comment-body{flex:1;min-height:0;overflow:visible;padding:0}.comment-frame{width:100%;border:2px solid #d5e0ef;border-radius:10px;transition:border-color .12s ease,box-shadow .12s ease,background-color .12s ease}.comment-frame.editing{border-color:var(--comment-soft);background:#fff}.comment-frame.saved{border-color:var(--comment-accent);background:var(--comment-surface)}.comment-frame.editing:focus-within{border-color:var(--comment-accent);box-shadow:0 0 0 1px color-mix(in oklab,var(--comment-accent) 35%,white)}.matrix-panel{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable;padding:.75rem .45rem .9rem;min-height:0}.matrix-layout{display:flex;gap:0;align-items:stretch}.matrix-rail{order:2;flex:0 0 2.2rem;position:relative}.matrix-rail-track{position:absolute;top:0;bottom:0;left:1.2rem;width:.5rem;border-radius:.5rem;background:linear-gradient(180deg,var(--matrix-rail-accent) 0%,var(--matrix-rail-soft) 50%,var(--matrix-rail-accent) 100%);box-shadow:inset 0 0 0 1px color-mix(in oklab,var(--matrix-rail-accent) 26%,white);opacity:.95}.matrix-rail.with-actions .matrix-rail-track{top:2.55rem}.rail-actions{position:absolute;top:.08rem;left:1.45rem;transform:translate(-50%);display:grid;gap:.12rem;z-index:1}.rail-action-btn{width:1.5rem;height:1.2rem;border:none;border-radius:.45rem;background:transparent;color:color-mix(in oklab,var(--matrix-rail-accent) 72%,#0f172a);padding:0;display:grid;place-items:center;line-height:0;cursor:pointer}.rail-action-btn:hover{background:var(--matrix-rail-surface)}.rail-action-btn svg{width:.95rem;height:.95rem;display:block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.matrix-sections{order:1;display:flex;flex-direction:column;gap:.75rem;flex:1 1 auto;min-width:0}.comment-header-card{margin:0}.section-card{background:#fff;border:1px solid #dbe4f3;border-radius:9px;overflow:hidden}.section-card.collapsed .section-header{border-bottom-color:transparent}.section-header{padding:.65rem .85rem;border-bottom:1px solid #edf2f9;display:flex;justify-content:space-between;align-items:center;gap:.8rem;background:#f8fbff}.section-header h2{margin:0;font-size:.95rem}.section-title-group{min-width:0;display:grid;gap:.2rem}.section-expander-btn{min-width:0;display:inline-flex;align-items:center;gap:.35rem;border:none;background:transparent;color:#0f172a;font-size:.95rem;font-weight:700;padding:0;cursor:pointer;text-align:left}.section-expander-btn:hover{color:#1e40af}.section-expander-label{cursor:default}.section-expander-label:hover{color:#0f172a}.section-chevron{color:#64748b;transition:transform .12s ease}.section-chevron.expanded{transform:rotate(90deg)}.section-meta{font-size:.72rem;color:#64748b;letter-spacing:.02em}.section-meta-placeholder{visibility:hidden}.toggle-group{display:flex;gap:.3rem;background:#e6edf8;padding:.2rem;border-radius:8px}.toggle-btn{border:2px solid transparent;background:transparent;border-radius:6px;padding:.3rem .62rem;font-size:.74rem;font-weight:700;color:#475569;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem;transition:all .12s ease}.toggle-icon{font-size:.8rem;line-height:1}.edit-btn{color:#6b7280;border-color:transparent}.edit-btn[data-state=active]{color:#dc2626;border-color:#ef4444;background:#fff}.save-btn[data-state=pending]{color:#6b7280;border-color:#cbd5e1;background:#f8fafc}.save-btn[data-state=pending]:hover{color:#334155;border-color:#64748b;background:#eef2f7}.save-btn[data-state=saved]{color:#fff;border-color:#059669;background:#059669;box-shadow:0 1px 1px #05966933}.save-btn[data-state=saved]:hover{border-color:#047857;background:#047857}.comment-text{display:block;width:100%;min-height:320px;margin:0;border:none;border-radius:8px;padding:.75rem;background:transparent;resize:vertical;color:#0f172a}.comment-text:disabled{background:transparent;color:#334155;cursor:default}.rows{padding:.25rem .7rem .7rem}.rows.locked{pointer-events:none}.row{display:grid;grid-template-columns:1fr minmax(360px,.8fr);gap:.7rem;align-items:center;padding:.68rem 0;border-bottom:1px solid #eff3f9}.row:last-child{border-bottom:none}.row-text{color:#0f172a;font-size:.91rem}.scale-grid{display:grid;gap:.4rem;grid-template-columns:repeat(4,minmax(0,1fr))}.scale-btn{border:1px solid #d0dae7;background:#fff;color:#64748b;border-radius:9px;min-height:2.5rem;padding:.35rem;font-size:.69rem;font-weight:700;text-align:center;cursor:pointer}.scale-btn[data-state=draft-selected]{background:var(--soft);border-color:var(--soft-border);color:#0f172a}.scale-btn[data-state=saved-selected]{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 1px #0f172a29}.scale-btn[data-state=saved-empty]{opacity:.38;border-style:dashed}.scale-btn:disabled{cursor:default}.modal-overlay{position:fixed;inset:0;background:#0f172a59;display:grid;place-items:center;padding:1rem;z-index:20}.modal-card{width:min(760px,100%);background:#fff;border-radius:14px;overflow:hidden;border:1px solid #d8e1ef;position:relative}.unsaved-modal-card{width:min(620px,100%)}.unsaved-modal-text{margin:0;color:#334155}.unsaved-modal-footer{gap:.85rem}.unsaved-choice-group{display:flex;gap:.45rem;flex-wrap:wrap}.unsaved-discard-group{margin-left:auto;padding-left:.9rem;border-left:1px solid #d8e1ef}.unsaved-choice-btn{display:inline-flex;align-items:center;gap:.38rem}.trash-icon{width:.92rem;height:.92rem;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;border-bottom:1px solid #e8eef7;background:#f8fbff}.modal-header h3{margin:0}.modal-header p{margin:.25rem 0 0;font-size:.83rem;color:#64748b}.icon-btn{border:none;background:#eff4fb;border-radius:8px;width:2rem;height:2rem;cursor:pointer}.modal-body{display:grid;gap:.8rem;padding:1rem}label{display:grid;gap:.35rem;font-size:.84rem;font-weight:700}label textarea,label select,label input{border:1px solid #cfd9e8;border-radius:8px;padding:.56rem .62rem;font-weight:400}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.modal-footer{border-top:1px solid #e8eef7;padding:.8rem 1rem;display:flex;justify-content:space-between;align-items:center}.actions{display:flex;gap:.45rem}button.primary,button.secondary,button.ghost,button.danger{border-radius:8px;border:1px solid transparent;padding:.47rem .78rem;font-weight:700;cursor:pointer}button.primary{background:#1d4ed8;color:#fff}button.secondary{background:#fff;color:#0f172a;border-color:#cbd5e1}button.icon-action-btn{display:inline-flex;align-items:center;gap:.4rem}button.icon-action-btn svg{width:1rem;height:1rem;fill:currentColor}button.secondary.danger{color:#b91c1c}button.ghost{background:transparent;color:#334155}button.danger{background:#dc2626;color:#fff}.confirm-overlay{position:absolute;inset:0;background:#ffffffeb;display:grid;place-items:center}.confirm-card{width:min(340px,90%);border:1px solid #fecaca;border-radius:12px;background:#fff;padding:1rem}.confirm-card h4{margin:0}.confirm-card p{margin:.55rem 0 .85rem;color:#64748b;font-size:.84rem}@media(max-width:1200px){.content-grid{grid-template-columns:1fr}.comment-panel{max-height:360px}}@media(max-width:960px){.app-shell{grid-template-columns:1fr}.sidebar{max-height:48vh;border-right:none;border-bottom:1px solid #dbe3ef}.row{grid-template-columns:1fr}.scale-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-row{grid-template-columns:1fr}.section-header{flex-wrap:wrap}.matrix-layout{display:block}.matrix-rail{display:none}.unsaved-modal-footer{align-items:stretch;flex-direction:column}.unsaved-discard-group{margin-left:0;padding-left:0;padding-top:.45rem;border-left:none;border-top:1px solid #d8e1ef}}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f8fafc}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:360px;box-shadow:0 4px 24px #00000012;display:flex;flex-direction:column;gap:1.25rem}.login-title{font-size:1.75rem;font-weight:800;color:#1e293b;margin:0;text-align:center}.login-subtitle{font-size:.85rem;color:#64748b;margin:-.75rem 0 0;text-align:center}.login-field{display:flex;flex-direction:column;gap:.4rem}.login-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.07em;color:#64748b;font-weight:600}.login-select{padding:.6rem .75rem;border:1px solid #cbd5e1;border-radius:7px;font-size:.95rem;color:#1e293b;background:#fff;cursor:pointer}.login-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f126}.login-btn{padding:.7rem 1.25rem;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.login-btn:hover{background:#4f46e5}.conflict-banner-stack{position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);z-index:500;display:flex;flex-direction:column;gap:.6rem;width:min(560px,calc(100vw - 2rem));pointer-events:none}.conflict-banner{display:flex;align-items:flex-start;gap:.75rem;background:#fef2f2;border:1.5px solid #fca5a5;border-radius:10px;padding:.75rem 1rem;box-shadow:0 4px 16px #0000001f;pointer-events:all}.conflict-banner-body{flex:1;font-size:.88rem;line-height:1.5;color:#7f1d1d}.conflict-banner-body strong{color:#991b1b}.conflict-banner-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:#b91c1c;font-size:.85rem;padding:.1rem .25rem;line-height:1;border-radius:4px;opacity:.7;transition:opacity .15s}.conflict-banner-close:hover{opacity:1}
