*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Noto Sans KR,Arial,sans-serif;color:#18212f;background:#eef2f5}button,input,select{font:inherit}.login-shell{min-height:100vh;display:grid;place-items:center;background:linear-gradient(#0c1826a8,#0c1826a8),url(https://images.unsplash.com/photo-1523580846011-d3a5bc25702b?auto=format&fit=crop&w=1600&q=80) center/cover}.login-panel{width:min(380px,calc(100vw - 32px));background:#fffffff0;border:1px solid rgba(255,255,255,.5);border-radius:8px;padding:28px;box-shadow:0 18px 42px #0a142047}.login-mark{width:42px;height:42px;display:grid;place-items:center;color:#fff;background:#235a70;border-radius:8px}h1,h2,h3,p{margin:0}.login-panel h1{margin:18px 0 24px;font-size:25px}label{display:grid;gap:7px;font-size:13px;font-weight:700}input,select{min-height:36px;border:1px solid #c8d1d9;border-radius:6px;background:#fff;padding:0 10px;color:#17212c}input:focus,select:focus{outline:2px solid #2b7c96;outline-offset:1px}button{border:0;border-radius:6px;min-height:36px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:7px;cursor:pointer;white-space:nowrap}button:disabled{cursor:not-allowed;opacity:.55}.primary{background:#235a70;color:#fff;font-weight:800}.login-panel .primary{width:100%;margin-top:18px}.error,.banner{color:#9e2f24}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto auto 1fr}.topbar{height:72px;display:flex;justify-content:space-between;align-items:center;padding:0 22px;background:#fff;border-bottom:1px solid #d8e0e7}.topbar h1{font-size:21px}.topbar p{margin-top:4px;color:#607080;font-size:13px}.top-actions{display:flex;align-items:center;gap:8px}.seg{background:#e6edf2;color:#344250;font-weight:800}.seg.active{background:#1d2e3d;color:#fff}.banner{padding:10px 22px;background:#fff2ed;border-bottom:1px solid #f2c2b3;font-weight:700}.workspace{min-height:0;display:grid;grid-template-columns:360px 1fr}.input-pane{min-height:0;overflow:auto;padding:18px;background:#f8fafb;border-right:1px solid #d8e0e7}.pane-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.pane-head h2{font-size:16px}.pane-head.compact{margin-top:20px}.subject-groups{display:grid;gap:14px}.subject-group{border-top:1px solid #dce4ea;padding-top:10px}.subject-group h3{color:#4d5d6b;font-size:12px;margin-bottom:8px}.score-row{grid-template-columns:1fr 86px;align-items:center;gap:9px;margin-bottom:7px;font-weight:600}.score-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-row input{min-height:32px}.grade-list{max-height:330px;overflow:auto;padding-right:4px}.result-pane{min-width:0;display:grid;grid-template-rows:auto 1fr}.filters{display:grid;grid-template-columns:minmax(220px,1.2fr) repeat(4,minmax(110px,.7fr));gap:8px;padding:14px 18px;background:#fff;border-bottom:1px solid #d8e0e7}.search{position:relative}.search svg{position:absolute;left:10px;top:10px;color:#6b7a87}.search input{padding-left:34px}.table-wrap{min-height:0;overflow:auto}.empty{height:100%;display:grid;place-content:center;gap:10px;color:#6b7a87;font-weight:700}table{width:100%;min-width:1120px;border-collapse:collapse;background:#fff}th,td{border-bottom:1px solid #e1e7ec;padding:8px 10px;text-align:left;font-size:13px;vertical-align:middle}th{position:sticky;top:0;z-index:1;background:#f4f7f9;color:#40505e;font-size:12px}.major{min-width:160px}.num{text-align:right;font-variant-numeric:tabular-nums}.strong{font-weight:800}.status{display:inline-flex;align-items:center;min-height:24px;border-radius:6px;padding:0 8px;font-size:12px;font-weight:800;background:#edf1f4;color:#42515f}.status.stable{background:#19563b;color:#fff}.status.expected{background:#b9e5cf;color:#16432d}.status.reach{background:#ffe28f;color:#5d4500}.status.low{background:#f4b6ad;color:#6d2118}.status.blocked{background:#f1f3f5;color:#7b8790}@media(max-width:980px){.topbar{height:auto;align-items:stretch;gap:12px;flex-direction:column;padding:14px}.top-actions{display:grid;grid-template-columns:1fr 1fr auto}.workspace{grid-template-columns:1fr}.input-pane{max-height:50vh;border-right:0;border-bottom:1px solid #d8e0e7}.filters{grid-template-columns:1fr 1fr}}@media(max-width:560px){.filters{grid-template-columns:1fr}.top-actions{grid-template-columns:1fr 1fr}.top-actions .primary{grid-column:1 / -1}}
