*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inline{display:inline}.flex{display:flex}.grid{display:grid}.contents{display:contents}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root,[data-theme=dark]{--bg:#0b0b0f;--surface:#14141b;--surface-2:#1c1c25;--surface-3:#24242f;--border:#2a2a37;--border-soft:#1e1e29;--text:#f1f1f4;--text-mute:#8c8c99;--text-dim:#5d5d6a;--accent:#a78bfa;--accent-2:#c4b5fd;--accent-soft:#2a2342;--accent-glow:rgba(167,139,250,.18);--success:#6ee7b7;--warn:#fcd34d;--danger:#f87171;--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow:0 1px 0 hsla(0,0%,100%,.04) inset,0 8px 24px rgba(0,0,0,.35);--shadow-lg:0 1px 0 hsla(0,0%,100%,.04) inset,0 24px 60px rgba(0,0,0,.55);--topbar-bg:rgba(11,11,15,.85);--sans:"IBM Plex Sans KR","IBM Plex Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace}[data-theme=light]{--bg:#fafafb;--surface:#fff;--surface-2:#f4f4f7;--surface-3:#ebebf0;--border:#d8d8e0;--border-soft:#e8e8ee;--text:#15151b;--text-mute:#5d5d6a;--text-dim:#9999a3;--accent:#7c5cf2;--accent-2:#6244e3;--accent-soft:#ece7ff;--accent-glow:rgba(124,92,242,.16);--success:#15a872;--warn:#c08a00;--danger:#dc4747;--shadow:0 1px 0 rgba(0,0,0,.02) inset,0 4px 16px rgba(15,15,30,.06);--shadow-lg:0 1px 0 rgba(0,0,0,.02) inset,0 18px 48px rgba(15,15,30,.12);--topbar-bg:rgba(250,250,251,.85)}[data-theme=light] ::-webkit-scrollbar-thumb{background:#cdcdd6;border:2px solid var(--bg)}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#b6b6c2}[data-theme=light] .list__row--head{background:rgba(0,0,0,.025)}[data-theme=light] .subm__thumb--code{background:linear-gradient(135deg,#efeaff,#e3dcff);color:#6244e3}[data-theme=light] .subm__thumb--img{background:repeating-linear-gradient(45deg,#eef0f5 0 6px,#e3e6ed 6px 12px);color:var(--text-mute)}[data-theme=light] .subm__thumb--pdf{background:linear-gradient(135deg,#fff3d8,#ffe9b8);color:#a06600}[data-theme=light] .btn--primary{color:#fff}[data-theme=light] .btn:hover{border-color:#bdbdc7}[data-theme=light] .topbar__kbd{background:#fff}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{font-size:14px;line-height:1.5;letter-spacing:-.005em}a{color:inherit;text-decoration:none}button{background:none;border:0;cursor:pointer;padding:0}button,input,select,textarea{font:inherit;color:inherit}::selection{background:var(--accent-soft);color:var(--accent-2)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#2a2a37;border-radius:8px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:#3a3a4a}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh;background:var(--bg)}.app--noshell{grid-template-columns:1fr}.side{background:linear-gradient(180deg,var(--surface) 0,var(--bg) 100%);border-right:1px solid var(--border-soft);padding:20px 14px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.side__brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}.side__logo{width:30px;height:30px;border-radius:8px;background:radial-gradient(120% 120% at 0 0,var(--accent) 0,#6d4dd6 60%,#3a2575 100%);display:grid;place-items:center;color:#0b0b0f;font-weight:700;font-size:14px;box-shadow:0 4px 12px var(--accent-glow),inset 0 1px 0 hsla(0,0%,100%,.25)}.side__brandname{font-weight:600;letter-spacing:-.01em;font-size:15px}.side__brandsub{font-family:var(--mono);margin-top:1px}.side__brandsub,.side__section{font-size:11px;color:var(--text-dim)}.side__section{text-transform:uppercase;letter-spacing:.08em;padding:14px 8px 6px;font-weight:500}.side__item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:var(--text-mute);font-size:13.5px;font-weight:500;cursor:pointer;transition:background .12s,color .12s}.side__item:hover{background:var(--surface);color:var(--text)}.side__item.is-active{background:var(--surface-2);color:var(--text)}.side__item.is-active .side__icon{color:var(--accent)}.side__icon{width:16px;height:16px;color:var(--text-dim);flex-shrink:0}.side__count{margin-left:auto;font-size:11px;color:var(--text-dim);font-family:var(--mono);background:var(--surface-2);padding:2px 6px;border-radius:5px}.side__item.is-active .side__count{background:var(--accent-soft);color:var(--accent-2)}.side__user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;background:var(--surface);border:1px solid var(--border-soft)}.side__avatar{width:30px;height:30px;border-radius:50%;background:var(--accent-soft);color:var(--accent-2);display:grid;place-items:center;font-weight:600;font-size:12px;flex-shrink:0}.side__username{font-size:13px;font-weight:500;line-height:1.2}.side__userrole{font-size:11px;color:var(--text-dim);font-family:var(--mono);margin-top:2px}.topbar{gap:16px;padding:14px 28px;border-bottom:1px solid var(--border-soft);background:var(--topbar-bg);backdrop-filter:blur(8px);position:sticky;top:0;z-index:5}.topbar,.topbar__crumb{display:flex;align-items:center}.topbar__crumb{gap:6px;color:var(--text-mute);font-size:13px}.topbar__crumb b{color:var(--text);font-weight:600}.topbar__sep{color:var(--text-dim)}.topbar__spacer{flex:1}.topbar__search{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--surface);border:1px solid var(--border-soft);border-radius:8px;width:280px;color:var(--text-mute);font-size:13px}.topbar__search:focus-within{border-color:var(--accent);background:var(--surface-2)}.topbar__search input{background:none;border:0;outline:0;flex:1;color:var(--text);min-width:0}.topbar__search input::placeholder{color:var(--text-dim)}.topbar__kbd{font-family:var(--mono);font-size:11px;color:var(--text-dim);padding:2px 5px;border:1px solid var(--border);border-radius:4px;background:var(--bg)}.topbar__icon-btn{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;color:var(--text-mute);border:1px solid transparent;position:relative}.topbar__icon-btn:hover{background:var(--surface);color:var(--text)}.topbar__dot{position:absolute;top:7px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 2px var(--bg)}.main{padding:28px 32px;max-width:1280px;width:100%}.main--narrow{max-width:920px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.page-title{font-size:24px;font-weight:600;letter-spacing:-.015em;line-height:1.2;margin:0}.page-sub{color:var(--text-mute);font-size:14px;margin-top:6px}.page-actions{display:flex;gap:8px;align-items:center}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;font-size:13.5px;font-weight:500;border:1px solid var(--border);background:var(--surface);color:var(--text);transition:background .12s,border-color .12s,transform .04s;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:#3a3a4a}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--accent);color:#0b0b0f;border-color:transparent;font-weight:600}.btn--primary:hover{background:var(--accent-2)}.btn--ghost{background:transparent;border-color:transparent;color:var(--text-mute)}.btn--ghost:hover{background:var(--surface);color:var(--text)}.btn--danger{color:var(--danger);border-color:transparent}.btn--danger:hover{background:hsla(0,91%,71%,.08);border-color:hsla(0,91%,71%,.2)}.btn--sm{padding:5px 10px;font-size:12.5px;border-radius:6px}.btn--icon{padding:7px;width:32px;height:32px;justify-content:center}.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden}.card__head{padding:14px 18px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;gap:12px}.card__title{font-size:14px;font-weight:600;letter-spacing:-.005em;margin:0}.card__body{padding:18px}.card__foot{padding:12px 18px;border-top:1px solid var(--border-soft);background:rgba(0,0,0,.15)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stat{padding:16px 18px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius)}.stat__label{font-size:12px;color:var(--text-mute);font-weight:500;display:flex;align-items:center;gap:6px}.stat__value{font-size:28px;font-weight:600;letter-spacing:-.02em;margin-top:6px;line-height:1;font-feature-settings:"tnum"}.stat__sub{font-size:12px;color:var(--text-dim);margin-top:4px;font-family:var(--mono)}.stat__sub--up{color:var(--success)}.stat__sub--warn{color:var(--warn)}.list{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);overflow:hidden}.list__row{display:grid;align-items:center;padding:14px 18px;gap:16px;border-bottom:1px solid var(--border-soft);cursor:pointer;transition:background .1s}.list__row:last-child{border-bottom:0}.list__row:hover{background:var(--surface-2)}.list__row--head{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);padding:10px 18px;cursor:default;font-weight:500}.list__row--head,.list__row--head:hover{background:rgba(0,0,0,.2)}.subm-row{grid-template-columns:1.4fr .7fr .9fr .8fr .6fr 28px}.subm-row--student{grid-template-columns:1.6fr .9fr 1fr .7fr 28px}.subm__title{display:flex;align-items:center;gap:12px;min-width:0}.subm__thumb{width:38px;height:38px;border-radius:8px;flex-shrink:0;background:var(--surface-2);border:1px solid var(--border-soft);display:grid;place-items:center;color:var(--text-mute);font-family:var(--mono);font-size:11px;font-weight:600}.subm__thumb--code{background:linear-gradient(135deg,#1a1a2e,#0f0f1a);color:#a78bfa}.subm__thumb--img{background:repeating-linear-gradient(45deg,#1a1a2e 0 6px,#15151b 6px 12px);color:var(--text-mute)}.subm__thumb--pdf{background:linear-gradient(135deg,#2a1a1a,#1f0f0f);color:#fbbf24}.subm__name{font-weight:500;font-size:13.5px;color:var(--text);margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subm__meta{font-size:12px;color:var(--text-mute);font-family:var(--mono);display:flex;gap:10px}.subm__meta span{gap:4px}.pill,.subm__meta span{display:inline-flex;align-items:center}.pill{gap:5px;padding:3px 8px;border-radius:6px;font-size:11.5px;font-weight:500;font-family:var(--mono);letter-spacing:0;white-space:nowrap}.pill__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.pill--pending{background:rgba(252,211,77,.1);color:#fcd34d}.pill--reviewed{background:rgba(110,231,183,.1);color:#6ee7b7}.pill--needs{background:hsla(0,91%,71%,.1);color:#f87171}.pill--draft{background:var(--surface-2);color:var(--text-mute)}.pill--new{background:var(--accent-soft);color:var(--accent-2)}.stars{display:inline-flex;gap:2px;color:var(--text-dim)}.stars svg{width:13px;height:13px}.stars .on{color:var(--warn)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field__label{font-size:12px;font-weight:500;color:var(--text-mute);letter-spacing:0}.field__hint{font-size:11.5px;color:var(--text-dim);margin-top:-2px}.input,.select,.textarea{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:13.5px;color:var(--text);outline:0;transition:border-color .12s,background .12s}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);background:var(--surface-3);box-shadow:0 0 0 3px var(--accent-glow)}.textarea{resize:vertical;min-height:84px;font-family:var(--sans);line-height:1.55}.textarea--code{font-family:var(--mono);font-size:13px}.drop{border:1.5px dashed var(--border);border-radius:var(--radius);padding:36px 20px;text-align:center;background:var(--surface);transition:border-color .15s,background .15s}.drop.is-active{border-color:var(--accent);background:var(--accent-soft)}.drop__icon{width:42px;height:42px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center;margin:0 auto 12px;color:var(--accent)}.drop__title{font-size:15px;font-weight:600;margin-bottom:4px}.drop__sub{font-size:13px;color:var(--text-mute)}.drop__formats{margin-top:14px;display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:center}.drop__chip{font-family:var(--mono);font-size:11px;color:var(--text-dim);padding:3px 8px;border:1px solid var(--border-soft);border-radius:5px}.code-block{background:#0a0a10;border:1px solid var(--border-soft);border-radius:10px;overflow:hidden}.code-block__head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-soft);font-family:var(--mono);font-size:11.5px;color:var(--text-mute);background:hsla(0,0%,100%,.02)}.code-block__name{display:flex;align-items:center;gap:8px}.code-block__lang{padding:2px 6px;background:var(--surface-2);border-radius:4px;color:var(--accent-2);font-size:10.5px}.code-block__body{padding:14px 0;font-family:var(--mono);font-size:12.5px;line-height:1.7;overflow-x:auto;display:flex}.code-line{display:flex;padding:0 16px 0 0;min-height:21px;position:relative}.code-line.is-comment{color:#6b7280}.code-line__num{flex-shrink:0;width:42px;padding-right:14px;text-align:right;color:var(--text-dim);user-select:none}.code-line__txt{white-space:pre;color:#d4d4d8;flex:1}.code-line:hover{background:rgba(167,139,250,.04)}.code-line.has-comment{background:rgba(252,211,77,.04);box-shadow:inset 2px 0 0 var(--warn)}.code-line__add{opacity:0;width:18px;height:18px;border-radius:4px;background:var(--accent);color:#0b0b0f;display:grid;place-items:center;font-size:13px;font-weight:600;position:absolute;left:24px;top:1px;cursor:pointer;transition:opacity .1s}.code-line:hover .code-line__add{opacity:1}.tok-kw{color:#c084fc}.tok-fn{color:#7dd3fc}.tok-str{color:#86efac}.tok-num{color:#fcd34d}.tok-com{color:#71717a;font-style:italic}.tok-pun{color:#a1a1aa}.tok-var{color:#e4e4e7}.img-preview{background:repeating-linear-gradient(45deg,#15151b 0 10px,#1a1a22 10px 20px);border:1px solid var(--border-soft);border-radius:10px;height:340px;position:relative;overflow:hidden;display:grid;place-items:center;color:var(--text-dim);font-family:var(--mono);font-size:12px}.img-preview__pin{position:absolute;width:24px;height:24px;border-radius:50%;background:var(--warn);color:#0b0b0f;font-weight:700;font-size:12px;display:grid;place-items:center;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 3px rgba(252,211,77,.15);transition:transform .1s}.img-preview__pin:hover{transform:scale(1.15)}.img-preview__pin.is-active{background:var(--accent);color:#0b0b0f;box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 4px var(--accent-glow)}.comment{display:flex;gap:10px;padding:12px 0;border-bottom:1px solid var(--border-soft)}.comment:last-child{border-bottom:0}.comment__avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--accent-soft);color:var(--accent-2);display:grid;place-items:center;font-size:11px;font-weight:600}.comment__avatar--teacher{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff}.comment__head{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:3px}.comment__name{font-weight:600;color:var(--text)}.comment__role{font-size:10px;padding:1px 5px;background:var(--accent-soft);color:var(--accent-2);border-radius:4px;font-family:var(--mono);font-weight:500;letter-spacing:.02em}.comment__time{color:var(--text-dim);font-family:var(--mono)}.comment__body{font-size:13.5px;color:var(--text);line-height:1.55}.comment__line{font-family:var(--mono);font-size:11px;color:var(--text-dim);background:var(--surface-2);padding:1px 5px;border-radius:4px;margin-left:6px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border-soft);margin-bottom:20px}.tab{padding:10px 14px;font-size:13px;color:var(--text-mute);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer}.tab.is-active,.tab:hover{color:var(--text)}.tab.is-active{border-color:var(--accent)}.sidepanel{position:fixed;top:0;right:0;bottom:0;width:480px;background:var(--surface);border-left:1px solid var(--border);z-index:50;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideIn .25s cubic-bezier(.2,.8,.2,1)}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.sidepanel__head{padding:18px 22px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.sidepanel__body{flex:1;overflow:auto;padding:22px}.sidepanel__foot{padding:14px 22px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:flex-end}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:40;display:grid;place-items:center;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:560px;max-width:92vw;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:popIn .2s cubic-bezier(.2,.8,.2,1)}@keyframes popIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal__head{padding:18px 22px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.modal__body{padding:20px 22px;max-height:60vh;overflow:auto}.modal__foot{padding:14px 22px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:flex-end}.login-stage{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-aside{background:radial-gradient(circle at 20% 80%,rgba(167,139,250,.18) 0,transparent 50%),radial-gradient(circle at 80% 20%,rgba(167,139,250,.1) 0,transparent 50%),linear-gradient(180deg,#0e0e15,#0b0b0f);border-right:1px solid var(--border-soft);padding:48px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-form-wrap{display:grid;place-items:center;padding:48px}.login-form{width:380px;max-width:100%}.login-headline{font-size:40px;font-weight:600;letter-spacing:-.025em;line-height:1.1;margin:0 0 16px}.login-headline em{color:var(--accent);font-style:normal}.login-tag{font-size:14px;color:var(--text-mute);font-family:var(--mono)}.login-feat{display:flex;flex-direction:column;gap:14px;margin-top:32px}.login-feat__row{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--text-mute)}.login-feat__check{width:22px;height:22px;border-radius:6px;background:var(--accent-soft);color:var(--accent-2);display:grid;place-items:center;flex-shrink:0;margin-top:1px}.row{align-items:center}.col,.row{display:flex;gap:8px}.col{flex-direction:column}.muted{color:var(--text-mute)}.dim{color:var(--text-dim)}.mono{font-family:var(--mono)}.divider{height:1px;background:var(--border-soft);margin:14px 0}.spacer{flex:1}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:10;background:var(--surface);border-top:1px solid var(--border-soft);padding:6px 0 env(safe-area-inset-bottom,6px)}.mobile-nav__items{display:flex;justify-content:space-around;align-items:center}.mobile-nav__item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;border-radius:8px;color:var(--text-mute);font-size:10px;font-weight:500;text-decoration:none;transition:color .12s}.mobile-nav__item.is-active,.mobile-nav__item:hover{color:var(--text)}.mobile-nav__item.is-active svg{color:var(--accent)}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}.main{padding:20px}.login-stage{grid-template-columns:1fr}.login-aside{display:none}.login-form-wrap{min-height:100vh}}@media (max-width:768px){.app{grid-template-columns:1fr;padding-bottom:60px}.side{display:none}.mobile-nav{display:block}.topbar{padding:10px 16px}.topbar__search{display:none}.main{padding:16px}.main--narrow{max-width:100%}.page-head{flex-direction:column;align-items:flex-start;gap:12px}.page-actions{width:100%}.page-actions .btn{flex:1;justify-content:center}.stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}.stat{padding:12px 14px}.stat__value{font-size:22px}.grid-responsive{display:flex!important;flex-direction:column!important}.subm-row,.subm-row--student{grid-template-columns:1fr auto!important}.list__row--head,.subm-row .mono,.subm-row--student .mono,.subm-row--student>div:nth-child(2),.subm-row--student>div:nth-child(3),.subm-row>div:nth-child(2),.subm-row>div:nth-child(3){display:none}.code-block__body{font-size:11.5px}.code-line__num{width:32px;padding-right:8px}.drop{padding:24px 16px}.drop__formats{gap:4px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.tab{white-space:nowrap;flex-shrink:0}.card__foot .row{flex-wrap:wrap;gap:6px}.card__foot .btn{font-size:12px;padding:6px 10px}}.attachment-list{display:flex;flex-wrap:wrap;gap:8px}.attachment-item{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;border:1px solid var(--border-soft);background:var(--surface-2);cursor:pointer;font-size:13px;transition:border-color .15s,background .15s}.attachment-item:hover{border-color:var(--primary);background:rgba(99,102,241,.05)}.attachment-item:disabled{opacity:.6;cursor:wait}.attachment-item__name{font-weight:500;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-item__loading,.attachment-item__size{font-size:11px;color:var(--text-mute)}.attachment-preview-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;padding:24px}.attachment-preview{background:var(--surface-1);border-radius:12px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}.attachment-preview__head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-soft);font-size:13px;font-weight:500}.attachment-preview__body{overflow:auto;padding:16px;display:flex;align-items:center;justify-content:center}.attachment-preview__body img{max-width:100%;max-height:70vh;border-radius:6px}.attachment-preview__foot{padding:12px 16px;border-top:1px solid var(--border-soft);display:flex;justify-content:flex-end}