:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#app{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.class-header[data-v-4ab5aee4]{background:#f5f5f5;border-bottom:1px solid #ddd;flex-wrap:wrap;justify-content:center;gap:1rem;padding:.75rem 1rem;display:flex}.field-group[data-v-4ab5aee4]{align-items:center;gap:.35rem;display:flex}.label[data-v-4ab5aee4]{color:#666;white-space:nowrap;font-size:.9rem;font-weight:500}.field[data-v-4ab5aee4]{background:#fff;border:1px solid #ccc;border-radius:4px;outline:none;min-width:140px;padding:.3rem .5rem;font-size:.95rem}.field.short[data-v-4ab5aee4]{min-width:100px;max-width:120px}.field[data-v-4ab5aee4]:focus{border-color:#4a9eff;box-shadow:0 0 0 2px #4a9eff26}.score-input[data-v-fedfab65]{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;padding:2rem 1rem;display:flex}.student-info[data-v-fedfab65]{align-items:center;gap:.75rem;height:6rem;margin-bottom:1.5rem;display:flex}.group-badge[data-v-fedfab65]{color:#6b4eff;background:#e8e0ff;border-radius:4px;padding:.2rem .5rem;font-size:.8rem;font-weight:600}.index-badge[data-v-fedfab65]{color:#fff;background:#4a9eff;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.85rem;font-weight:600;display:flex}.name[data-v-fedfab65]{color:#000;font-size:5rem;font-weight:700}.id[data-v-fedfab65]{color:#ff2121;font-size:2rem}.empty-hint[data-v-fedfab65]{color:#aaa;font-size:1rem}.slots[data-v-fedfab65]{align-items:center;gap:.5rem;margin-bottom:1rem;font-family:Courier New,monospace;font-size:2.4rem;font-weight:700;display:flex}.slot[data-v-fedfab65]{background:#fafafa;border:2px solid #ccc;border-radius:6px;justify-content:center;align-items:center;width:4rem;height:3.2rem;transition:border-color .15s;display:inline-flex}.slot.active[data-v-fedfab65]{background:#f0f6ff;border-color:#4a9eff}.sep[data-v-fedfab65]{color:#bbb;font-size:1.8rem}.progress-bar-wrap[data-v-fedfab65]{width:100%;max-width:300px;margin-bottom:.5rem}.progress-bar[data-v-fedfab65]{background:#e0e0e0;border-radius:3px;height:6px;overflow:hidden}.progress-fill[data-v-fedfab65]{background:#4a9eff;border-radius:3px;height:100%;transition:width .3s}.progress-text[data-v-fedfab65]{color:#999;text-align:center;margin-top:.3rem;font-size:.8rem;display:block}.order-btn[data-v-fedfab65]{cursor:pointer;color:#666;background:#fff;border:1px solid #ccc;border-radius:4px;padding:.2rem .6rem;font-size:.8rem}.order-btn[data-v-fedfab65]:hover{color:#4a9eff;border-color:#4a9eff}.tts-btn[data-v-fedfab65]{cursor:pointer;opacity:.5;background:0 0;border:none;padding:.2rem;font-size:1.2rem;line-height:1;transition:opacity .15s}.tts-btn.on[data-v-fedfab65]{opacity:1}.tts-settings-btn[data-v-fedfab65]{cursor:pointer;color:#999;background:0 0;border:none;padding:.2rem;font-size:.7rem;line-height:1}.tts-settings[data-v-fedfab65]{background:#fafafa;border:1px solid #e0e0e0;border-radius:6px;width:100%;max-width:320px;margin-top:1rem;padding:.75rem}.tts-row[data-v-fedfab65]{align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.tts-row[data-v-fedfab65]:last-child{margin-bottom:0}.tts-label[data-v-fedfab65]{color:#888;flex-shrink:0;width:2.5rem;font-size:.8rem}.tts-select[data-v-fedfab65]{border:1px solid #ccc;border-radius:4px;flex:1;padding:.2rem .3rem;font-size:.8rem}.tts-slider[data-v-fedfab65]{accent-color:#4a9eff;flex:1}.tts-rate[data-v-fedfab65]{color:#666;text-align:right;width:2.5rem;font-size:.8rem}.grade-map[data-v-d7065e24]{border-top:1px solid #eee}.table-wrap[data-v-d7065e24]{max-width:640px;max-height:400px;margin:2rem auto;overflow-y:auto}table[data-v-d7065e24]{border-collapse:collapse;width:100%;font-size:.8rem}th[data-v-d7065e24]{text-align:center;color:#666;white-space:nowrap;background:#f5f5f5;border-bottom:1px solid #ddd;padding:.4rem .35rem;font-weight:600;position:sticky;top:0}td[data-v-d7065e24]{text-align:center;cursor:pointer;border-bottom:1px solid #eee;padding:.35rem;transition:background .1s}tr:hover td[data-v-d7065e24]{background:#f0f6ff}tr.active td[data-v-d7065e24]{background:#dceaff!important}tr.empty td[data-v-d7065e24]{color:#bbb;background:#f7f7f7}tr.partial td[data-v-d7065e24]{background:#fffde7}tr.done td[data-v-d7065e24]{background:#e8f5e9}.col-group[data-v-d7065e24]{width:10%}.col-id[data-v-d7065e24]{width:18%}.col-name[data-v-d7065e24]{text-align:left;width:16%;font-weight:600}.col-score[data-v-d7065e24]{width:12%}.col-total[data-v-d7065e24]{width:12%;font-weight:700}.export-area[data-v-0242aeb3]{text-align:center;padding:.75rem 1rem}.export-btn[data-v-0242aeb3]{color:#fff;cursor:pointer;background:#4a9eff;border:none;border-radius:6px;padding:.5rem 1.5rem;font-size:1rem;font-weight:600}.export-btn[data-v-0242aeb3]:hover{background:#3a8eef}.start-screen[data-v-d7307371]{max-width:640px;margin:auto;padding:1.5rem 1rem}.section[data-v-d7307371]{margin-bottom:2rem}.section h2[data-v-d7307371]{color:#555;margin:0 0 .75rem;font-size:1.1rem}.new-form[data-v-d7307371]{gap:.5rem;display:flex}.class-select[data-v-d7307371]{background:#fff;border:1px solid #ccc;border-radius:4px;flex:1;padding:.5rem;font-size:1rem}.btn[data-v-d7307371]{cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:.5rem 1.2rem;font-size:1rem;font-weight:600}.btn.primary[data-v-d7307371]{color:#fff;background:#4a9eff}.btn.primary[data-v-d7307371]:disabled{opacity:.5;cursor:default}.session-list[data-v-d7307371]{flex-direction:column;gap:.5rem;display:flex}.session-card[data-v-d7307371]{cursor:pointer;text-align:left;background:#fff;border:1px solid #e0e0e0;border-radius:6px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.95rem;transition:border-color .15s;display:flex}.session-card[data-v-d7307371]:hover{border-color:#4a9eff}.sc-class[data-v-d7307371]{flex:1;font-weight:600}.sc-time[data-v-d7307371]{color:#888;font-size:.85rem}.sc-progress[data-v-d7307371]{color:#2e7d32;background:#e8f5e9;border-radius:4px;padding:.15rem .5rem;font-size:.8rem;font-weight:600}.guide-body[data-v-d7307371]{color:#555;text-align:justify;font-size:.85rem;line-height:1.6}.guide-body h3[data-v-d7307371]{color:#444;margin:.75rem 0 .35rem;font-size:.9rem;font-weight:600}.guide-body p[data-v-d7307371]{margin:0 0 .5rem}.guide-body .example[data-v-d7307371]{background:#f5f5f5;border-radius:4px;margin:.3rem 0 .6rem 1rem;padding:.35rem .6rem;font-size:.82rem}.guide-body .example code[data-v-d7307371]{color:#4a9eff;letter-spacing:.1em;font-weight:700}.guide-body ul[data-v-d7307371]{margin:.3rem 0 .6rem 1rem;padding:0;list-style:none}.guide-body li[data-v-d7307371]{margin-bottom:.25rem}.guide-body li[data-v-d7307371]:before{content:"·";color:#4a9eff;margin-right:.4rem}.guide-body code[data-v-d7307371]{color:#d63384;font-family:Courier New,monospace}.history-screen[data-v-7e4913bc]{max-width:640px;margin:0 auto;padding:1.5rem 1rem}.history-screen h2[data-v-7e4913bc]{color:#555;margin:0 0 1rem;font-size:1.1rem}.empty[data-v-7e4913bc]{color:#aaa;text-align:center;padding:2rem 0}.list[data-v-7e4913bc]{flex-direction:column;gap:.5rem;display:flex}.hist-card[data-v-7e4913bc]{cursor:pointer;text-align:left;border:1px solid #e0e0e0;border-radius:6px;padding:.75rem 1rem;transition:border-color .15s}.hist-card[data-v-7e4913bc]:hover{border-color:#4a9eff}.hc-top[data-v-7e4913bc]{align-items:center;gap:.75rem;margin-bottom:.3rem;display:flex}.hc-class[data-v-7e4913bc]{flex:1;font-weight:600}.hc-time[data-v-7e4913bc]{color:#888;font-size:.8rem}.hc-del[data-v-7e4913bc]{color:#ccc;cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:.9rem;line-height:1}.hc-del[data-v-7e4913bc]:hover{color:#e53935}.hc-bottom[data-v-7e4913bc]{color:#888;align-items:center;gap:.75rem;font-size:.85rem;display:flex}.hc-exp[data-v-7e4913bc]{flex:1}.hc-progress[data-v-7e4913bc]{color:#2e7d32;background:#e8f5e9;border-radius:4px;padding:.1rem .5rem;font-size:.8rem;font-weight:600}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.app[data-v-b11bd550]{z-index:0;background:0 0;flex-direction:column;width:1200px;min-height:100vh;margin:0 auto;display:flex;position:relative}.content[data-v-b11bd550]{flex:1}.site-header[data-v-b11bd550]{text-align:center;letter-spacing:.1em;-webkit-text-fill-color:transparent;background:#fafafa linear-gradient(90deg,#4a9eff,#6b4eff,#e53935,#ff8f00);-webkit-background-clip:text;background-clip:text;border-bottom:1px solid #eee;padding:1rem;font-size:1.2rem;font-weight:700}.tabs[data-v-b11bd550]{background:#f5f5f5;border-bottom:1px solid #ddd;display:flex}.tabs button[data-v-b11bd550]{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.65rem 0;font-size:.95rem;font-weight:600;transition:all .15s}.tabs button.active[data-v-b11bd550]{color:#4a9eff;background:#fff;border-bottom-color:#4a9eff}.tabs button[data-v-b11bd550]:disabled{opacity:.4;cursor:default}.bg-stack[data-v-b11bd550]{z-index:-10;position:fixed;inset:0}.bg-img[data-v-b11bd550]{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity 1.5s;position:absolute;inset:0}.bg-img.active[data-v-b11bd550]{opacity:1}.site-footer[data-v-b11bd550]{text-align:center;color:#bbb;padding:1.5rem 1rem .8rem;font-size:.75rem}.bg-overlay[data-v-b11bd550]{z-index:-9;background:#ffffffd9;position:fixed;inset:0}.mobile-block[data-v-b11bd550]{z-index:9999;background:#fff;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.mobile-msg[data-v-b11bd550]{text-align:center;max-width:360px;padding:2rem}.mobile-msg h1[data-v-b11bd550]{color:#333;margin-bottom:1rem;font-size:1.4rem}.mobile-msg p[data-v-b11bd550]{color:#666;font-size:.95rem;line-height:1.6}
