@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700;800&display=swap";:root{color:#172033;font-synthesis:none;background:#f7f9fc;font-family:Noto Sans KR,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{z-index:5;background:#fff;border-right:1px solid #e8edf5;flex-direction:column;width:248px;padding:25px 17px;display:flex;position:fixed;inset:0 auto 0 0}.brand{letter-spacing:-.7px;align-items:center;gap:10px;font-size:19px;display:flex}.brand>span{color:#fff;background:#356df3;border-radius:10px;place-items:center;width:34px;height:34px;display:grid}.sidebar nav{gap:5px;margin-top:35px;display:grid}.sidebar nav button{color:#667085;text-align:left;background:0 0;border:0;border-radius:9px;align-items:center;gap:11px;padding:11px 13px;font-size:14px;font-weight:600;display:flex}.sidebar nav button:hover,.sidebar nav button.active{color:#245bd7;background:#edf3ff}.student-mode{color:#3564c7;text-align:left;background:#f6f9ff;border:1px solid #dbe5f8;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:9px;margin-top:auto;padding:12px;display:grid}.student-mode span{gap:2px;display:grid}.student-mode strong{font-size:12px}.student-mode small{color:#8193b5;font-size:10px}.profile{border-top:1px solid #edf0f5;align-items:center;gap:10px;margin-top:16px;padding-top:16px;display:flex}.profile>span{color:#3564c7;background:#e9efff;border-radius:50%;place-items:center;width:34px;height:34px;font-weight:700;display:grid}.profile div{display:grid}.profile strong{font-size:12px}.profile small{color:#98a2b3;margin-top:2px;font-size:10px}.profile-button{text-align:left;color:#667085;background:0 0;border:0;width:100%}.profile-button div{flex:1}.profile-button:hover{color:#356df3}.app-shell>main{grid-column:2;min-width:0}.topbar{z-index:4;background:#fff;border-bottom:1px solid #e8edf5;justify-content:space-between;align-items:center;height:91px;padding:0 34px;display:flex;position:sticky;top:0}.topbar p{color:#98a2b3;margin:0 0 4px;font-size:11px;font-weight:600}.topbar h1{letter-spacing:-.6px;margin:0;font-size:21px}.top-actions{align-items:center;gap:9px;display:flex}.top-actions select{width:160px}.button{border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:39px;padding:0 15px;font-size:13px;font-weight:700;transition:all .18s;display:inline-flex}.button.primary{color:#fff;background:#356df3;box-shadow:0 4px 12px #356df32e}.button.primary:hover{background:#265ddd;transform:translateY(-1px)}.button.secondary{color:#4b5565;background:#fff;border-color:#dce2eb}.button.ghost{color:#667085;background:0 0}.button.danger{color:#cf3f4c;background:#fff0f1}.button:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.content{max-width:1520px;margin:0 auto;padding:28px 34px 45px}.welcome{color:#fff;background:#245fd7;border-radius:14px;justify-content:space-between;align-items:center;min-height:139px;padding:28px 31px;display:flex;box-shadow:0 10px 25px #1f56c426}.welcome h2{letter-spacing:-.8px;margin:0 0 8px;font-size:22px}.welcome p{color:#dbe7ff;margin:0;font-size:13px}.welcome .button{color:#245bd7;box-shadow:none;background:#fff}.stat-row{grid-template-columns:repeat(3,1fr);gap:15px;margin:19px 0;display:grid}.stat-row button{text-align:left;color:#98a2b3;background:#fff;border:1px solid #e7ebf2;border-radius:12px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:18px;display:grid}.stat-row button:hover{border-color:#bfd0f7;box-shadow:0 6px 18px #18274b0f}.stat-row button div{gap:4px;display:grid}.stat-row small{color:#7c8799;font-size:11px}.stat-row strong{color:#172033;font-size:21px}.stat-icon{border-radius:10px;place-items:center;width:42px;height:42px;display:grid}.stat-icon svg{width:19px}.stat-icon.blue{color:#356df3;background:#edf3ff}.stat-icon.green{color:#20a274;background:#e9f8f2}.stat-icon.violet{color:#7758d6;background:#f2edff}.dashboard-grid{grid-template-columns:1.3fr 1fr;gap:19px;display:grid}.panel{background:#fff;border:1px solid #e7ebf2;border-radius:13px;padding:22px}.panel.fill{min-height:calc(100vh - 155px)}.panel-head{justify-content:space-between;align-items:center;gap:20px;margin-bottom:20px;display:flex}.panel-head h3{letter-spacing:-.3px;margin:0 0 4px;font-size:15px}.panel-head p{color:#98a2b3;margin:0;font-size:11px}.panel-head>button{color:#667085;background:0 0;border:0;align-items:center;font-size:11px;font-weight:600;display:flex}.compact-list,.class-compact{display:grid}.media-row{text-align:left;color:#98a2b3;background:0 0;border:0;border-top:1px solid #eef1f5;grid-template-columns:auto 1fr auto;align-items:center;gap:11px;width:100%;padding:11px 4px;display:grid}.media-row:hover{background:#f8faff}.media-row>span{color:#356df3;background:#edf3ff;border-radius:8px;place-items:center;width:35px;height:35px;display:grid}.media-row div{gap:3px;display:grid}.media-row strong{color:#344054;font-size:12px}.media-row small{color:#98a2b3;font-size:10px}.class-compact>div{border-top:1px solid #eef1f5;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:11px 3px;display:grid}.class-compact>div>span,.class-letter{color:#567099;background:#eff3fa;border-radius:9px;place-items:center;width:35px;height:35px;font-weight:800;display:grid}.class-compact div div{gap:3px;display:grid}.class-compact strong{font-size:12px}.class-compact small,.class-compact p{color:#98a2b3;margin:0;font-size:10px}.class-compact p b{color:#356df3}.empty{text-align:center;color:#98a2b3;flex-direction:column;justify-content:center;align-items:center;min-height:260px;display:flex}.empty>span{background:#f2f5f9;border-radius:50%;place-items:center;width:50px;height:50px;margin-bottom:12px;display:grid}.empty strong{color:#4b5565;font-size:14px}.empty p{margin:6px 0 0;font-size:11px}.class-table{gap:1px;display:grid}.class-table article{border-top:1px solid #eef1f5;align-items:center;gap:14px;padding:16px 5px;display:flex}.class-table .grow{flex:1}.class-table h3{margin:0 0 4px;font-size:13px}.class-table p{color:#98a2b3;margin:0;font-size:11px}.class-meta{color:#7c8799;gap:22px;font-size:11px;display:flex}.class-meta strong{color:#344054}.icon-button{color:#98a2b3;background:0 0;border:0;border-radius:7px;place-items:center;width:34px;height:34px;display:grid}.icon-button:hover{color:#344054;background:#f3f5f8}.danger-icon:hover{color:#d14352;background:#fff0f1}.search{color:#98a2b3;border:1px solid #dce2eb;border-radius:8px;align-items:center;gap:8px;width:230px;height:37px;padding:0 11px;display:flex}.search input{border:0;outline:0;width:100%;font-size:11px}.data-table{width:100%}.table-row{color:#667085;border-top:1px solid #eef1f5;grid-template-columns:1.1fr 1.2fr 1fr 1fr 40px;align-items:center;gap:15px;min-height:58px;font-size:11px;display:grid}.table-header{color:#98a2b3;min-height:35px;font-size:10px;font-weight:700}.person{align-items:center;gap:10px;display:flex}.person b{color:#356df3;background:#edf3ff;border-radius:50%;place-items:center;width:31px;height:31px;display:grid}.person strong{color:#344054}.media-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;display:grid}.media-card{background:#fff;border:1px solid #e4e9f1;border-radius:11px;transition:all .2s;overflow:hidden}.media-card:hover{transform:translateY(-2px);box-shadow:0 9px 24px #18274b14}.media-preview-button{background:#eef2f7;border:0;width:100%;padding:0;display:block;overflow:hidden}.media-preview-button>img,.video-preview,.file-preview{aspect-ratio:16/10;object-fit:cover;background:#eef2f7;justify-content:center;align-items:center;width:100%;display:flex}.media-preview-button:hover img,.media-preview-button:hover video{transform:scale(1.02)}.media-preview-button img,.media-preview-button video{transition:transform .2s}.video-preview{color:#fff;position:relative}.video-preview video{object-fit:cover;width:100%;height:100%}.video-preview>svg{background:#172033b3;border-radius:50%;width:48px;height:48px;padding:9px;position:absolute}.file-preview{color:#8190a5;flex-direction:column;gap:7px;font-size:11px}.media-body{flex-direction:column;justify-content:space-between;min-height:145px;padding:14px;display:flex}.media-body small{color:#356df3;font-size:10px;font-weight:700}.media-body h3{margin:5px 0;font-size:13px}.media-body p{color:#8a95a6;margin:0;font-size:10px;line-height:1.6}.media-foot{color:#98a2b3;border-top:1px solid #eef1f5;justify-content:space-between;align-items:center;margin-top:14px;padding-top:10px;font-size:9px;display:flex}.modal-backdrop{z-index:20;background:#18203061;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:#fff;border-radius:14px;width:min(470px,100%);max-height:92vh;padding:24px;overflow:auto;box-shadow:0 20px 60px #18274b33}.modal-head{justify-content:space-between;gap:20px;display:flex}.modal-head h2{margin:0 0 6px;font-size:18px}.modal-head p{color:#98a2b3;margin:0;font-size:11px}.modal form,.login-card form{gap:15px;margin-top:24px;display:grid}.modal label,.login-card label{color:#4b5565;gap:7px;font-size:11px;font-weight:700;display:grid}input,select,textarea{color:#344054;background:#fff;border:1px solid #dce2eb;border-radius:8px;outline:none;width:100%;padding:10px 11px;font-size:12px}input:focus,select:focus,textarea:focus{border-color:#83a7fb;box-shadow:0 0 0 3px #edf3ff}textarea{resize:vertical;min-height:75px}.upload-field{background:#f8faff;border:1px dashed #b9c8e5;border-radius:9px;justify-content:center;align-items:center;min-height:125px;position:relative;color:#356df3!important;display:flex!important}.upload-field input{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-field span{color:#98a2b3;font-size:10px;font-weight:400}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.error{color:#bd3947;background:#fff0f1;border-radius:7px;margin:0;padding:9px 10px;font-size:11px}.toast{z-index:30;color:#fff;background:#172033;border-radius:8px;padding:11px 16px;font-size:11px;position:fixed;bottom:25px;right:25px;box-shadow:0 8px 25px #18203033}.confirm-modal{text-align:center;width:min(380px,100%)}.confirm-modal h2{margin:14px 0 6px;font-size:18px}.confirm-modal p{color:#7c8799;margin:0 0 22px;font-size:11px;line-height:1.6}.confirm-modal p strong{color:#344054}.confirm-modal .form-actions{justify-content:center}.confirm-icon{color:#cf3f4c;background:#fff0f1;border-radius:50%;place-items:center;width:52px;height:52px;margin:auto;display:grid}.media-viewer-backdrop{background:#111827b8;padding:28px}.media-viewer{background:#fff;border-radius:14px;flex-direction:column;width:min(1100px,100%);max-height:calc(100vh - 56px);display:flex;overflow:hidden;box-shadow:0 25px 80px #0000004d}.media-viewer-head{border-bottom:1px solid #e7ebf2;justify-content:space-between;align-items:center;gap:20px;min-height:68px;padding:14px 18px;display:flex}.media-viewer-head h2{margin:0 0 4px;font-size:15px}.media-viewer-head p{color:#98a2b3;margin:0;font-size:10px}.media-viewer-content{background:#111827;flex:1;place-items:center;min-height:0;display:grid;overflow:auto}.media-viewer-content img,.media-viewer-content video{object-fit:contain;max-width:100%;max-height:calc(100vh - 125px);display:block}.route-loading{color:#356df3;place-items:center;min-height:100vh;display:grid}.route-loading svg{width:42px;height:42px;animation:1s ease-in-out infinite pulse}@keyframes pulse{50%{opacity:.35;transform:scale(.94)}}.login-page{background:#f4f7fc;place-items:center;min-height:100vh;padding:25px;display:grid;position:relative}.back-admin{color:#667085;background:0 0;border:0;align-items:center;gap:5px;font-size:11px;display:flex;position:absolute;top:23px;left:24px;transform:rotate(180deg)}.back-admin svg{transform:rotate(180deg)}.login-card{background:#fff;border:1px solid #e5eaf2;border-radius:17px;width:min(410px,100%);padding:34px;box-shadow:0 16px 45px #18274b14}.login-brand{text-align:center}.login-brand>span{color:#fff;background:#356df3;border-radius:13px;place-items:center;width:48px;height:48px;margin:auto;display:grid}.login-brand h1{margin:13px 0 5px;font-size:22px}.login-brand p{color:#98a2b3;margin:0;font-size:11px}.login-card .button{width:100%;margin-top:5px}.phone-input{grid-template-columns:auto 1fr auto;align-items:center;gap:8px;display:grid}.phone-input span{color:#98a2b3;background:#f2f4f7;border-radius:8px;place-items:center;min-height:39px;padding:0 12px;font-size:12px;display:grid}.login-card label small{color:#98a2b3;font-size:9px;font-weight:400}.student-portal{background:#f7f9fc;min-height:100vh}.student-portal>header{background:#fff;border-bottom:1px solid #e7ebf2;justify-content:space-between;align-items:center;height:70px;padding:0 max(25px,50vw - 560px);display:flex}.student-content{max-width:1120px;margin:auto;padding:30px 25px 55px}.student-welcome{background:#fff;border:1px solid #e4e9f1;border-radius:14px;justify-content:space-between;align-items:center;min-height:150px;padding:30px;display:flex}.student-welcome p{color:#356df3;margin:0 0 7px;font-size:11px;font-weight:700}.student-welcome h1{margin:0 0 8px;font-size:22px}.student-welcome span{color:#98a2b3;font-size:11px}.student-welcome>div:last-child{color:#356df3;background:#edf3ff;border-radius:18px;place-items:center;width:66px;height:66px;display:grid}.student-heading{align-items:center;gap:8px;margin:28px 0 14px;display:flex}.student-heading h2{margin:0;font-size:16px}.student-heading span{color:#356df3;background:#edf3ff;border-radius:10px;padding:3px 7px;font-size:10px}.handwriting-page{gap:18px;display:grid}.handwriting-result{min-height:390px}.handwriting-result>img{object-fit:contain;background:#f4f6f9;border:1px solid #e4e9f1;border-radius:10px;max-width:100%;max-height:780px;margin:0 auto;display:block}.result-actions{gap:8px;display:flex}.material-save-fields{grid-template-columns:1fr 1fr;gap:10px;margin-top:15px;display:grid}.handwriting-workspace{grid-template-columns:280px minmax(0,1fr);align-items:start;gap:18px;display:grid}.codex-connect{gap:16px;display:grid}.codex-connect>div{grid-template-columns:auto 1fr;column-gap:8px;display:grid}.codex-connect strong{font-size:13px}.codex-connect p{color:#98a2b3;grid-column:2;margin:4px 0 0;font-size:10px;line-height:1.5}.codex-connect .button{width:100%}.connected-dot{background:#20a274;border-radius:50%;width:9px;height:9px;margin-top:5px;box-shadow:0 0 0 4px #e9f8f2}.connected-dot.off{background:#98a2b3;box-shadow:0 0 0 4px #f0f2f5}.handwriting-form{gap:15px;display:grid}.handwriting-form>label{color:#4b5565;gap:7px;font-size:11px;font-weight:700;display:grid}.handwriting-form textarea{min-height:115px}.handwriting-form>.button{min-height:46px}.model-pill{color:#356df3;background:#edf3ff;border-radius:20px;padding:6px 10px;font-size:10px;font-weight:700}.problem-upload{text-align:center;background:#f8faff;border:1px dashed #b9c8e5;border-radius:11px;justify-content:center;align-items:center;min-height:220px;position:relative;overflow:hidden;color:#356df3!important;display:flex!important}.problem-upload input{opacity:0;cursor:pointer;z-index:2;position:absolute;inset:0}.problem-upload span{color:#98a2b3;font-size:10px;font-weight:400}.problem-upload img{object-fit:contain;width:100%;max-height:420px;display:block}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1000px){.media-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.stat-row{gap:9px}.stat-row button{padding:14px}}@media (width<=760px){.app-shell{display:block}.sidebar{z-index:10;border:1px solid #e7ebf2;flex-direction:row;width:auto;height:65px;padding:7px 10px;position:fixed;inset:auto 0 0}.sidebar .brand,.student-mode,.profile{display:none}.sidebar nav{grid-template-columns:repeat(5,1fr);gap:2px;width:100%;margin:0}.sidebar nav button{flex-direction:column;justify-content:center;gap:2px;padding:5px 3px;font-size:9px}.topbar{align-items:flex-start;gap:10px;height:auto;min-height:82px;padding:14px 16px}.topbar h1{font-size:18px}.top-actions{flex-wrap:wrap;justify-content:flex-end}.top-actions select{width:125px}.content{padding:15px 12px 90px}.welcome{flex-direction:column;align-items:flex-start;gap:20px;padding:21px}.welcome h2{font-size:18px}.stat-row{grid-template-columns:1fr}.dashboard-grid{gap:12px}.panel{padding:16px}.panel-head{align-items:flex-start}.panel-head .search{width:155px}.class-meta{display:none}.table-row{grid-template-columns:1fr 1fr 38px}.table-row span:nth-child(3),.table-row span:nth-child(4){display:none}.media-grid{grid-template-columns:1fr}.login-card{padding:26px 21px}.student-content{padding:18px 12px 45px}.student-welcome{padding:22px}.student-welcome>div:last-child{display:none}.media-viewer-backdrop{padding:10px}.media-viewer{max-height:calc(100vh - 20px)}.media-viewer-head{padding:11px 12px}.media-viewer-content img,.media-viewer-content video{max-height:calc(100vh - 95px)}.handwriting-workspace{grid-template-columns:1fr}.result-actions{flex-wrap:wrap;width:100%}.material-save-fields{grid-template-columns:1fr}}
