@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8298327da6d5bcce-s.fb2d5852.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/44fac91e6f2d2b1b-s.0a39a854.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2b402d8aebffd579-s.ec7e94a5.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/a88409fdd7dc121c-s.62b55a98.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/e8f2fbee2754df70-s.p.9b7a96b4.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Montserrat Fallback;src:local(Arial);ascent-override:85.79%;descent-override:22.25%;line-gap-override:0.0%;size-adjust:112.83%}.montserrat_a6b8e55e-module__JnHUVq__className{font-family:Montserrat,Montserrat Fallback;font-style:normal}.montserrat_a6b8e55e-module__JnHUVq__variable{--font-montserrat:"Montserrat","Montserrat Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:radial-gradient(120% 120% at 20% 20%,#f7fbff,#e4f0ff 42%,#d4e7ff 78%);--panel:#eaf4ffe6;--panel-strong:#daebfff7;--border-subtle:#5890cc47;--border-strong:#5890cc73;--text-primary:#0f2035;--text-muted:#52708f;--accent:#5ab3ff;--accent-2:#7bd3ff;--accent-3:#b7a5ff;--success:#4dbf9f;--warning:#f2b880;--danger:#ef8aa4;--radius-lg:22px;--radius-md:14px;--radius-sm:10px;--shadow-soft:0 24px 60px #75a2d638;--color-bg:var(--bg);--color-panel:var(--panel);--color-panel-strong:var(--panel-strong);--color-border:var(--border-subtle);--color-border-strong:var(--border-strong);--color-ink-900:var(--text-primary);--color-ink-700:#2a4764;--color-ink-500:var(--text-muted);--color-ink-300:#7b93ad;--color-primary:var(--accent);--color-primary-soft:#cbe6ff;--color-danger:var(--danger);--color-danger-soft:#ef8aa42e;--color-success:var(--success);--shadow-card:0 18px 40px #75a2d638}body{color:var(--color-ink-900);background:var(--color-bg)}h1,h2,h3,h4{color:var(--color-ink-900)}p{color:var(--color-ink-500)}
html,body{max-width:100vw;overflow-x:hidden}body{font-family:var(--font-montserrat),"Montserrat","Segoe UI",sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:18px;line-height:1.65}*{box-sizing:border-box;margin:0;padding:0}a{color:inherit;text-decoration:none}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-header,.app-footer{border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,var(--color-panel),var(--color-panel-strong));box-shadow:var(--shadow-card);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.app-footer{border-top:1px solid var(--color-border);color:var(--color-ink-500);border-bottom:none;margin-top:auto;font-size:14px}.app-nav{align-items:center;gap:16px;display:flex}.app-nav__logout{display:none}.app-actions__logout{display:block}.app-hamburger{cursor:pointer;background:0 0;border:none;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:46px;height:46px;transition:background .2s;display:none}.app-hamburger:hover,.app-hamburger:focus-visible{background:#ffffff26}.app-hamburger:focus-visible{outline:2px solid var(--color-ink-300);outline-offset:3px}.app-hamburger span{background:var(--color-ink-900);border-radius:999px;width:22px;height:2px;transition:transform .3s,opacity .2s;display:block}.app-hamburger--open span:first-child{transform:translateY(6px)rotate(45deg)}.app-hamburger--open span:nth-child(2){opacity:0}.app-hamburger--open span:last-child{transform:translateY(-6px)rotate(-45deg)}@media (max-width:1024px){.app-header{flex-wrap:wrap;gap:12px;position:relative}.app-hamburger{display:inline-flex}.app-nav{background:linear-gradient(135deg,var(--color-panel),var(--color-panel-strong));border:1px solid var(--color-border);box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transform-origin:top;z-index:10;border-bottom-right-radius:18px;border-bottom-left-radius:18px;flex-direction:column;align-items:flex-start;max-height:0;padding:16px 24px 20px;transition:opacity .25s,transform .25s;position:absolute;top:100%;left:0;right:0;overflow:hidden;transform:translateY(-10px)}.app-nav a{width:100%}.app-nav--open{opacity:1;pointer-events:auto;max-height:420px;overflow:auto;transform:translateY(0)}.app-actions{order:2;justify-content:flex-end;width:100%}.app-actions__logout{display:none}.app-nav__logout{text-align:center;width:100%;margin-top:16px;display:block}}.app-main{padding:24px}.admin-shell{flex-direction:column;min-height:100vh;display:flex}.admin-body{grid-template-columns:240px 1fr;gap:0 24px;min-height:calc(100vh - 96px);transition:grid-template-columns .3s;display:grid}.admin-body.admin-body--collapsed{grid-template-columns:96px 1fr}@media (max-width:1024px){.admin-body{grid-template-columns:80px 1fr}}.admin-sidebar{border:1px solid var(--color-border);background:linear-gradient(155deg,var(--color-panel),#eaf4ffb3);box-shadow:var(--shadow-card);border-radius:20px;flex-direction:column;gap:16px;width:240px;height:fit-content;max-height:calc(100vh - 40px);margin:20px;padding:20px;transition:width .3s,padding .3s;display:flex;position:sticky;top:20px;overflow-y:auto}.admin-sidebar--collapsed{width:90px;padding:20px 12px}.admin-sidebar-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding-bottom:12px;display:flex}.admin-brand{color:var(--color-ink-900);white-space:nowrap;font-size:16px;font-weight:700;overflow:hidden}.admin-sidebar-toggle{border:1px solid var(--color-border);cursor:pointer;color:var(--color-ink-700);background:#7bcaff33;border-radius:8px;flex-shrink:0;padding:6px 10px;font-size:14px;transition:all .2s}.admin-sidebar-toggle:hover{background:#7bcaff4d;transform:translateY(-1px)}.admin-nav{flex-direction:column;gap:8px;display:flex}.admin-nav-link{color:var(--color-ink-700);border:1px solid #0000;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.admin-nav-link:hover{border-color:var(--color-border);background:#7bcaff26;transform:translate(2px)}.admin-nav-link--active{color:var(--color-ink-900);background:linear-gradient(135deg,#7bcaff40,#a69bff33);border-color:#7bcaff66;font-weight:600;box-shadow:0 4px 12px #7bcaff33}.admin-nav-link--active:before{content:"";background:linear-gradient(135deg,#7bcaff,#a69bff);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.admin-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;font-size:18px;display:flex}.admin-nav-label{white-space:nowrap;overflow:hidden}.admin-sidebar--collapsed .admin-nav-link{justify-content:center;padding:12px}.admin-sidebar--collapsed .admin-nav-label{display:none}@media (max-width:1024px){.admin-body{grid-template-columns:80px 1fr}.admin-sidebar{padding:16px 12px}.admin-brand span:not(:first-child),.admin-nav-label{display:none}.admin-nav-link{justify-content:center;padding:12px}}.admin-content{padding:24px;overflow-x:hidden}.breadcrumbs{margin-bottom:20px}.breadcrumbs-list{flex-wrap:wrap;align-items:center;gap:8px;list-style:none;display:flex}.breadcrumbs-item{align-items:center;gap:8px;font-size:14px;display:flex}.breadcrumbs-link{color:var(--color-ink-500);text-decoration:none;transition:color .2s}.breadcrumbs-link:hover{color:var(--color-ink-900)}.breadcrumbs-current{color:var(--color-ink-900);font-weight:600}.breadcrumbs-separator{color:var(--color-ink-300);margin:0 4px}.toast-container{z-index:10000;flex-direction:column;gap:12px;max-width:400px;display:flex;position:fixed;top:100px;right:24px}.toast{border:1px solid var(--color-border);background:#fff;border-radius:12px;align-items:center;gap:12px;min-width:280px;padding:14px 18px;animation:.3s toastSlideIn;display:flex;box-shadow:0 8px 24px #00000026}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast--success{border-left:4px solid var(--color-success)}.toast--error{border-left:4px solid var(--color-danger)}.toast--info{border-left:4px solid var(--color-primary)}.toast--warning{border-left:4px solid var(--warning)}.toast-icon{flex-shrink:0;font-size:20px}.toast-message{color:var(--color-ink-900);flex:1;font-size:14px;line-height:1.4}.toast-close{color:var(--color-ink-500);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:20px;transition:all .2s;display:flex}.toast-close:hover{color:var(--color-ink-900);background:#0000000d}.confirm-dialog-overlay{z-index:10001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{border:1px solid var(--color-border);background:#fff;border-radius:20px;width:90%;max-width:480px;padding:28px;animation:.3s slideUp;box-shadow:0 20px 60px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-dialog-title{color:var(--color-ink-900);margin-bottom:12px;font-size:20px;font-weight:700}.confirm-dialog-message{color:var(--color-ink-700);margin-bottom:24px;line-height:1.6}.confirm-dialog-actions{justify-content:flex-end;gap:12px;display:flex}.confirm-dialog--danger .confirm-dialog-title{color:var(--color-danger)}.modal-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-content{border:1px solid var(--color-border);background:#fff;border-radius:20px;flex-direction:column;width:100%;max-width:600px;max-height:90vh;animation:.3s slideUp;display:flex;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:24px 28px;display:flex}.modal-header h2{color:var(--color-ink-900);margin:0;font-size:24px;font-weight:700}.modal-close{color:var(--color-ink-500);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;line-height:1;transition:all .2s;display:flex}.modal-close:hover{color:var(--color-ink-900);background:#0000000d}.modal-form{flex-direction:column;gap:20px;padding:28px;display:flex}.form-field{flex-direction:column;gap:8px;display:flex}.form-field span{color:var(--color-ink-700);font-size:14px;font-weight:600}.form-field--full{grid-column:1/-1}.form-helper{color:var(--color-ink-500);margin-top:-4px;font-size:12px}.modal-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;margin-top:8px;padding-top:20px;display:flex}.modal-content--large{max-width:800px;max-height:90vh}.attach-filters{grid-template-columns:2fr 1fr 1fr;gap:12px;margin-bottom:20px;display:grid}.attach-list-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px 0;display:flex}.attach-checkbox{cursor:pointer;color:var(--color-ink-700);align-items:center;gap:8px;font-weight:600;display:flex}.attach-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.attach-count{color:var(--color-ink-500);font-size:14px;font-weight:600}.attach-list{flex-direction:column;gap:8px;max-height:400px;margin-bottom:20px;display:flex;overflow-y:auto}.attach-item{border:1px solid var(--color-border);cursor:pointer;background:#fff;border-radius:12px;align-items:flex-start;gap:12px;padding:12px;transition:all .2s;display:flex}.attach-item:hover{border-color:var(--color-primary);background:#7bcaff0d}.attach-item input[type=checkbox]{cursor:pointer;flex-shrink:0;width:20px;height:20px;margin-top:2px}.attach-item-content{flex-direction:column;flex:1;gap:6px;display:flex}.attach-item-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.attach-item-header strong{color:var(--color-ink-900);font-size:16px}.attach-badges{flex-shrink:0;gap:6px;display:flex}.attach-badge{background:var(--color-primary-soft);color:var(--color-ink-700);border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.attach-badge--secondary{color:var(--color-ink-700);background:#a69bff33}.attach-item-description{color:var(--color-ink-500);margin:0;font-size:14px;line-height:1.4}.attach-item-tags{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.attach-tag{color:var(--color-ink-600);background:#7bcaff1a;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.attach-empty{text-align:center;color:var(--color-ink-500);padding:40px 20px;font-size:14px}.attachmentRemove{cursor:pointer;color:var(--color-ink-500);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:18px;line-height:1;transition:all .2s;display:flex}.attachmentRemove:hover{color:var(--color-danger);background:#ef8aa41a}@media (max-width:768px){.attach-filters{grid-template-columns:1fr}.attach-item-header{flex-direction:column;align-items:flex-start}}.ui-button{color:#0b2540;cursor:pointer;background:linear-gradient(135deg,#a8d9ff,#a693ff);border:1px solid #0000;border-radius:999px;padding:10px 16px;font-weight:700;transition:transform .12s,box-shadow .12s,border-color .12s,background .12s;box-shadow:0 12px 32px #89a2ff59}.ui-button:hover{transform:translateY(-1px)}.ui-button--secondary{color:var(--color-ink-900);border-color:var(--color-border);box-shadow:none;background:#7bcaff24}.ui-button--danger{color:var(--color-ink-900);box-shadow:none;background:#ef8aa42e;border-color:#ef8aa466}.ui-button--success{color:var(--color-ink-900);box-shadow:none;background:#4dbf9f33;border-color:#4dbf9f66}.ui-button--warning{color:var(--color-ink-900);box-shadow:none;background:#f2b88033;border-color:#f2b88066}.ui-button--info{color:var(--color-ink-900);box-shadow:none;background:#7bd3ff38;border-color:#7bd3ff66}.ui-card{border:1px solid var(--color-border);background:linear-gradient(145deg,var(--color-panel),var(--color-panel-strong));box-shadow:var(--shadow-card);border-radius:18px;padding:16px}.ui-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-ink-900);background:#e6f3fff0;height:44px;padding:10px 12px;font-size:20px}.ui-table{border:1px solid var(--color-border);border-radius:14px;overflow:hidden}.teacher-button{color:#0c1e33;cursor:pointer;z-index:10010;background:linear-gradient(135deg,#a9d4ff,#b49dff);border:none;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;transition:transform .18s,box-shadow .18s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 30px #0d203f4d}.teacher-button:focus-visible{outline-offset:4px;outline:3px solid #7bcaffe6}.teacher-button:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 18px 36px #0d203f59}.teacher-button__icon{font-size:30px}.teacher-panel{border:1px solid var(--color-border);z-index:10005;background:#fffffffa;border-radius:20px;flex-direction:column;gap:12px;width:min(420px,90vw);padding:18px 20px 24px;display:flex;position:fixed;bottom:110px;right:24px;box-shadow:0 30px 60px #0d203f59}.teacher-panel__header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.teacher-panel__title{color:var(--color-ink-900);margin:0;font-size:18px;font-weight:700}.teacher-panel__subtitle{color:var(--color-ink-500);margin:2px 0 0;font-size:13px}.teacher-panel__close{cursor:pointer;color:var(--color-ink-500);background:0 0;border:none;border-radius:50%;min-width:32px;min-height:32px;padding:0;font-size:20px;line-height:1;transition:background .12s}.teacher-panel__close:hover{background:#0000000d}.teacher-panel__selectors{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.teacher-panel__label{color:var(--color-ink-700);flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.teacher-panel__label select{border:1px solid var(--color-border);color:var(--color-ink-900);background:#f5f8ffe6;border-radius:12px;padding:8px 10px;font-size:14px}.teacher-panel__word-list{flex-direction:column;gap:14px;max-height:320px;margin-top:6px;padding-right:4px;display:flex;overflow-y:auto}.teacher-panel__word-row{flex-direction:column;gap:6px;display:flex}.teacher-panel__word-label{color:var(--color-ink-500);font-size:12px}.teacher-panel__send{color:#0d1b39;cursor:pointer;background:linear-gradient(135deg,#7bc3ff,#a69bff);border:none;border-radius:12px;margin-top:6px;padding:12px 0;font-weight:700;transition:transform .13s,box-shadow .13s}.teacher-panel__send:hover{transform:translateY(-1px);box-shadow:0 16px 30px #0d203f40}@media (max-width:780px){.teacher-button{bottom:20px;right:16px}.teacher-panel{width:calc(100% - 32px);bottom:90px;right:16px}}
