html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}body{background:#1a1b26;font:15px/1.5 system-ui,Segoe UI,Roboto,sans-serif}:root{--bg:#1a1b26;--panel:#24283b;--panel-2:#1f2335;--border:#2f3347;--accent:#7aa2f7;--text:#c0caf5;--muted:#787c99;--err:#f7768e;--ok:#9ece6a}*{box-sizing:border-box}.app{background:var(--bg);min-height:100vh;color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.topbar{z-index:10;background:var(--panel);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex;position:sticky;top:0}.brand{margin-right:8px;font-weight:700}.topbar button{background:var(--accent);color:#1a1b26;cursor:pointer;border:0;border-radius:7px;padding:7px 12px;font-size:13px;font-weight:600}.topbar button.ghost{background:var(--panel-2);color:var(--text);border:1px solid var(--border)}.topbar button:disabled{opacity:.45;cursor:not-allowed}.divider{background:var(--border);width:1px;height:22px;margin:0 4px}.status-area{align-items:center;gap:14px;margin-left:auto;font-size:12px;display:flex}.kernel-status{color:var(--muted)}.kernel-status.ok{color:var(--ok)}.saved{color:var(--muted)}.cells{max-width:980px;margin:0 auto;padding:22px 16px 120px}.cell{gap:10px;margin-bottom:14px;display:flex}.cell-side{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:42px;padding-top:4px;display:flex}.run-dot{border:1px solid var(--border);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;width:28px;height:28px;font-size:11px}.run-dot:disabled{opacity:.4;cursor:not-allowed}.exec-label{color:var(--muted);font-family:monospace;font-size:11px}.exec-label.md{color:var(--accent)}.cell-main{border:1px solid var(--border);background:var(--panel-2);border-radius:10px;flex:1;min-width:0;overflow:hidden}.cell.running .cell-main{border-color:var(--accent)}.cell-toolbar{background:var(--panel);border-bottom:1px solid var(--border);align-items:center;gap:4px;padding:5px 8px;display:flex}.cell-type{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.cell-toolbar .spacer{flex:1}.cell-toolbar button{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:5px;padding:2px 6px;font-size:13px}.cell-toolbar button:hover:not(:disabled){background:var(--panel-2);color:var(--text)}.cell-toolbar button:disabled{opacity:.3;cursor:not-allowed}.cm-editor{font-size:13.5px}.output{border-top:1px solid var(--border);padding:8px 12px}.output pre{white-space:pre-wrap;word-break:break-word;margin:0;font-family:SFMono-Regular,Consolas,monospace;font-size:12.5px;line-height:1.5}.out-stream{color:var(--text)}.out-result{color:var(--accent)}.out-err{color:var(--err)}.out-muted{color:var(--muted);font-style:italic}.out-img{background:#fff;border-radius:6px;max-width:100%;margin-top:8px}.md-editor{background:var(--panel-2);width:100%;min-height:90px;color:var(--text);resize:vertical;border:0;outline:none;padding:12px;font-family:monospace;font-size:13.5px}.md-rendered{cursor:text;padding:4px 16px}.md-rendered h1{font-size:24px}.md-rendered h2{font-size:20px}.md-rendered code{background:var(--panel);border-radius:4px;padding:1px 5px;font-size:.9em}.md-rendered pre{background:var(--panel);border-radius:8px;padding:10px;overflow:auto}.md-rendered a{color:var(--accent)}.add-row{gap:8px;margin-left:52px;display:flex}.add-row button{border:1px dashed var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-size:13px}.add-row button:hover{color:var(--text);border-color:var(--accent)}.centered{min-height:100vh;color:var(--text);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.muted{color:var(--muted)}.auth-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:12px;width:360px;max-width:100%;padding:28px;display:flex}.auth-card h1{margin:0;font-size:22px}.auth-sub{color:var(--muted);margin:0 0 6px;font-size:13px}.auth-card input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;padding:11px 12px;font-size:14px}.auth-card input:focus{border-color:var(--accent)}.auth-card button[type=submit]{background:var(--accent);color:#1a1b26;cursor:pointer;border:0;border-radius:8px;margin-top:4px;padding:11px;font-size:14px;font-weight:600}.auth-card button:disabled{opacity:.6;cursor:not-allowed}.auth-error{border:1px solid var(--err);color:var(--err);background:#f7768e1f;border-radius:8px;padding:9px 12px;font-size:13px}.auth-switch{text-align:center;color:var(--muted);font-size:13px}.auth-switch a{color:var(--accent);cursor:pointer;text-decoration:underline}.list-main{max-width:760px;margin:0 auto;padding:28px 16px}.list-main h2{margin:0 0 16px}.assignment-list{flex-direction:column;gap:12px;display:flex}.assignment-card{background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:16px 18px;text-decoration:none;transition:border-color .15s;display:block}.assignment-card:hover{border-color:var(--accent)}.assignment-title{font-size:16px;font-weight:600}.assignment-desc{color:var(--muted);margin-top:4px;font-size:13px}.assignment-due{color:var(--accent);margin-top:6px;font-size:12px}.submit-btn{background:var(--ok)!important;color:#1a1b26!important}.badge-submitted{color:var(--ok);border:1px solid var(--ok);background:#9ece6a29;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.list-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.list-head h2{margin:0}.list-head button{background:var(--accent);color:#1a1b26;cursor:pointer;border:0;border-radius:8px;padding:8px 14px;font-weight:600}.assignment-card.static:hover{border-color:var(--border)}.card-actions{gap:10px;margin-top:12px;display:flex}.link-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:7px;padding:5px 10px;font-size:12.5px;text-decoration:none}.link-btn:hover{border-color:var(--accent)}.link-btn.danger{color:var(--err)}.link-btn.danger:hover{border-color:var(--err)}.editor-form{flex-direction:column;gap:12px;max-width:980px;margin:0 auto;padding:18px 16px 0;display:flex}.editor-form label{color:var(--muted);flex-direction:column;gap:5px;font-size:13px;display:flex}.editor-form input,.editor-form textarea{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;padding:9px 11px;font-family:inherit;font-size:14px}.editor-form input:focus,.editor-form textarea:focus{border-color:var(--accent)}.editor-form input[type=datetime-local]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;width:max-content}.editor-hint{color:var(--muted);border-top:1px dashed var(--border);padding-top:10px;font-size:12px}.link-btn.primary{background:var(--accent);color:#1a1b26;border-color:var(--accent)}.sub-of{color:var(--muted);font-size:13px;font-weight:400}.badge-draft{color:var(--muted);border:1px solid var(--muted);background:#787c992e;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.ok-text{color:var(--ok)}.grade-table{border-collapse:collapse;width:100%;font-size:13.5px}.grade-table th,.grade-table td{text-align:left;border-bottom:1px solid var(--border);padding:9px 12px}.grade-table th{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:600}.grade-table tbody tr:hover{background:var(--panel)}.grade-table .muted-cell{color:var(--muted)}.grade-panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:10px;max-width:980px;margin:16px auto 0;padding:16px;display:flex}.grade-row{align-items:flex-end;gap:12px;display:flex}.grade-row label{color:var(--muted);flex-direction:column;gap:5px;font-size:13px;display:flex}.grade-row input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;width:110px;padding:9px 11px;font-size:16px}.grade-row input:focus{border-color:var(--accent)}.fb-label{color:var(--muted);flex-direction:column;gap:5px;font-size:13px;display:flex}.grade-panel textarea{background:var(--panel-2);border:1px solid var(--border);color:var(--text);resize:vertical;border-radius:8px;outline:none;padding:9px 11px;font-family:inherit;font-size:14px}.grade-panel textarea:focus{border-color:var(--accent)}.grade-banner{border:1px solid var(--ok);background:#9ece6a1f;border-radius:12px;max-width:980px;margin:16px auto 0;padding:14px 18px}.grade-score{color:var(--ok);font-size:18px}.grade-fb{color:var(--text);white-space:pre-wrap;margin-top:6px;font-size:14px}.import-box{background:var(--panel);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;padding:18px}.import-box h3{margin:0 0 6px}.import-text{background:var(--panel-2);border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;border-radius:8px;outline:none;margin-top:8px;padding:10px 12px;font-family:monospace;font-size:13px}.import-text:focus{border-color:var(--accent)}.import-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-top:12px;display:flex}.inline-field{color:var(--muted);flex-direction:column;flex:1;gap:5px;min-width:240px;font-size:12.5px;display:flex}.inline-field input{background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;padding:9px 11px;font-size:14px}.inline-field input:focus{border-color:var(--accent)}.file-pick{background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;padding:9px 14px;font-size:13px}.import-controls>button{background:var(--accent);color:#1a1b26;cursor:pointer;white-space:nowrap;border:0;border-radius:8px;padding:9px 16px;font-weight:600}.import-controls>button:disabled{opacity:.6;cursor:not-allowed}.import-result{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;margin-top:14px;padding:12px;font-size:13.5px}.import-errors{color:var(--err);margin-top:8px}.import-errors ul{margin:4px 0 0;padding-left:20px}.import-box code{background:var(--panel-2);border-radius:4px;padding:1px 6px;font-size:.9em}.due-chip{color:var(--muted);border:1px solid var(--border);border-radius:20px;padding:3px 10px;font-size:12px}.due-chip.overdue{color:var(--err);border-color:var(--err);font-weight:600}.src-row{border-bottom:1px dashed var(--border);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:4px;padding-bottom:12px;display:flex}.tpl-select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;outline:none;padding:8px 11px;font-size:14px}.tpl-select:focus{border-color:var(--accent)}.ghost-btn{background:var(--panel-2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:8px;padding:8px 14px;font-size:13px}.ghost-btn:hover{border-color:var(--accent)}.check-field{cursor:pointer;align-items:center;font-size:13px;color:var(--text)!important;flex-direction:row!important;gap:8px!important}.check-field input{width:auto}.proctor-note{border:1px solid var(--accent);max-width:980px;color:var(--accent);background:#7aa2f71f;border-radius:10px;margin:12px auto 0;padding:9px 14px;font-size:12.5px}.proctor-panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;max-width:980px;margin:14px auto 0;padding:14px 16px}.proctor-panel.warn{border-color:var(--err)}.proctor-head{margin-bottom:10px;font-weight:600}.proctor-panel.warn .proctor-head{color:var(--err)}.proctor-stats{color:var(--muted);flex-wrap:wrap;gap:16px;font-size:13px;display:flex}.proctor-stats b{color:var(--text)}.proctor-timeline{margin-top:12px;font-size:12.5px}.proctor-timeline summary{cursor:pointer;color:var(--accent)}.proctor-timeline ul{max-height:220px;margin:8px 0 0;padding-left:18px;overflow:auto}.proctor-timeline li{margin-bottom:3px}.row-session td{background:#7aa2f712;font-weight:500}.fs-gate{z-index:1000;background:#0f1018f7;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.fs-box{text-align:center;background:var(--panel);border:1px solid var(--accent);border-radius:16px;flex-direction:column;gap:12px;max-width:460px;padding:32px;display:flex}.fs-icon{font-size:40px}.fs-box h2{margin:0;font-size:20px}.fs-box p{color:var(--muted);margin:0;font-size:14px;line-height:1.6}.fs-btn{background:var(--accent);color:#1a1b26;cursor:pointer;border:0;border-radius:10px;margin-top:8px;padding:12px 18px;font-size:15px;font-weight:700}.fs-back{color:var(--muted);cursor:pointer;background:0 0;border:0;font-size:13px}.fs-back:hover{color:var(--text)}
