:root{--text:#2b2b32;--text-h:#08060d;--bg:#fafafa;--border:#e5e4e7;--accent:#57c;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/145% var(--sans);letter-spacing:.18px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{background:var(--bg);width:100%;max-width:100vw;margin:0;padding:0;overflow-x:hidden}#root{text-align:left;box-sizing:border-box;width:100%;max-width:100%;min-height:100svh;margin:0;display:block}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:600}p{margin:0}*,:before,:after{box-sizing:border-box}._page_fxvvb_2{color:#222;box-sizing:border-box;background:#fafafa;justify-content:center;min-height:100vh;padding:1.5rem;font-family:system-ui,Segoe UI,Roboto,sans-serif;display:flex}._title_fxvvb_13{margin:0 0 .5rem;font-size:1.6rem;font-weight:600}._subtitle_fxvvb_19{color:#555;margin:0 0 1.25rem}._muted_fxvvb_24{color:#888}._errorText_fxvvb_28{color:#dc143c;margin:.5rem 0 0}._errorTextSmall_fxvvb_33{color:#dc143c;text-align:center;padding:.25rem;font-size:.75rem}._primaryBtn_fxvvb_40{color:#fff;cursor:pointer;background:#57c;border:none;border-radius:8px;padding:.7rem 1.4rem;font-size:1rem;font-weight:600;transition:background .12s}._primaryBtn_fxvvb_40:hover:not(:disabled){background:#46b}._primaryBtn_fxvvb_40:disabled{cursor:not-allowed;background:#aab}._backBtn_fxvvb_59{color:#444;cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:6px;padding:.4rem .8rem;font-size:.85rem}._backBtn_fxvvb_59:hover{background:#f3f3f3}._sourceCard_fxvvb_73{width:100%;max-width:720px}._sourceButtons_fxvvb_78{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}._sourceBtn_fxvvb_84{cursor:pointer;font:inherit;color:inherit;background:#fff;border:1px solid #ddd;border-radius:12px;flex-direction:column;align-items:center;gap:.4rem;padding:1.5rem .5rem;transition:transform .12s,border-color .12s,background .12s;display:flex}._sourceBtn_fxvvb_84:hover:not(:disabled){background:#f4f8ff;border-color:#57c;transform:translateY(-1px)}._sourceBtn_fxvvb_84:disabled{opacity:.55;cursor:not-allowed}._sourceBtnIcon_fxvvb_108{font-size:2rem}._sourceBtnLabel_fxvvb_111{font-size:1.05rem;font-weight:600}._sourceBtnHint_fxvvb_115{color:#666;text-align:center;font-size:.78rem}._modalScrim_fxvvb_122{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}._modal_fxvvb_122{box-sizing:border-box;background:#fff;border-radius:12px;width:100%;max-width:920px;max-height:92vh;padding:1.25rem;overflow:auto}._modalHeader_fxvvb_144{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}._modalHeader_fxvvb_144 h2{margin:0;font-size:1.2rem}._modalClose_fxvvb_154{cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:6px;width:32px;height:32px;font-size:1rem}._modalClose_fxvvb_154:hover{background:#f3f3f3}._galleryGroups_fxvvb_167{flex-direction:column;gap:1.25rem;display:flex}._galleryGroup_fxvvb_167{flex-direction:column;gap:.5rem;display:flex}._galleryGroupLabel_fxvvb_179{color:#57c;margin:0;font-size:.95rem;font-weight:600}._galleryCategories_fxvvb_186{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem;display:grid}._galleryCategoryBtn_fxvvb_192{cursor:pointer;font:inherit;color:inherit;background:#fff;border:1px solid #ddd;border-radius:10px;flex-direction:column;align-items:center;gap:.25rem;padding:.7rem .5rem;transition:transform .12s,border-color .12s;display:flex}._galleryCategoryBtn_fxvvb_192:hover:not(:disabled){border-color:#57c;transform:translateY(-1px)}._galleryCategoryBtn_fxvvb_192:disabled{opacity:.4;cursor:not-allowed}._galleryCategoryIcon_fxvvb_215{font-size:1.5rem}._galleryCategoryLabel_fxvvb_218{text-align:center;font-size:.9rem}._galleryCategoryCount_fxvvb_222{color:#888;font-size:.7rem}._galleryDetail_fxvvb_227{flex-direction:column;gap:.75rem;display:flex}._galleryCategoryTitle_fxvvb_233{margin:0;font-size:1.05rem}._galleryPhotosGrid_fxvvb_238{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;display:grid}._galleryPhotoBtn_fxvvb_244{cursor:pointer;aspect-ratio:1;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;padding:0;transition:transform .12s,border-color .12s;overflow:hidden}._galleryPhotoBtn_fxvvb_244:hover:not(:disabled){border-color:#57c;transform:translateY(-1px)}._galleryPhotoBtn_fxvvb_244:disabled{opacity:.55;cursor:not-allowed}._galleryPhotoBtn_fxvvb_244 img{object-fit:cover;width:100%;height:100%;display:block}._levelsCard_fxvvb_270{width:100%;max-width:1100px}._levelsHeader_fxvvb_275{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}._previewRow_fxvvb_282{background:#fff;border:1px solid #e3e3e3;border-radius:12px;align-items:flex-start;gap:1rem;margin-bottom:1rem;padding:.75rem;display:flex}._preview_fxvvb_282{object-fit:cover;background:#f5f5f5;border-radius:8px;width:140px;height:140px}._levelGrid_fxvvb_301{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;display:grid}._levelCard_fxvvb_307{cursor:pointer;font:inherit;color:inherit;text-align:left;background:#fff;border:2px solid #ddd;border-radius:12px;flex-direction:column;align-items:stretch;gap:.5rem;padding:.75rem;transition:border-color .12s,transform .12s,background .12s;display:flex}._levelCard_fxvvb_307:hover:not(:disabled){border-color:#8af;transform:translateY(-2px)}._levelCardActive_fxvvb_326{box-shadow:0 4px 14px #5577cc2e;background:#eef3ff!important;border-color:#57c!important}._levelCard_fxvvb_307:disabled{opacity:.65;cursor:progress}._levelCardCanvas_fxvvb_336{background:#fff;border:1px solid #eee;border-radius:6px;justify-content:center;align-items:center;min-height:180px;margin:0 auto;display:flex;overflow:hidden}._levelCardMeta_fxvvb_348{flex-direction:column;gap:.1rem;display:flex}._levelCardCode_fxvvb_353{color:#57c;letter-spacing:.05em;font-size:.75rem;font-weight:600}._levelCardTitle_fxvvb_359{font-size:1rem;font-weight:600}._levelCardSubtitle_fxvvb_363{color:#666;font-size:.78rem;line-height:1.25}._levelsFooter_fxvvb_369{justify-content:center;margin-top:1rem;display:flex}@media (width<=640px){._page_fxvvb_2{padding:.75rem}._title_fxvvb_13{font-size:1.3rem}._sourceButtons_fxvvb_78{grid-template-columns:1fr}._sourceBtn_fxvvb_84{text-align:left;flex-direction:row;justify-content:flex-start;gap:.75rem;padding:1rem}._sourceBtnIcon_fxvvb_108{font-size:1.6rem}._sourceBtnHint_fxvvb_115{text-align:left}._previewRow_fxvvb_282{flex-direction:column;align-items:stretch}._preview_fxvvb_282{width:100%;height:200px}._levelGrid_fxvvb_301{grid-template-columns:1fr}._levelCardCanvas_fxvvb_336{width:100%!important;height:180px!important}._modal_fxvvb_122{border-radius:0;max-height:100vh;padding:.75rem}._galleryCategories_fxvvb_186{grid-template-columns:repeat(2,1fr)}._galleryPhotosGrid_fxvvb_238{grid-template-columns:repeat(3,1fr)}}._page_u7vwy_1{color:#222;box-sizing:border-box;background:#fafafa;grid-template-columns:200px 1fr 320px;align-items:start;gap:1.5rem;min-height:100vh;padding:1.5rem 2rem;font-family:system-ui,Segoe UI,Roboto,sans-serif;display:grid}._title_u7vwy_27{color:#222;margin:0 0 .5rem;font-size:1.4rem;font-weight:600}._stageIndicator_u7vwy_41{color:#666;margin:0 0 .75rem;font-size:.85rem}._errorText_u7vwy_53{color:#dc143c;margin:.5rem 0}._loadingText_u7vwy_63{color:#888;margin:.5rem 0}._sidebarHeading_u7vwy_75{color:#444;letter-spacing:.02em;margin:0 0 .5rem;font-size:.95rem;font-weight:600}._stagePicker_u7vwy_91{width:100%}._stageList_u7vwy_99{outline:none;flex-direction:column;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}._stageList_u7vwy_99:focus{outline-offset:2px;border-radius:6px;outline:2px solid #8af4}._stageItem_u7vwy_131{margin:0}._stageButton_u7vwy_139{text-align:left;cursor:pointer;width:100%;font:inherit;color:inherit;background:#fff;border:1px solid #ddd;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem;transition:border-color .12s,background .12s;display:flex}._stageButton_u7vwy_139:hover:not(:disabled){background:#fdfdfd;border-color:#aab}._stageButtonActive_u7vwy_181{background:#eef3ff!important;border-color:#57c!important}._stageButtonDisabled_u7vwy_191{opacity:.55;cursor:not-allowed}._stageThumb_u7vwy_201{background:#fff;border:1px solid #e3e3e3;border-radius:4px;flex:none;justify-content:center;align-items:center;width:60px;height:60px;display:flex;overflow:hidden}._thumbPlaceholder_u7vwy_227{background:repeating-linear-gradient(45deg,#f5f5f5,#f5f5f5 4px,#ececec 4px 8px)}._stageMeta_u7vwy_247{flex:auto;min-width:0;font-size:.85rem;line-height:1.25}._stageNumber_u7vwy_261{font-weight:600}._stageKind_u7vwy_269{color:#333}._stageStrokeCount_u7vwy_277{color:#888;margin-top:2px;font-size:.75rem}._backLink_u7vwy_289{color:#557;margin-top:1rem;font-size:.85rem;text-decoration:none;display:inline-block}._backLink_u7vwy_289:hover{text-decoration:underline}._canvasColumn_u7vwy_315{flex-direction:column;gap:.75rem;min-width:0;display:flex}._lessonProgressWrap_u7vwy_329{flex-direction:column;gap:.25rem;display:flex}._lessonProgressLabel_u7vwy_341{color:#666;justify-content:space-between;font-size:.75rem;display:flex}._lessonProgressTrack_u7vwy_355{background:#ececec;border-radius:3px;height:6px;overflow:hidden}._lessonProgressFill_u7vwy_369{background:#57c;height:100%;transition:width .12s linear}._canvasWrap_u7vwy_381{width:100%;max-width:100%;transition:opacity .2s;display:block}._canvasFading_u7vwy_395{opacity:.25}._scrubBar_u7vwy_403{cursor:pointer;background:#ececec;border-radius:4px;width:100%;max-width:720px;height:8px;margin-top:.25rem;position:relative}._scrubFill_u7vwy_425{background:#57c;border-radius:4px;transition:width 60ms linear;position:absolute;top:0;bottom:0;left:0}._scrubLabel_u7vwy_445{color:#666;margin-top:.15rem;font-size:.7rem}._controlsRow_u7vwy_457{flex-wrap:wrap;align-items:center;gap:.75rem;margin-top:.25rem;display:flex}._controlButton_u7vwy_473{font:inherit;cursor:pointer;color:#222;background:#fff;border:1px solid #ccc;border-radius:4px;padding:.35rem .7rem;font-size:.85rem}._controlButton_u7vwy_473:hover:not(:disabled){background:#f5f5f5}._controlButton_u7vwy_473:disabled{opacity:.5;cursor:not-allowed}._speedPresets_u7vwy_513{gap:.25rem;margin-left:.25rem;display:inline-flex}._speedPreset_u7vwy_513{font:inherit;cursor:pointer;color:#444;background:#fff;border:1px solid #ccc;border-radius:4px;padding:.2rem .5rem;font-size:.75rem}._speedPreset_u7vwy_513:hover{background:#f0f4ff}._speedPresetActive_u7vwy_555{color:#248!important;background:#eef3ff!important;border-color:#57c!important}._speedSlider_u7vwy_567{vertical-align:middle;width:180px}._autoAdvanceLabel_u7vwy_577{color:#444;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.3rem;font-size:.85rem;display:inline-flex}._teacherPanel_u7vwy_599{flex-direction:column;gap:.75rem;display:flex}._referenceCard_u7vwy_611{background:#fff;border:1px solid #e3e3e3;border-radius:8px;flex-direction:column;gap:.4rem;padding:.5rem;display:flex}._referenceImage_u7vwy_631{object-fit:contain;background:#f5f5f5;border-radius:4px;width:100%;height:auto;max-height:220px;display:block}._finalPreviewWrap_u7vwy_651{border-top:1px dashed #e3e3e3;flex-direction:column;align-items:center;gap:.25rem;margin-top:.25rem;padding-top:.5rem;display:flex}._finalPreviewLabel_u7vwy_671{color:#57c;letter-spacing:.02em;font-size:.75rem;font-weight:600}@media (width<=900px){._page_u7vwy_1{grid-template-columns:1fr;gap:.9rem;padding:.75rem}._stageList_u7vwy_99{flex-direction:row;padding-bottom:.25rem;overflow:auto hidden}._stageItem_u7vwy_131{flex:none}._stageButton_u7vwy_139{flex-direction:column;width:90px;padding:.35rem}._stageMeta_u7vwy_247{text-align:center}._stageThumb_u7vwy_201{margin:0 auto}._canvasWrap_u7vwy_381{width:100%;max-width:100%;display:block;overflow:hidden}._referenceImage_u7vwy_631{max-height:140px}._teacherPanel_u7vwy_599,._controlsRow_u7vwy_457{gap:.5rem}._speedSlider_u7vwy_567{width:130px}}@media (width<=520px){._title_u7vwy_27{font-size:1.15rem}._speedSlider_u7vwy_567{width:100px}._controlsRow_u7vwy_457 label{font-size:.8rem}._speedPresets_u7vwy_513{flex-wrap:wrap}}._reactionsList_u7vwy_827{flex-direction:column;gap:.5rem;display:flex}._reactionPending_u7vwy_839{color:#888;font-size:.8rem;font-style:italic}._reactionItem_u7vwy_851{color:#224;background:#eef5ff;border:1px solid #cdd9ee;border-radius:8px;padding:.5rem .75rem;font-size:.9rem}._introCard_u7vwy_869{background:#fffde7;border:1px solid #eed;border-radius:8px;padding:.75rem;font-size:.95rem}._introCard_u7vwy_869 p{white-space:pre-line;margin:0}._introTipsList_u7vwy_895{margin-top:.5rem;padding-left:1.2rem}._introTipsList_u7vwy_895 li{margin-bottom:.25rem}._glossaryWrap_u7vwy_913{border-top:1px solid #eed;margin-top:.75rem;padding-top:.5rem}._glossaryToggle_u7vwy_925{cursor:pointer;color:#557;background:0 0;border:none;padding:0;font-size:.85rem}._glossaryList_u7vwy_943{margin-top:.5rem;font-size:.85rem}._glossaryItem_u7vwy_953{margin-bottom:.4rem}._glossaryTerm_u7vwy_961{font-weight:600}._glossaryDef_u7vwy_969{color:#555;margin:0 0 0 .5rem}
