:root{--bg:#f8fafc;--card:#fff;--line:#e2e8f0;--line-2:#f1f5f9;--text:#0f172a;--muted:#64748b;--primary:#1c9dd8;--primary-d:#1683b8;--primary-soft:#e8f6fc;--primary-line:#bce4f4;--ink:#14365a;--danger-bg:#fee2e2;--danger-fg:#991b1b;--ok:#059669;--ng:#dc2626;--warn-bg:#fef3c7;--warn-fg:#92400e;--info-bg:#dbeafe;--info-fg:#1e40af;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--focus-ring:0 0 0 3px #1c9dd833}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-family:-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,Meiryo,system-ui,sans-serif;font-size:14px;line-height:1.55}.sheet-tabbar{z-index:60;-webkit-backdrop-filter:blur(18px);background:#f8fafcf5;border-top:1px solid #cbd5e1;align-items:center;gap:8px;min-height:52px;padding:7px 12px 8px;display:flex;position:fixed;inset:auto 0 0;box-shadow:0 -8px 22px #0f172a14}.sheet-brand{color:#0f172a;white-space:nowrap;border-right:1px solid #e2e8f0;flex:none;align-items:center;gap:8px;min-height:36px;padding:0 9px 0 2px;font-size:12px;font-weight:900;text-decoration:none;display:inline-flex}.sheet-brand:hover{text-decoration:none}.sheet-mark{background:var(--primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;font-size:15px;font-weight:900;display:inline-flex}.sheet-wordmark{color:var(--ink,#14365a);letter-spacing:.01em;font-size:14px;font-weight:900}.brand-mark{color:#fff;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:800;display:inline-flex;box-shadow:0 8px 20px #2563eb40}.sheet-tabs{scrollbar-width:thin;flex:auto;align-items:flex-end;gap:4px;min-width:0;display:flex;overflow-x:auto}.sheet-tabs a{color:#334155;white-space:nowrap;background:#e2e8f0;border:1px solid #cbd5e1;border-bottom-color:#94a3b8;border-radius:8px 8px 0 0;flex:none;justify-content:center;align-items:center;gap:6px;min-width:92px;height:36px;padding:0 14px;font-size:12px;font-weight:900;text-decoration:none;display:inline-flex;box-shadow:inset 0 -1px #0f172a0f}.sheet-tabs a:hover{color:#0f172a;background:#f1f5f9;text-decoration:none}.sheet-tabs a.active{color:#0f172a;background:#fff;border-color:#94a3b8 #94a3b8 #fff;height:41px;transform:translateY(1px)}.sheet-status{color:#64748b;flex:none;align-items:center;gap:6px;font-size:11px;font-weight:900;display:inline-flex}.db-badge{border:1px solid var(--line);color:#475569;background:#fff;border-radius:8px;align-items:center;padding:4px 9px;font-size:11px;font-weight:800;text-decoration:none;display:inline-flex}.db-badge:hover{background:#f8fafc;text-decoration:none}.iplus-main{max-width:1200px;margin:0 auto;padding:22px 24px 40px}.iplus-main.wide{max-width:none;margin:0;padding:22px 24px 48px}.iplus-main.narrow{max-width:640px;padding:20px 16px 48px}.skel{background:linear-gradient(90deg,#eef2f7 25%,#f6f8fb 37%,#eef2f7 63%) 0 0/400% 100%;border-radius:8px;animation:1.2s ease-in-out infinite skel}@keyframes skel{0%{background-position:100% 0}to{background-position:0 0}}.card{background:var(--card);box-shadow:var(--shadow);border:1px solid var(--line);border-radius:16px;margin:0 0 16px;padding:20px 22px}.card h2{flex-wrap:wrap;align-items:center;gap:10px;margin:0 0 14px;font-size:15px;font-weight:600;display:flex}.page-head h1{margin:0;font-size:20px;font-weight:700}.page-head p{color:var(--muted);margin:4px 0 0;font-size:13px}.hint{color:var(--muted);font-size:12px}.btn-primary,.btn-secondary,.btn-danger{cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex;box-shadow:0 1px 2px #0000000d}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-d);box-shadow:var(--shadow);text-decoration:none;transform:translateY(-1px)}.btn-primary[disabled]{opacity:.5;cursor:not-allowed}.btn-primary.big{padding:13px 30px;font-size:15px;font-weight:700}.btn-secondary{color:var(--text);border-color:var(--line);background:#fff}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db;text-decoration:none}.btn-secondary[disabled]{opacity:.4;cursor:not-allowed}.btn-danger{background:var(--danger-bg);color:var(--danger-fg);padding:6px 12px;font-size:12px}.btn-danger:hover{background:#fecaca;text-decoration:none}.roster .record-table{border:1px solid #c7ced6}.roster th,.roster td{vertical-align:middle;border-bottom:1px solid #dce1e7;border-right:1px solid #dce1e7;height:42px;padding:0}.roster tr>th:last-child,.roster tr>td:last-child{border-right:0}.roster thead th{height:auto;padding:8px 10px}.roster input,.roster select{width:100%;height:42px;font:inherit;color:var(--text);appearance:none;background:#fff;border:0;border-radius:0;margin:0;padding:0 10px;font-size:14px}.roster select{cursor:pointer;padding-right:22px}.roster input:hover,.roster select:hover{background:#f5fafd}.roster input:focus,.roster select:focus{box-shadow:inset 0 0 0 2px var(--primary);background:#fff;outline:none}.roster input::placeholder{color:#9aa6b2}.roster input.code{letter-spacing:.04em;font-weight:700}.roster .cell-pad{padding:0 10px;display:inline-block}.roster .input-with-btn{background:#fff;align-items:center;gap:6px;padding-right:6px;display:flex}.roster .input-with-btn input{flex:auto}.roster .row-actions{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:6px;padding:0 8px;display:inline-flex}.roster .gbtn{white-space:nowrap;height:28px;box-shadow:none;border-radius:0;flex:none;padding:0 10px;font-size:12px;font-weight:700}.roster .gbtn:hover{box-shadow:none;transform:none}.roster .add-btn{width:100%;height:42px;box-shadow:none;border-radius:0}.roster .add-btn:hover{box-shadow:none;transform:none}.dashboard{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px;display:grid}.dashboard .tile{background:var(--card);border:1px solid var(--line);text-align:center;color:var(--text);box-shadow:var(--shadow);border-radius:16px;padding:18px 16px;text-decoration:none;transition:transform 80ms,box-shadow 80ms;display:block}.dashboard .tile:hover{box-shadow:var(--shadow-lg);text-decoration:none;transform:translateY(-1px)}.dashboard .tile-num{font-variant-numeric:tabular-nums;font-size:28px;font-weight:700}.dashboard .tile-label{color:var(--muted);margin-top:4px;font-size:12px}.record-table{border-collapse:collapse;background:#fff;border:1px solid #c7ced6;width:100%;font-size:13px}.record-table th,.record-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #dce1e7;border-right:1px solid #dce1e7;padding:9px 12px}.record-table tr>th:last-child,.record-table tr>td:last-child{border-right:0}.record-table thead th{color:#475569;letter-spacing:.02em;background:#eef3f7;font-size:12px;font-weight:700}.record-table .num{font-variant-numeric:tabular-nums;text-align:center;color:var(--muted)}.record-table .right{text-align:right}.record-table .empty,.empty{text-align:center;color:var(--muted);padding:28px 0;font-size:13px}.badge{background:var(--info-bg);color:var(--info-fg);border-radius:999px;align-items:center;padding:2px 9px;font-size:11px;font-weight:700;display:inline-flex}.r-OK{color:var(--ok);font-weight:700}.r-NG{color:var(--ng);font-weight:700}.muted{color:var(--muted);font-size:12px}.grid-scroll{border:1px solid var(--line);background:#fff;border-radius:12px;overflow-x:auto}.entry-grid{border-collapse:collapse;min-width:100%;font-size:13px}.entry-grid th,.entry-grid td{border:1px solid var(--line);vertical-align:middle;background:#fff;padding:8px 10px}.entry-grid thead th{z-index:2;text-align:left;background:#f9fafb;border-bottom:2px solid #d1d5db;position:sticky;top:0}.entry-grid .row-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;z-index:1;text-align:right;background:#f9fafb;width:92px;font-size:11px;font-weight:600;position:sticky;left:0}.entry-grid thead .row-label{z-index:3;background:#f3f4f6}.entry-grid .col{text-align:left;min-width:200px;max-width:280px}.entry-grid .col-head{flex-direction:column;gap:2px;display:flex}.entry-grid .col-name{font-size:13px;font-weight:700}.entry-grid .col-meta{color:var(--muted);font-size:11px}.entry-grid tr.row-range td{background:#fafbff}.entry-grid tr.row-score td{background:#fffefb}.entry-grid tr.row-comment td{background:#fff}.entry-grid tr.row-next td{background:#f0fdf4}.entry-grid tr.row-next .next-label{color:#047857;font-weight:700}.entry-grid tr.row-op td{background:#fafafa}.entry-grid input[type=text],.entry-grid input[type=number]{border:1px solid var(--line);background:#fff;border-radius:4px;width:100%;padding:6px 8px;font-family:inherit;font-size:13px}.entry-grid input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #2563eb26}.entry-grid .score-pair{align-items:center;gap:4px;display:inline-flex}.entry-grid .score-pair input{width:64px}.radio-group{border:1px solid var(--line);background:#fff;border-radius:6px;display:inline-flex;overflow:hidden}.radio-group .radio{cursor:pointer;-webkit-user-select:none;user-select:none;border-right:1px solid var(--line);background:#fff;justify-content:center;align-items:center;min-width:40px;padding:6px 12px;font-size:13px;font-weight:700;transition:background 80ms;display:inline-flex}.radio-group .radio:last-child{border-right:0}.radio-group .radio.ok{color:var(--ok)}.radio-group .radio.ng{color:var(--ng)}.radio-group .radio.blank{color:#9ca3af}.radio-group .radio:hover{background:#f9fafb}.radio-group .radio.is-on{box-shadow:inset 0 0 0 2px var(--primary);background:#eff6ff}.radio-group .radio.ok.is-on{box-shadow:inset 0 0 0 2px var(--ok);background:#d1fae5}.radio-group .radio.ng.is-on{box-shadow:inset 0 0 0 2px var(--ng);background:#fee2e2}.mastery-toolbar{border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px;padding:12px 16px;display:flex}.toolbar-left,.toolbar-right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toolbar-field{align-items:center;gap:8px;font-size:13px;font-weight:600;display:inline-flex}.toolbar-field input,.toolbar-field select{border:1px solid var(--line);background:var(--card);height:36px;color:var(--text);font:inherit;border-radius:8px;padding:0 12px}.toolbar-field input:focus,.toolbar-field select:focus{border-color:var(--primary);box-shadow:var(--focus-ring);outline:none}.form-grid{gap:12px;display:grid}.form-row{gap:4px;display:grid}.form-row label{color:var(--muted);font-size:12px;font-weight:600}.form-row input,.form-row select,.form-row textarea{border:1px solid var(--line);background:var(--card);color:var(--text);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--primary);box-shadow:var(--focus-ring);outline:none}.page-head-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:14px;display:flex}.metric-row{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.metric-chip{background:var(--primary-soft);color:var(--primary-d);border:1px solid var(--primary-line);border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.assign-wrap{border:1px solid var(--line);background:#fff;border-radius:12px;max-height:72vh;overflow:auto}.assign-grid{border-collapse:separate;border-spacing:0;background:#fff;font-size:13px}.assign-grid th{color:#556;white-space:nowrap;z-index:3;text-align:left;background:#f1f5f9;border-bottom:1px solid #cbd5e1;border-right:1px solid #e2e8f0;padding:8px 10px;font-size:11px;font-weight:700;position:sticky;top:0}.assign-grid td{vertical-align:top;border-bottom:1px solid #eef0f3;border-right:1px solid #eef0f3;padding:0}.assign-grid td.ag-name,.assign-grid th.ag-name{width:132px;min-width:132px;max-width:132px}.assign-grid td.ag-name{z-index:2;background:#fafbfd;border-right:2px solid #cbd5e1;padding:8px 10px;font-weight:700;position:sticky;left:0}.assign-grid th.ag-name{z-index:4;left:0}.assign-grid td.ag-name .small{color:#94a3b8;font-size:11px;font-weight:400;display:block}.assign-grid td.ag-cell,.assign-grid td.ag-addcell{width:200px;min-width:200px;max-width:200px}.assign-grid td.ag-cell.assigned{border-left:4px solid var(--c,#9aa0a6)}.assign-grid .ag-mat{color:var(--ink,#222);word-break:break-word;padding:8px 10px 3px;font-weight:700;line-height:1.3}.assign-grid .ag-range{color:#047857;word-break:break-word;padding:0 10px 6px;font-size:12px;line-height:1.3}.assign-grid .ag-range .ag-arrow{color:#aaa;margin:0 3px}.assign-grid .ag-actions{border-top:1px dashed #0000000f;flex-wrap:wrap;align-items:center;gap:6px;padding:4px 8px 7px;display:flex}.assign-grid .ag-status{color:#64748b;font-size:11px}.assign-grid .ag-open{color:var(--primary);font-size:11px;text-decoration:none}.assign-grid .ag-x{color:#d93025;cursor:pointer;background:0 0;border:0;margin-left:auto;padding:0 2px;font-size:15px;line-height:1}.assign-grid .ag-x:hover{color:#b91c1c}.assign-grid td.ag-addcell{background:#ecfdf3;padding:8px 9px}.assign-grid td.ag-addcell.empty-add{background:#f8fafc}.assign-grid .ag-add-form{flex-direction:column;gap:5px;display:flex}.assign-grid .ag-add-form select,.assign-grid .ag-add-form input{width:100%;font:inherit;background:#fff;border:1px solid #c9d2de;border-radius:6px;padding:5px 7px;font-size:12px}.assign-grid .ag-add-btn{color:#15803d;font:inherit;cursor:pointer;background:#fff;border:1px solid #86efac;border-radius:6px;padding:5px 8px;font-size:12px;font-weight:700}.assign-grid .ag-add-btn:hover{background:#dcfce7}.assign-grid .ag-startpick{background:#f0fdf4;border:1px solid #c9d2de;border-radius:6px;align-items:center;gap:4px;padding:3px 4px;display:flex}.assign-grid .ag-startpick-cap{color:#15803d;padding:0 2px;font-size:10px;font-weight:800}.assign-grid .ag-startpick-btn{color:#15803d;cursor:pointer;background:#fff;border:1px solid #86efac;border-radius:5px;flex:none;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:inline-flex}.assign-grid .ag-startpick-btn:hover:not(:disabled){background:#dcfce7}.assign-grid .ag-startpick-btn:disabled{opacity:.35;cursor:not-allowed}.assign-grid .ag-startpick-val{color:#14532d;text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-size:11px;font-weight:700;overflow:hidden}.assign-grid .ag-startpick-pos{color:#64748b;flex:none;font-size:10px}.assign-grid tr:hover td.ag-cell,.assign-grid tr:hover td.ag-name{filter:brightness(.98)}.assign-grid td.empty-cell{background:#f4f5f7}.action-menu{position:relative}.action-menu>summary{cursor:pointer;list-style:none}.action-menu>summary::-webkit-details-marker{display:none}.action-menu-body{border:1px solid var(--line);width:320px;max-width:86vw;box-shadow:var(--shadow-lg);z-index:50;background:#fff;border-radius:12px;margin-top:8px;padding:16px;position:absolute;right:0}.grade-workspace{grid-template-columns:minmax(0,1fr) 430px;align-items:start;gap:16px;display:grid}.grade-canvas{border:1px solid var(--line);box-shadow:var(--shadow-lg);background:#0f172a;border-radius:18px;overflow:hidden}.grade-canvas-head{color:#cbd5e1;letter-spacing:.02em;background:#0b1220;border-bottom:1px solid #ffffff14;padding:11px 16px;font-size:12px;font-weight:800}.grade-canvas-body{max-height:calc(100vh - 230px);padding:16px;overflow:auto}.answer-large{background:#fff;border-radius:12px;display:block;overflow:hidden;box-shadow:0 6px 18px #00000040}.answer-large img{width:100%;height:auto;display:block}.answer-thumb{border:1px solid var(--line);background:#fff;border-radius:10px;display:block;overflow:hidden}.answer-thumb img{object-fit:cover;width:100%;height:120px;display:block}.grade-side{position:sticky;top:12px}.grade-panel{gap:16px;display:grid}.grade-score-row{align-items:flex-end;gap:10px;display:flex}.grade-field{color:var(--muted);gap:4px;font-size:12px;font-weight:700;display:grid}.grade-field input{text-align:center;border:1px solid var(--line);font-variant-numeric:tabular-nums;background:#fff;border-radius:12px;width:112px;height:50px;font-size:22px}.grade-field input:focus{border-color:var(--primary);box-shadow:var(--focus-ring);outline:none}.grade-slash{color:#cbd5e1;padding-bottom:10px;font-size:22px}.grade-block{gap:7px;display:grid}.grade-label{color:var(--muted);letter-spacing:.02em;align-items:center;gap:8px;font-size:12px;font-weight:800;display:flex}.grade-panel textarea,.grade-panel input[type=text]{border:1px solid var(--line);width:100%;font:inherit;background:#fff;border-radius:12px;padding:11px 13px;font-size:14px}.grade-panel textarea:focus,.grade-panel input[type=text]:focus{border-color:var(--primary);box-shadow:var(--focus-ring);outline:none}.radio-group--lg{width:100%}.radio-group--lg .radio{flex:1;padding:14px 18px;font-size:16px}.tag-wrap{flex-wrap:wrap;gap:8px;display:flex}.tag-chip{border:1px solid var(--line);font:inherit;cursor:pointer;background:#fff;border-radius:999px;align-items:center;gap:6px;padding:7px 13px;font-size:13px;transition:all .1s;display:inline-flex}.tag-chip.is-on{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-d);font-weight:700}.tag-dot{border-radius:999px;width:10px;height:10px;display:inline-block}.grade-actions{gap:8px;margin-top:2px;display:grid}.grade-actions .btn-primary,.grade-actions .btn-secondary,.grade-actions .btn-danger{width:100%}.notice-list{gap:10px;margin-bottom:16px;display:grid}.notice{border:1px solid var(--primary-line);box-shadow:var(--shadow);color:var(--text);background:linear-gradient(#f5f9ff,#fff);border-radius:16px;align-items:flex-start;gap:12px;padding:13px 15px;text-decoration:none;display:flex}.notice:hover{box-shadow:var(--shadow-lg);text-decoration:none;transform:translateY(-1px)}.notice .notice-ico{background:var(--primary);color:#fff;border-radius:10px;flex:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:inline-flex}.notice .notice-title{font-weight:700}.notice .notice-body{color:var(--muted);margin-top:2px;font-size:13px}.page-head h1{letter-spacing:.01em}.card{border-radius:18px}.card h2{letter-spacing:.01em}.brand-mark{letter-spacing:0;font-weight:900}.sr-only{clip:rect(0 0 0 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.auth{background:#edf0f3;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.auth-box{text-align:center;background:#fff;border:1px solid #e2e6ea;border-radius:0;width:100%;max-width:392px;padding:30px 32px 26px;box-shadow:0 1px 2px #0f172a0d}.auth-logo-wrap{margin:2px 0 14px}.auth-logo{width:256px;max-width:86%;height:auto;display:inline-block}.auth-h1{letter-spacing:.04em;color:#0f172a;margin:0 0 22px;font-size:22px;font-weight:800}.auth-form{text-align:left;gap:10px;display:grid}.auth-form input{color:#0f172a;background:#fff;border:1px solid #cdd4db;border-radius:0;width:100%;height:52px;padding:0 16px;font-size:16px;transition:border-color .12s,box-shadow .12s}.auth-form input::placeholder{color:#9aa7b8}.auth-form input:focus{border-color:var(--primary);box-shadow:var(--focus-ring);outline:none}.auth-error{background:var(--danger-bg);color:var(--danger-fg);margin:2px 0 0;padding:9px 12px;font-size:13px;font-weight:700}.auth-submit{cursor:pointer;background:var(--primary);color:#fff;width:100%;height:52px;font:inherit;border:0;border-radius:0;margin-top:8px;font-size:16px;font-weight:800;transition:background .12s,transform 60ms}.auth-submit:hover:not(:disabled){background:var(--primary-d)}.auth-submit:active:not(:disabled){transform:translateY(1px)}.auth-submit:disabled{opacity:.6;cursor:default}.setup-info{border:1px solid var(--line);background:#f8fafc;border-radius:10px;margin-bottom:14px;padding:12px 14px}.setup-info-row{gap:10px;font-size:13px;line-height:1.9;display:flex}.setup-info-label{color:var(--muted);flex:0 0 76px;font-weight:700}.setup-info-val{color:var(--ink);word-break:break-all;font-weight:700}.auth-help{color:var(--muted);margin:18px 0 0;font-size:12.5px;line-height:1.7}.auth-demo{border-top:1px solid #eef1f4;margin-top:18px;padding-top:16px}.auth-demo-label{color:var(--muted);margin-bottom:8px;font-size:12px;font-weight:700}.auth-demo-btns{gap:8px;display:grid}.auth-demo-btns .btn-secondary{width:100%}.auth-foot{color:#9aa3ad;margin-top:20px;font-size:12px}.auth-foot-sep{color:#c8ced5;margin:0 8px}.cred-form{gap:12px;max-width:460px;display:grid}.cred-inline{align-items:center;gap:8px;display:flex}.cred-inline input{flex:auto}.cred-result{border:1px solid var(--primary-line);background:linear-gradient(#f5f9ff,#fff);border-radius:14px;margin-top:4px;padding:12px 14px}.cred-result-title{margin-bottom:8px;font-size:13px;font-weight:800}.cred-kv{align-items:baseline;gap:10px;padding:2px 0;display:flex}.cred-kv span{width:90px;color:var(--muted);font-size:12px;font-weight:700}.cred-kv b{font-variant-numeric:tabular-nums;letter-spacing:.04em;font-size:18px}.cred-issued{color:#047857;font-size:13px;font-weight:700}.iplus-main.narrow{font-size:15px}.iplus-main.narrow .page-head h1{font-size:22px}.iplus-main.narrow .btn-primary{border-radius:12px;padding:12px 18px;font-size:15px}.iplus-main.narrow .card{border-radius:18px}.iplus-main.narrow .notice{padding:15px 16px}@media (max-width:1024px){.grade-workspace{grid-template-columns:1fr}.grade-side{position:static}.grade-canvas-body{max-height:60vh}}@media (max-width:900px){.grading-cols{grid-template-columns:1fr!important}}@media (max-width:640px){.iplus-main{padding:16px 12px 40px}.sheet-brand strong{display:none}}.appbar{border-bottom:2px solid var(--primary);background:#fff}.appbar-inner{align-items:stretch;gap:6px;height:58px;padding:0 20px;display:flex}.brand{border-right:1px solid var(--line);align-items:center;gap:10px;margin-right:6px;padding-right:16px;text-decoration:none;display:inline-flex}.brand:hover{text-decoration:none}.brand-logo{width:auto;height:34px;display:block}.brand-tile{background:var(--primary);color:#fff;justify-content:center;align-items:center;width:32px;height:32px;font-size:17px;font-weight:900;display:inline-flex}.brand-name{color:var(--ink,#14365a);letter-spacing:.01em;white-space:nowrap;font-size:15px;font-weight:900}.topnav{scrollbar-width:thin;align-items:stretch;gap:0;display:flex;overflow-x:auto}.topnav a{color:#5b6b7c;white-space:nowrap;border-bottom:3px solid #0000;align-items:center;padding:0 14px;font-size:13.5px;font-weight:700;text-decoration:none;display:inline-flex}.topnav a:hover{color:var(--ink,#14365a);background:#f5f7f9;text-decoration:none}.topnav a.active{color:var(--primary);border-bottom-color:var(--primary)}.topnav a{gap:6px}.topnav-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:800;line-height:1;display:inline-flex}.appbar-right{align-items:center;gap:10px;margin-left:auto;padding-left:12px;display:flex}.division-switch{border:1px solid var(--line);background:#f1f5f9;border-radius:999px;padding:2px;display:inline-flex}.division-switch button{cursor:pointer;font:inherit;color:#64748b;white-space:nowrap;background:0 0;border:0;border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:800;line-height:1}.division-switch button:hover:not(.active):not(:disabled){color:#334155}.division-switch button.active{background:var(--primary);color:#fff;box-shadow:0 1px 2px #0000001f}.division-switch button:disabled{cursor:default}.appbar-user{color:var(--ink,#14365a);white-space:nowrap;align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.appbar-role{color:#5b6b7c;border:1px solid var(--line);background:#eef2f6;padding:2px 7px;font-size:11px;font-weight:800}.appbar .db-badge,.appbar-right .db-badge{border-radius:0}@media (max-width:720px){.appbar-inner{flex-wrap:wrap;gap:8px;height:auto;padding:8px 14px}.brand{border-right:0;padding-right:0}.appbar-right{order:3;width:100%}.topnav{order:4;width:100%}.topnav a{height:42px}}.card,.btn-primary,.btn-secondary,.btn-danger,.badge,.metric-chip,.dashboard .tile,.grid-scroll,.assign-wrap,.grade-canvas,.grade-canvas-head,.action-menu-body,.notice,.notice .notice-ico,.cred-result,.login-demo .btn-secondary,.radio-group,.radio-group .radio,.tag-chip,.form-row input,.form-row select,.form-row textarea,.toolbar-field input,.toolbar-field select,.entry-grid input[type=text],.entry-grid input[type=number],.grade-field input,.grade-panel textarea,.grade-panel input[type=text],.cred-form input,.cred-inline input,.assign-grid .ag-add-form select,.assign-grid .ag-add-form input,.assign-grid .ag-add-btn{border-radius:0!important}.card{box-shadow:none;border:1px solid #dde2e7}.dashboard .tile{box-shadow:none;border:1px solid #dde2e7;transition:background 80ms}.dashboard .tile:hover{box-shadow:none;background:#f6f8fa;transform:none}.btn-primary{box-shadow:none}.btn-primary:hover{box-shadow:none;transform:none}.grid-scroll,.assign-wrap,.grade-canvas{box-shadow:none}.notice{box-shadow:none;border:1px solid var(--primary-line);background:#fff}.notice:hover{box-shadow:none;background:#f7fbfe;transform:none}.mastery-toolbar{box-shadow:none;border-radius:0}.action-menu-body{border:1px solid #d4dae0;box-shadow:0 6px 16px -8px #0f172a59}.dashboard .tile-num{color:var(--ink,#14365a)}:root{--brand-head:#eaf6fc;--brand-head-ink:#15486b}.page-head h1,.card h2{color:var(--ink,#14365a)}.section-title{color:var(--brand-head-ink)}.record-table thead th{background:var(--brand-head);color:var(--brand-head-ink);border-bottom:1px solid var(--primary-line)}.record-table tbody tr:hover{background:#f4fafd}.entry-grid thead th{background:var(--brand-head);border-bottom:2px solid var(--primary-line);color:var(--brand-head-ink)}.entry-grid .row-label{background:var(--brand-head);color:var(--brand-head-ink)}.entry-grid thead .row-label{background:#ddeef8}.assign-grid th{background:var(--brand-head);color:var(--brand-head-ink);border-bottom:1px solid var(--primary-line)}.assign-grid td.ag-name{background:#f4fafd}.assign-grid th.ag-name{background:#ddeef8}.badge{background:var(--primary-soft);color:var(--primary-d)}.record-table tbody tr.add-row,.add-row{background:#eef8fd}.section-title{color:#5b6b7c;letter-spacing:.06em;align-items:center;gap:10px;margin:22px 0 10px;font-size:13px;font-weight:800;display:flex}.section-title:after{content:"";background:var(--line);flex:1;height:1px}.section-title:first-of-type{margin-top:6px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;display:grid}.stat{border:1px solid #dde2e7;border-left:4px solid var(--accent,#94a3b8);background:#fff;flex-direction:column;gap:4px;padding:16px 18px;text-decoration:none;transition:background 80ms;display:flex}.stat:hover{background:#f6f8fa;text-decoration:none}.stat-top{justify-content:space-between;align-items:baseline;display:flex}.stat-num{color:var(--ink,#14365a);font-variant-numeric:tabular-nums;font-size:30px;font-weight:800;line-height:1}.stat-num.is-zero{color:#b6c0cb}.stat-go{color:var(--accent,#94a3b8);font-size:12px;font-weight:700}.stat-label{color:#5b6b7c;font-size:12.5px;font-weight:700}.stat-icon{justify-content:center;align-items:center;display:inline-flex}.dash-hero{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;padding:18px 22px;display:flex}.dash-hero-greet{letter-spacing:.01em;font-size:20px;font-weight:900}.dash-hero-sub{color:#ffffffd9;margin-top:4px;font-size:13px;font-weight:600}.dash-hero-r{align-items:center;gap:10px;display:flex}.dash-hero-metric{align-items:baseline;gap:2px;display:inline-flex}.dash-hero-num{font-variant-numeric:tabular-nums;font-size:38px;font-weight:900;line-height:1}.dash-hero-unit{font-size:15px;font-weight:800}.dash-hero-mlabel{color:#ffffffd9;margin-right:6px;font-size:12px;font-weight:800}.dash-hero-cta{color:var(--primary-d);white-space:nowrap;background:#fff;padding:11px 18px;font-size:14px;font-weight:800;text-decoration:none}.dash-hero-cta:hover{background:#eaf6fc;text-decoration:none}.dash-empty{align-items:center;gap:14px;padding:18px 6px;display:flex}.dash-empty-ico{color:#22b07d;background:#e7f7f0;flex:none;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;font-weight:900;display:inline-flex}.dash-empty-title{color:var(--ink,#14365a);font-weight:800}.dash-empty-sub{color:#5b6b7c;margin-top:2px;font-size:13px}@media (max-width:560px){.dash-hero{flex-direction:column;align-items:flex-start}.dash-hero-r{justify-content:space-between;width:100%}}.learn-hero{color:#fff;background:radial-gradient(150px 150px at 80% 58%,#ffffff47,#fff0 70%),linear-gradient(118deg,#1b3fa0 0%,#1aa3e6 50%,#15c39a 100%);justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding:24px 26px;display:flex;position:relative;overflow:hidden}.learn-hero:after{content:"";pointer-events:none;background:radial-gradient(3px 3px at 18% 26%,#fffc,#0000),radial-gradient(2px 2px at 30% 72%,#fff9,#0000),radial-gradient(2px 2px at 52% 20%,#ffffff8c,#0000),radial-gradient(2.5px 2.5px at 64% 80%,#fff9,#0000),radial-gradient(220px 120px at -5% 110%,#ffffff1f,#0000);position:absolute;inset:0}.learn-hero-body{z-index:1;min-width:0;position:relative}.learn-hero-mascot{z-index:1;background:radial-gradient(closest-side at 50% 92%,#fff6,#fff0 76%);flex:none;justify-content:center;align-self:flex-end;align-items:flex-end;padding:0 14px;line-height:0;display:inline-flex;position:relative}.learn-mascot{width:auto;height:122px;display:block}@media (max-width:520px){.learn-mascot{height:84px}.learn-hero{padding:18px}}.learn-hero-tag{letter-spacing:.22em;background:#ffffff29;border:1px solid #ffffff4d;margin-bottom:12px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-block}.learn-hero-title{letter-spacing:.01em;font-size:27px;font-weight:900;line-height:1.28}.learn-hero-sub{color:#fffffff0;max-width:560px;margin-top:8px;font-size:14px;line-height:1.7}.learn-stats{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.lstat{text-align:center;border:1px solid #0f172a0f;padding:20px 12px}.lstat-num{font-variant-numeric:tabular-nums;font-size:34px;font-weight:900;line-height:1}.lstat-label{color:#5b6b7c;margin-top:8px;font-size:13px;font-weight:800}.lsection{color:var(--ink,#14365a);align-items:center;gap:8px;margin:0 0 12px;font-size:17px;font-weight:900;display:flex}.lsection-n{background:var(--primary);color:#fff;justify-content:center;align-items:center;min-width:24px;height:24px;padding:0 7px;font-size:12px;font-weight:800;display:inline-flex}.lcard-empty{color:#5b6b7c;text-align:center;background:#fff;border:1px dashed #cdd9e4;padding:24px 16px;font-size:14px}.home-tabs{border-bottom:2px solid #e2e8f0;gap:8px;margin-bottom:16px;display:flex}.home-tab{cursor:pointer;color:#6b7a8a;background:0 0;border:0;border-bottom:3px solid #0000;align-items:center;gap:8px;margin-bottom:-2px;padding:10px 16px;font-size:15px;font-weight:800;display:inline-flex}.home-tab.on{color:var(--ink);border-bottom-color:var(--primary)}.home-tab-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 7px;font-size:12px;font-weight:800;display:inline-flex}.home-tab-badge.alt{background:#1f9d55}.task{color:var(--text);background:#fff;border:1px solid #dde2e7;align-items:center;gap:14px;padding:16px 18px;text-decoration:none;transition:background 80ms,border-color 80ms;display:flex}.task:hover{background:#f9fcfe;border-color:#c7d3de;text-decoration:none}.task-ico{color:#fff;flex:none;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:900;display:inline-flex}.task-main{flex:1;min-width:0}.task-title{color:var(--ink,#14365a);flex-wrap:wrap;align-items:center;gap:8px;font-size:16px;font-weight:800;display:flex}.task-meta{color:#5b6b7c;margin-top:4px;font-size:13px}.task-cta{color:#fff;white-space:nowrap;flex:none;padding:13px 22px;font-size:15px;font-weight:800}.task-cta:hover{filter:brightness(.95)}@media (max-width:520px){.task{flex-wrap:wrap}.task-cta{text-align:center;width:100%;margin-top:4px}}.hero-chips{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.hero-chip{color:#fff;background:#ffffff2e;border:1px solid #ffffff52;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:800;display:inline-flex}.hero-chip svg{flex:none}.mission{border:1px solid #dde2e7;border-left:6px solid var(--accent,var(--primary));color:var(--text);background:#fff;align-items:center;gap:14px;margin-bottom:20px;padding:18px;text-decoration:none;transition:background 80ms,border-color 80ms;display:flex}.mission:hover{background:#f9fcfe;border-color:#c7d3de;text-decoration:none}.mission-ico{color:#fff;flex:none;justify-content:center;align-items:center;width:54px;height:54px;font-size:24px;font-weight:900;display:inline-flex}.mission-mascot{flex:none;line-height:0}.mission-mascot img{width:auto;height:70px;display:block}.mission-body{flex:1;min-width:0}.mission-label{letter-spacing:.1em;color:var(--accent,var(--primary));font-size:12px;font-weight:900}.mission-title{color:var(--ink,#14365a);margin-top:3px;font-size:19px;font-weight:900}.mission-meta{color:#5b6b7c;margin-top:3px;font-size:13px}.mission-cta{color:#fff;white-space:nowrap;flex:none;padding:15px 24px;font-size:16px;font-weight:800}.mission-cta:hover{filter:brightness(.95)}.mission-done{background:#eafaf3;border:1px solid #bfe9d6;border-left:6px solid #22b07d}.mission-done-emoji{font-size:34px}.meter{background:#fff;border:1px solid #dde2e7;margin-bottom:24px;padding:16px 18px}.meter-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.meter-title{color:var(--ink,#14365a);font-size:15px;font-weight:900}.meter-level{color:#d39a2a;align-items:center;gap:6px;font-size:13px;font-weight:800;display:inline-flex}.meter-bar{background:#eef2f6;height:14px;overflow:hidden}.meter-fill{background:linear-gradient(90deg,#1aa3e6,#18c39a);height:100%;transition:width .4s}.meter-foot{color:#5b6b7c;margin-top:8px;font-size:13px;font-weight:700}.meter-stats{text-align:center;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;display:grid}.ms{border:1px solid #e6ebf0;padding:12px 6px}.ms .ms-ico{justify-content:center;align-items:center;margin-bottom:6px;line-height:1;display:flex}.ms-star .ms-ico{color:#e2741a}.ms-done .ms-ico{color:#0f9e74}.ms-week .ms-ico{color:#1583c4}.ms b{font-variant-numeric:tabular-nums;font-size:24px;font-weight:900;line-height:1;display:block}.ms span:last-child{color:#5b6b7c;font-size:11px;font-weight:800}.ms-star{background:#fff7e6;border-color:#ffe2ad}.ms-star b{color:#e2741a}.ms-done{background:#e9f8f1;border-color:#bfe9d6}.ms-done b{color:#0f9e74}.ms-week{background:#e8f5fd;border-color:#bce4f4}.ms-week b{color:#1583c4}.meter-fill{background:linear-gradient(90deg,#1aa3e6,#18c39a,#46c35f)}@media (max-width:520px){.mission{flex-wrap:wrap}.mission-cta{text-align:center;width:100%}}.card.selfgrade{background:#f4fbf5;border:2px solid #bfe3c8}.card.selfgrade h2{color:#1f7a3d}.selfgrade-sol{background:#fff;border:1px solid #d4e9d9;border-radius:12px;margin-top:12px;padding:12px 14px}.selfgrade-label{color:#1f7a3d;margin-bottom:8px;font-size:13px;font-weight:800}.sg-split{grid-template-columns:1fr 1fr;gap:12px;margin-top:10px;display:grid}.sg-tabs{display:none}.sg-pane{background:#fff;border:1px solid #d4e9d9;border-radius:12px;flex-direction:column;height:70vh;min-height:360px;display:flex;overflow:hidden}.sg-pane-head{color:#1f7a3d;background:#f4fbf5;border-bottom:1px solid #e0efe4;flex-wrap:wrap;align-items:center;gap:10px;padding:9px 12px;font-size:14px;font-weight:800;display:flex}.sg-pane-body{background:#eef2f6;flex:1;position:relative;overflow:hidden}.sg-sol-links{align-items:center;gap:6px;margin-left:auto;display:inline-flex}.sg-pdf-pages{justify-items:center;gap:10px;display:grid}.sg-pdf-page{background:#fff;border-radius:4px;max-width:100%;height:auto;box-shadow:0 2px 10px #0f284624}.sg-pdf-note{text-align:center;color:#64748b;padding:20px;font-weight:700}.zpane{position:absolute;inset:0}.zpane-vp{touch-action:none;-webkit-user-select:none;user-select:none;cursor:grab;position:absolute;inset:0;overflow:hidden}.zpane-surf{transform-origin:0 0;box-sizing:border-box;will-change:transform;width:100%;padding:8px}.zpane-surf img{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.zpane-ctrls{z-index:3;background:#ffffffeb;border:1px solid #cbd5e1;border-radius:9px;gap:3px;padding:3px;display:inline-flex;position:absolute;top:8px;right:8px;box-shadow:0 1px 4px #0f284629}.zpane-ctrls button{color:#334155;cursor:pointer;background:0 0;border:none;border-radius:6px;min-width:32px;height:30px;padding:0 8px;font-size:12px;font-weight:800}.zpane-ctrls button:hover{background:#eef2f7}@media (max-width:899px){.sg-split{grid-template-columns:1fr}.sg-tabs{gap:6px;display:flex}.sg-tab{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #cdd6df;border-radius:10px;flex:1;min-height:44px;font-size:14px;font-weight:800}.sg-tab.on{border-color:var(--primary);color:var(--primary);background:#eaf6fc}.sg-split[data-active=answer] .sg-pane-solution,.sg-split[data-active=solution] .sg-pane-answer{display:none}.sg-pane{height:76vh}}.submit-modes{gap:8px;display:flex}.submit-mode{color:#475569;cursor:pointer;background:#fff;border:2px solid #dbe3ea;border-radius:12px;flex:1;padding:11px 12px;font-size:14px;font-weight:800}.submit-mode.on{border-color:var(--primary);color:var(--ink);background:#eaf6fc}.annotator{gap:12px;display:grid}.annot-stage,.annot-surface,.annot-canvas-wrap,.annot-page,.annot-ink,.annot-active{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.annot-toolbar{background:#fff;border:1px solid #e5eaf0;border-radius:14px;flex-wrap:wrap;align-items:center;gap:8px;padding:8px;display:flex;box-shadow:0 1px 3px #0f28460f}.annot-tools,.annot-colors,.annot-widths,.annot-zoom,.annot-edit{background:#eef2f7;border-radius:11px;align-items:center;gap:4px;padding:4px;display:inline-flex}.annot-btn{color:#475569;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-width:40px;min-height:40px;padding:0 12px;font-size:13px;font-weight:700;transition:background .12s,box-shadow .12s;display:inline-flex}.annot-btn:hover{background:#fff9}.annot-btn.on{color:var(--primary);background:#fff;border-color:#dbe4ee;box-shadow:0 1px 2px #0f284624}.annot-btn[disabled]{opacity:.4;cursor:not-allowed}.annot-btn.annot-danger{color:#dc2626}.annot-btn.annot-danger:hover{background:#fef2f2}.annot-swatch{cursor:pointer;border:2px solid #fff;border-radius:50%;width:28px;height:28px;transition:transform .12s,box-shadow .12s;box-shadow:0 0 0 1px #cbd5e1}.annot-swatch:hover{transform:scale(1.06)}.annot-swatch.on{box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--primary);transform:scale(1.06)}.annot-penonly{color:#64748b;white-space:nowrap;cursor:default;background:0 0;border-radius:8px;align-items:center;gap:5px;min-height:40px;padding:0 12px;font-size:13px;font-weight:700;display:inline-flex}.annot-stage{touch-action:none;overscroll-behavior:contain;background:#eef2f6;border:1px solid #e2e8f0;border-radius:12px;height:68vh;position:relative;overflow:hidden}.annot-loading{color:#64748b;z-index:2;place-items:center;font-weight:700;display:grid;position:absolute;inset:0}.annot-surface{transform-origin:0 0;will-change:transform;touch-action:none;position:absolute;top:0;left:0}.annot-canvas-wrap{background:#fff;line-height:0;display:inline-block;position:relative;box-shadow:0 2px 12px #0f28461f}.annot-page{background:#fff;display:block}.annot-ink{touch-action:none;cursor:crosshair;position:absolute;top:0;left:0}.annot-active{touch-action:none;pointer-events:none;position:absolute;top:0;left:0}.annot-zoom-val{text-align:center;color:#334155;min-width:48px;font-size:12px;font-weight:800}.annot-pager{color:#475569;justify-content:center;align-items:center;gap:12px;font-weight:700;display:flex}.annot-submit{align-items:center;display:flex}.annot-top-submit{align-items:center;margin-left:auto;display:inline-flex}.annot-top-submit .btn-primary{min-height:40px;padding:0 20px;font-size:15px}.annot-confirm{z-index:300;background:#0f1e3280;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.annot-confirm-box{text-align:center;background:#fff;border-radius:16px;width:min(420px,100%);padding:22px 20px;box-shadow:0 20px 60px #0f284659}.annot-confirm-title{color:var(--ink);font-size:19px;font-weight:900}.annot-confirm-body{color:#5b6b7c;margin:10px 0 18px;font-size:14px;line-height:1.6}.annot-confirm-actions{justify-content:center;gap:10px;display:flex}.annot-confirm-actions .annot-btn{min-height:44px;padding:0 20px}.annot-confirm-actions .btn-primary{min-height:44px;padding:0 24px;font-size:15px}.photo-drop{color:var(--ink);cursor:pointer;background:#f3fafe;border:2.5px dashed #b9d8ea;border-radius:16px;flex-direction:column;align-items:center;gap:6px;width:100%;padding:28px 16px;display:flex}.photo-drop:hover{border-color:var(--primary);background:#eaf6fc}.photo-drop-ico{font-size:34px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;display:grid}.photo-thumb{aspect-ratio:1;background:#fff;border:1px solid #e2e8f0;border-radius:12px;position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%}.photo-del{color:#fff;cursor:pointer;background:#0f172ab8;border:0;border-radius:50%;width:24px;height:24px;font-size:16px;line-height:1;position:absolute;top:4px;right:4px}.photo-add{aspect-ratio:1;color:var(--primary);cursor:pointer;background:#f3fafe;border:2px dashed #b9d8ea;border-radius:12px;place-items:center;font-weight:800;display:grid}.write-screen{z-index:200;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;background:#eef2f6;flex-direction:column;display:flex;position:fixed;inset:0}.write-bar{background:#fff;border-bottom:1px solid #dbe3ea;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.write-back{color:#334155;white-space:nowrap;background:#fff;border:1.5px solid #cdd6df;border-radius:10px;align-items:center;min-height:38px;padding:0 14px;font-weight:800;text-decoration:none;display:inline-flex}.write-title{color:var(--ink);text-align:center;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:8px;font-weight:900;display:flex}.write-range{color:#64748b;font-size:12px;font-weight:700}.write-body{flex:1;padding:8px;overflow:auto}.write-body .annot-stage{background:#e6ecf2;height:calc(100vh - 150px);min-height:420px}.write-body .annotator{gap:8px}.write-body .annot-toolbar{z-index:5;position:sticky;top:0}.write-body .annot-submit .btn-primary{width:100%;min-height:52px;font-size:17px}.grade-tiles{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.grade-tile{background:#fff;border:1px solid #dde2e7;border-radius:14px;flex-direction:column;gap:2px;padding:14px 16px;display:flex}.grade-tile-label{color:#64748b;font-size:12px;font-weight:700}.grade-tile-value{color:var(--ink);font-size:26px;font-weight:900;line-height:1.1}.grade-tile-sub{color:#94a3b8;font-size:11px}.grade-tile.tone-ok .grade-tile-value{color:#0e9f6e}.grade-tile.tone-info .grade-tile-value{color:var(--primary)}.grade-tile.tone-star .grade-tile-value{color:#d97706}.grade-tile.tone-fire .grade-tile-value{color:#e0497b}.grade-cols{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (max-width:760px){.grade-cols{grid-template-columns:1fr}}.subj-list{gap:12px;display:grid}.subj-row{grid-template-columns:1fr auto;grid-template-areas:"head rate""bar rate";align-items:center;gap:2px 10px;display:grid}.subj-head{flex-wrap:wrap;grid-area:head;justify-content:space-between;gap:8px;display:flex}.subj-name{color:var(--ink);font-weight:800}.subj-meta{color:#64748b;font-size:12px}.subj-bar{background:#eef2f6;border-radius:999px;grid-area:bar;height:10px;overflow:hidden}.subj-bar-fill{background:linear-gradient(90deg, var(--primary), #34b3e6);border-radius:999px;height:100%;display:block}.subj-rate{color:var(--ink);text-align:right;grid-area:rate;min-width:44px;font-weight:900}.grade-spark{width:100%;height:90px;display:block}.grade-spark-line{fill:none;stroke:var(--primary);stroke-width:2.5px;stroke-linejoin:round;stroke-linecap:round}.grade-spark-area{fill:#1c9dd81a;stroke:none}.grade-spark-dot{fill:#fff;stroke:var(--primary);stroke-width:2px}.grade-spark-guide{stroke:#e2e8f0;stroke-width:1px;stroke-dasharray:3 3}.stu-switch{align-items:center;gap:8px;display:inline-flex}.stu-switch-label{color:#64748b;font-size:12px;font-weight:800}.stu-switch select{height:38px;font:inherit;color:var(--ink);cursor:pointer;background:#fff;border:1.5px solid #cdd6df;border-radius:10px;padding:0 12px;font-weight:700}.gsheet .score-cell{align-items:center;gap:4px;padding:0 6px;display:flex}.gsheet .score-cell input{text-align:center;flex:1;min-width:0;padding:0 4px}.gsheet .judge{gap:6px;padding:0 8px;display:inline-flex}.gsheet .judge-btn{cursor:pointer;color:#475569;white-space:nowrap;background:#fff;border:1.5px solid #cdd6df;border-radius:0;height:30px;padding:0 12px;font-size:13px;font-weight:800}.gsheet .judge-btn.ok.on{color:#0e7a55;background:#e6f7ef;border-color:#0e9f6e}.gsheet .judge-btn.ng.on{color:#b21437;background:#fdecef;border-color:#e11d48}.gsheet tr.j-ok>td{background:#f3fbf7}.gsheet tr.j-ng>td{background:#fdf4f6}.done-badge{border-radius:999px;padding:3px 10px;font-size:12px;font-weight:800;display:inline-block}.done-badge.ok{color:#0e7a55;background:#e6f7ef}.done-badge.done{color:#6d28d9;background:#ede9fe}.done-badge.ng{color:#b21437;background:#fdecef}.gstudent{background:#fff;border:1px solid #d7dee5;border-radius:14px;margin-bottom:16px;padding:16px 16px 14px}.gstudent-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.gstudent-name{color:var(--ink);font-size:18px;font-weight:900}.gstudent-grade{color:#64748b;margin-left:8px;font-size:13px;font-weight:700}.gstudent-count{color:#fff;background:var(--primary);border-radius:999px;margin-left:12px;padding:2px 9px;font-size:12px;font-weight:800}.gstudent{border-left:5px solid #16a34a}.gstudent.is-ok{border-color:#9ad9bd #9ad9bd #9ad9bd #16a34a}.gstudent.is-ng{border-color:#f0a6b6 #f0a6b6 #f0a6b6 #16a34a}.status-chip{vertical-align:middle;border-radius:999px;align-items:center;gap:4px;margin-left:10px;padding:3px 11px;font-size:12px;font-weight:900;line-height:1;display:inline-flex}.status-chip.ok{color:#0e7a55;background:#e6f7ef;border:1px solid #9ad9bd}.status-chip.wait{color:#92400e;background:#fef3c7;border:1px solid #f3d98b}.status-chip.done{color:#1567a0;background:#e8f4fb;border:1px solid #b6ddf1}.gstudent-combined{scroll-snap-type:x proximity;gap:8px;padding:4px 2px 12px;display:flex;overflow-x:auto}.gstudent-combined img{object-fit:contain;scroll-snap-align:start;background:#fff;border:1px solid #dde2e7;border-radius:6px;width:auto;max-width:240px;height:150px}.gstudent-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;display:flex}.next-assign{background:#f1f9f4;border:1px solid #c7e7d3;border-radius:10px;margin-top:12px;padding:12px 14px}.next-assign-title{color:#0e7a55;margin-bottom:8px;font-size:12px;font-weight:800}.next-row{flex-wrap:wrap;align-items:center;gap:10px;padding:5px 0;display:flex}.next-row+.next-row{border-top:1px dashed #cfe6d8}.next-mat{color:var(--ink);min-width:120px;font-weight:700}.next-arrow{color:#64748b;font-size:12px}.next-fixed{color:#6d28d9}.next-val{min-width:90px;color:var(--ink);background:#fff;border:1px solid #cdd6df;padding:4px 10px;font-weight:800}.next-manual{width:220px;height:34px;font:inherit;background:#fff;border:1px solid #cdd6df;border-radius:0;padding:0 10px}.next-stepper{align-items:center;gap:10px;display:inline-flex}.next-steps{gap:10px;display:inline-flex}.next-grp{color:#475569;align-items:center;gap:4px;font-size:12px;font-weight:800;display:inline-flex}.next-grp button{color:#0e7a55;cursor:pointer;background:#fff;border:1.5px solid #b9d8c6;border-radius:0;width:30px;height:30px;font-size:16px;font-weight:900;line-height:1}.next-grp button:hover{background:#e6f7ef}.single-check{border:1px solid var(--line);color:#64748b;cursor:pointer;box-sizing:border-box;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#fff;border-radius:6px;justify-content:center;align-items:center;gap:6px;height:30px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.single-check input[type=checkbox]{appearance:none;cursor:pointer;box-sizing:border-box;background:#fff;border:1.5px solid #b3bac4;border-radius:4px;flex:none;width:15px;height:15px;margin:0;position:relative}.single-check input[type=checkbox]:checked{background:currentColor;border-color:currentColor}.single-check input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}.single-check input:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.single-check.pass input{color:#10b981}.single-check.pass:has(input:checked){color:#047857;background:#ecfdf5;border-color:#10b981;box-shadow:inset 0 0 0 1px #10b981}.single-check.skip input{color:#2563eb}.single-check.skip:has(input:checked){color:#1d4ed8;background:#eff6ff;border-color:#2563eb;box-shadow:inset 0 0 0 1px #2563eb}.judge-checks{justify-content:center;gap:6px;display:inline-flex}.gsheet-col td.j-ok{background:#f3fbf7}.gsheet-col td.j-skip{background:#eff5ff}.gsheet-col td.j-ng{background:#fdf4f6}.is-required-missing input,.gsheet input.need-fill{background:#fff1f3;box-shadow:inset 0 0 0 1px #e11d48;border-color:#e11d48!important}.score-cell.is-required-missing{box-shadow:inset 0 0 0 1px #e11d48}.gsheet .judge-btn.skip.on{color:#1d4ed8;background:#eff6ff;border-color:#2563eb}.gsheet tr.j-skip>td{background:#f3f7ff}.entry-grade .gstudent{margin-bottom:22px}.entry-grade .entry-student-toolbar{margin-bottom:8px}.entry-grade .toolbar-field{color:var(--ink);align-items:center;gap:8px;font-size:13px;font-weight:700;display:inline-flex}.entry-grade .toolbar-field input{border:1px solid var(--line);height:34px;font:inherit;color:var(--ink);background:#fff;border-radius:8px;padding:0 10px}.entry-grade .toolbar-field .stu-name{color:var(--ink);font-size:15px;font-weight:800}.entry-grade .instructor-field .stu-name{color:#1d4ed8}.entry-grade .required-mark{color:#dc2626;margin-left:1px;font-weight:800}.entry-grade .metric-chip{color:#3730a3;background:#eef2ff;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:800}.entry-grade .reflect-btn{border-radius:10px;padding:10px 26px;font-size:1rem;font-weight:800}.entry-grade .mastery-sheet-wrap{border:1px solid var(--line);background:#fff;border-radius:12px;position:relative;overflow:auto;box-shadow:0 1px 2px #0f172a0d}.entry-grade .mastery-sheet-scroll{width:max-content;overflow:visible}.entry-grade .mastery-sheet{background:var(--line);transform-origin:0 0;min-width:max-content;display:grid}.entry-grade .sheet-row-label,.entry-grade .sheet-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:54px}.entry-grade .sheet-row-label{z-index:3;color:var(--muted);box-shadow:1px 0 0 var(--line);background:#eef2f7;border-left:4px solid #cbd5e1;justify-content:flex-end;align-items:center;padding:8px 12px;font-size:12px;font-weight:800;display:flex;position:sticky;left:0}.entry-grade .sheet-row-label.row-name{z-index:12;color:#475569;background:#e2e8f0;border-bottom:1px solid #cbd5e1;border-left:4px solid #cbd5e1;justify-content:center;min-height:76px;position:sticky;top:0;left:0}.entry-grade .sheet-row-label[data-row-label=review],.entry-grade .sheet-row-label[data-row-label=next1],.entry-grade .sheet-row-label[data-row-label=review-retest],.entry-grade .sheet-row-label[data-row-label=no-assignment]{color:#0b4a6f;background:#cfe6fb}.entry-grade .sheet-row-label[data-row-label=review-skip],.entry-grade .sheet-row-label[data-row-label=new-material]{color:#991b1b;background:#fcdada}.entry-grade .sheet-row-label[data-row-label=review-pass]{color:#047857;background:#bbf7d0}.entry-grade .sheet-row-label[data-row-label=review-score],.entry-grade .sheet-row-label[data-row-label=review-max-score],.entry-grade .sheet-row-label[data-row-label=remark]{color:#475569;background:#fff;font-weight:700}.entry-grade .sheet-cell{background:#fff;justify-content:center;align-items:center;min-width:172px;padding:8px 10px;font-size:.9rem;transition:background .12s;display:flex}.entry-grade .sheet-cell input[type=number],.entry-grade .sheet-cell input[type=text]{width:100%;height:26px;font:inherit;text-align:center;background:#fff;border:1px solid #d6dee7;border-radius:6px;padding:0 7px}.entry-grade .range-cell{background:#e8f3fe}.entry-grade .range-cell input[type=text],.entry-grade .range-cell .range-text{text-align:center;color:#0b4a6f;background:0 0;border:0;font-weight:700}.entry-grade .rate-cell{font-variant-numeric:tabular-nums}.entry-grade .next-preview-cell{background:#e8f3fe}.entry-grade .remark-cell input{text-align:left;background:0 0!important;border:0!important}.entry-grade .score-cell.is-required-missing input{background:#fff1f3;box-shadow:inset 0 0 0 1px #e11d48;border-color:#e11d48!important}.entry-grade .score-cell input.need-fill{background:#fff1f3;border-color:#e11d48!important}.entry-grade .check-cell{background:#fff}.entry-grade .check-cell[data-sheet-row=review-pass][data-on=true]{background:#bbf7d0}.entry-grade .check-cell[data-sheet-row=review-skip][data-on=true],.entry-grade .check-cell[data-sheet-row=new-material][data-on=true]{background:#fbd5d5}.entry-grade .check-cell[data-sheet-row=review-retest][data-on=true],.entry-grade .check-cell[data-sheet-row=no-assignment][data-on=true]{background:#cfe6fb}.entry-grade .single-check{border:1px solid var(--line);color:#64748b;cursor:pointer;box-sizing:border-box;white-space:nowrap;background:#fff;border-radius:6px;justify-content:center;align-items:center;gap:6px;width:100%;height:30px;padding:0 8px;font-size:12px;font-weight:800;display:inline-flex}.entry-grade .single-check input[type=checkbox]{appearance:none;cursor:pointer;box-sizing:border-box;background:#fff;border:1.5px solid #b3bac4;border-radius:4px;flex:none;width:15px;height:15px;margin:0;position:relative}.entry-grade .single-check input[type=checkbox]:checked{background:currentColor;border-color:currentColor}.entry-grade .single-check input[type=checkbox]:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:4px;height:8px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}.entry-grade .material-head{z-index:8;background:#f8fafc;border-bottom:1px solid #cbd5e1;flex-direction:column;justify-content:flex-start;align-items:flex-start;gap:3px;min-height:76px;padding:6px 8px;position:sticky;top:0;overflow:hidden}.entry-grade .material-head-top{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.entry-grade .subject-pill{letter-spacing:.02em;border-radius:999px;align-items:center;height:16px;padding:0 7px;font-size:9.5px;font-weight:800;display:inline-flex}.entry-grade .material-name{color:#0f172a;text-overflow:ellipsis;max-width:100%;font-size:12.5px;font-weight:800;line-height:1.3;overflow:hidden}.entry-grade .material-meta-line{align-items:center;gap:5px;display:flex}.entry-grade .track-chip{color:#334155;background:#e2e8f0;border-radius:4px;align-items:center;height:15px;padding:0 6px;font-size:9.5px;font-weight:800;display:inline-flex}.entry-grade .material-pace-current{color:#475569;background:#0f172a0d;border-radius:3px;padding:1px 5px;font-size:9.5px;display:inline-block}.entry-grade .next-cell{flex-direction:column;align-items:center;gap:3px;width:100%;padding:2px;display:flex}.entry-grade .next-cell.is-off{opacity:.4}.entry-grade .next-cell .next-val{color:#0b4a6f;text-align:center;background:#fff;border:1px solid #cdd6df;min-width:60px;padding:2px 6px;font-weight:800}.entry-grade .next-cell .next-manual{width:100%;height:26px;font:inherit;background:#fff;border:1px solid #cdd6df;padding:0 6px}.entry-grade .next-cell .next-steps{gap:6px;display:inline-flex}.entry-grade .next-cell .next-grp{color:#475569;align-items:center;gap:2px;font-size:10px;font-weight:800;display:inline-flex}.entry-grade .next-cell .next-grp button{color:#0e7a55;cursor:pointer;background:#fff;border:1.5px solid #b9d8c6;border-radius:4px;width:22px;height:22px;font-size:13px;font-weight:900;line-height:1}.entry-grade .next-cell .next-grp button:hover{background:#e6f7ef}.sheet-zoombar{z-index:60;background:#fff;border:1px solid #cfd6e0;border-radius:999px;align-items:center;gap:2px;padding:2px;display:flex;position:fixed;bottom:24px;right:18px;box-shadow:0 2px 10px #00000024}.sheet-zoombar button{cursor:pointer;font:inherit;color:#334155;background:0 0;border:0;border-radius:999px;padding:5px 11px;line-height:1}.sheet-zoombar button:hover{background:#eef2f8}.sheet-zoombar .sheet-zoom-reset{font-variant-numeric:tabular-nums;min-width:54px;font-weight:700}.gsheet-col{table-layout:fixed;width:auto}.gsheet-col .rowlab{color:#475569;z-index:1;text-align:left;background:#eef3f7;width:108px;font-weight:800;position:sticky;left:0}.gsheet-col .matcol{width:172px}.gsheet-col thead th{text-align:center}.gsheet-col thead th.rowlab{text-align:left}.gsheet-col tbody td{text-align:center}.gsheet-col tbody td.rowlab{text-align:left}.next-cell{flex-direction:column;align-items:center;gap:4px;padding:6px;display:flex}.next-cell.is-off{opacity:.45}.next-cell .next-val{min-width:70px;color:var(--ink);background:#fff;border:1px solid #cdd6df;padding:3px 8px;font-weight:800}.next-cell .next-manual{width:100%;height:32px;font:inherit;background:#fff;border:1px solid #cdd6df;padding:0 8px}.next-cell .next-steps{gap:8px;display:inline-flex}.next-cell .next-grp{color:#475569;align-items:center;gap:3px;font-size:11px;font-weight:800;display:inline-flex}.next-cell .next-grp button{color:#0e7a55;cursor:pointer;background:#fff;border:1.5px solid #b9d8c6;border-radius:0;width:26px;height:26px;font-size:14px;font-weight:900;line-height:1}.next-cell .next-grp button:hover{background:#e6f7ef}.btn-send{cursor:pointer;color:#fff;background:#e11d48;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:800;display:inline-flex;box-shadow:0 1px 2px #00000014}.btn-send:hover{background:#c01540}.btn-send[disabled]{opacity:.5;cursor:not-allowed}.btn-send.big{padding:13px 28px;font-size:15px}.gstudent.is-sent{opacity:.72;border-left-color:var(--primary)}.btn-sent{cursor:default;background:var(--primary);color:#fff;border:1px solid #0000;border-radius:8px;align-items:center;gap:6px;padding:13px 28px;font-family:inherit;font-size:15px;font-weight:800;display:inline-flex}.brand-wordmark{align-items:center;gap:8px;line-height:1;display:inline-flex}.brand-wordmark .bw-main{letter-spacing:.01em;color:#0f172a;font-size:22px;font-weight:800}.brand-wordmark .bw-badge{color:#fff;letter-spacing:.08em;background:#1e3a8a;border-radius:6px;padding:3px 9px;font-size:12px;font-weight:800}[data-division=secondary] .learn-hero{color:#fff;background:linear-gradient(135deg,#1e3a8a,#0f172a)!important}[data-division=secondary] .learn-hero-title,[data-division=secondary] .learn-hero-sub{color:#fff}[data-division=secondary] .hero-chip{color:#fff;background:#ffffff24}[data-division=secondary] .mission{border-color:#cbd5e1}[data-division=secondary] .meter-title{letter-spacing:.02em}.division-badge{letter-spacing:.02em;border-radius:999px;align-items:center;margin-left:6px;padding:1px 8px;font-size:11px;font-weight:800;display:inline-flex}.division-badge.elementary{color:#92400e;background:#fef3c7}.division-badge.secondary{color:#1e40af;background:#dbeafe}.division-root{transition:none}.division-root[data-division=secondary]{--primary:#1e3a8a;--primary-d:#172554;--primary-soft:#eef2ff;--primary-line:#c7d2fe}.division-root[data-division=secondary] .appbar{background:#f8fafc}.division-root[data-division=secondary] .appbar-role{color:#fff;background:#1e3a8a;border-color:#1e3a8a}.division-switch[data-pending=true]{opacity:.6;pointer-events:none}.mws-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;display:flex}.mws-split{grid-template-columns:minmax(0,1fr) 420px;align-items:start;gap:14px;display:grid}@media (max-width:1100px){.mws-split{grid-template-columns:1fr}}.mws-list-card{padding:0;overflow:hidden}.mws-list-head,.mws-row{align-items:center;gap:8px;padding:8px 12px;display:flex}.mws-list-head{color:#475569;z-index:1;background:#f1f5f9;border-bottom:1px solid #e2e8f0;font-size:12px;font-weight:600;position:sticky;top:0}.mws-list-body{max-height:calc(100vh - 260px);overflow-y:auto}.mws-row{border-bottom:1px solid #eef2f6}.mws-row:hover{background:#f8fbff!important}.mws-open{border:1px solid var(--primary);width:46px;height:30px;color:var(--primary);cursor:pointer;background:#fff;border-radius:6px;flex:none;font-size:12px;font-weight:600}.mws-open:hover{background:var(--primary);color:#fff}.mws-summary,.mws-summary-head{color:#b45309;text-overflow:ellipsis;white-space:nowrap;flex:160px;min-width:0;font-size:12px;font-weight:600;overflow:hidden}.mws-summary-head{color:#475569}.mws-detail-card{padding:0;position:sticky;top:12px;overflow:hidden}.mws-panel-head{color:#fff;background:linear-gradient(135deg,#1d4ed8,#2563eb);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.mws-panel-body{max-height:calc(100vh - 220px);padding:14px 16px;overflow-y:auto}.mws-detail-summary{background:#f0fdf4;border:1px solid #dcfce7;border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:8px 10px;display:flex}.mws-range-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.mws-range{background:#fff;border:1px solid #e3e7ee;border-radius:8px;align-items:flex-start;gap:8px;padding:8px;display:flex}.mws-range:hover{background:#fafcff;border-color:#cfd8e6}.mws-range-num{color:#475569;background:#eef2f7;border-radius:6px;flex:none;justify-content:center;align-items:center;min-width:24px;height:24px;margin-top:5px;font-size:12px;font-weight:700;display:inline-flex}.mws-range-body{flex-direction:column;flex:auto;gap:6px;min-width:0;display:flex}.mws-file-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.mws-file-label{text-align:center;border-radius:6px;flex:none;min-width:62px;padding:2px 8px;font-size:11px;font-weight:800}.mws-file-q{color:#1d4ed8;background:#e8f1ff;border:1px solid #c7dbff}.mws-file-a{color:#1f7a3d;background:#eaf7ee;border:1px solid #c3e6cd}
