header.svelte-1elxaub{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color);gap:1rem}.menu-toggle.svelte-1elxaub{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:background .15s}.menu-toggle.svelte-1elxaub:hover{background:var(--bg-active)}.logo.svelte-1elxaub{display:flex;align-items:center;gap:.5rem}.logo.svelte-1elxaub .icon:where(.svelte-1elxaub){font-size:1.5rem}.logo.svelte-1elxaub h1:where(.svelte-1elxaub){font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.progress-section.svelte-1elxaub{flex:1;max-width:400px;display:flex;flex-direction:column;gap:.25rem}.progress-bar.svelte-1elxaub{height:8px;background:var(--bg-active);border-radius:4px;overflow:hidden}.progress-fill.svelte-1elxaub{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);transition:width .3s ease}.progress-text.svelte-1elxaub{font-size:.75rem;color:var(--text-tertiary);text-align:center}.stats.svelte-1elxaub{display:flex;align-items:center;gap:1rem}.stat.svelte-1elxaub{display:flex;flex-direction:column;align-items:center;gap:.125rem}.stat-value.svelte-1elxaub{font-size:1.25rem;font-weight:700;color:#fbbf24}.stat-label.svelte-1elxaub{font-size:.625rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.sync-status.svelte-1elxaub{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-tertiary);padding:.25rem .75rem;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:999px;cursor:pointer;transition:all .15s}.sync-status.svelte-1elxaub:hover{background:var(--bg-active)}.sync-status.synced.svelte-1elxaub{color:#4ade80;border-color:#4ade80}.sync-status.syncing.svelte-1elxaub{color:#fbbf24;border-color:#fbbf24}.sync-status.error.svelte-1elxaub{color:#f87171;border-color:#f87171}.sync-status.offline.svelte-1elxaub{color:var(--text-tertiary)}.sync-text.svelte-1elxaub{display:inline}.theme-toggle.svelte-1elxaub{display:flex;align-items:center;justify-content:center;padding:.375rem;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:6px;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.theme-toggle.svelte-1elxaub:hover{background:var(--bg-active);color:var(--text-primary)}.pyodide-status.svelte-1elxaub{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text-tertiary);padding:.25rem .75rem;background:var(--bg-hover);border-radius:999px}.pyodide-status.ready.svelte-1elxaub{color:#4ade80}.pyodide-status.loading.svelte-1elxaub{color:#fbbf24}.status-text.svelte-1elxaub{display:inline}.dot.svelte-1elxaub{width:8px;height:8px;border-radius:50%;background:#4ade80}.dot.error.svelte-1elxaub{background:#f87171}.spinner.svelte-1elxaub{width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:svelte-1elxaub-spin 1s linear infinite}@keyframes svelte-1elxaub-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.progress-section.svelte-1elxaub{max-width:250px}.stats.svelte-1elxaub{gap:.75rem}.status-text.svelte-1elxaub{display:none}}@media(max-width:768px){header.svelte-1elxaub{padding:.5rem 1rem;gap:.75rem}.menu-toggle.svelte-1elxaub{display:flex;align-items:center;justify-content:center}.logo.svelte-1elxaub h1:where(.svelte-1elxaub){font-size:1rem}.logo.svelte-1elxaub .icon:where(.svelte-1elxaub){font-size:1.25rem}.progress-section.svelte-1elxaub{display:none}.stat.svelte-1elxaub{min-width:40px}.stat-value.svelte-1elxaub{font-size:1rem}.sync-text.svelte-1elxaub{display:none}.pyodide-status.svelte-1elxaub{padding:.25rem .5rem}}@media(max-width:480px){.logo.svelte-1elxaub h1:where(.svelte-1elxaub){display:none}.stat-label.svelte-1elxaub,.pyodide-status.svelte-1elxaub{display:none}}.backdrop.svelte-129hoe0{display:none}aside.svelte-129hoe0{width:280px;min-width:280px;background:var(--bg-primary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.sidebar-header.svelte-129hoe0{padding:1rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.sidebar-header.svelte-129hoe0 h2:where(.svelte-129hoe0){margin:0;font-size:.875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.close-btn.svelte-129hoe0{display:none;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:.25rem;border-radius:4px;transition:all .15s}.close-btn.svelte-129hoe0:hover{background:var(--bg-active);color:var(--text-primary)}nav.svelte-129hoe0{flex:1;overflow-y:auto;padding:.5rem}.category.svelte-129hoe0{margin-bottom:.25rem}.category-header.svelte-129hoe0{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:none;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;border-radius:4px;transition:background .15s}.category-header.svelte-129hoe0:hover{background:var(--bg-hover)}.chevron.svelte-129hoe0{font-size:.625rem;color:var(--text-muted);width:12px}.category-name.svelte-129hoe0{flex:1;text-align:left;font-weight:500}.category-count.svelte-129hoe0{font-size:.75rem;color:var(--text-muted)}.exercise-list.svelte-129hoe0{list-style:none;margin:0;padding:0 0 0 1.25rem}.exercise-item.svelte-129hoe0{width:100%;display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:none;border:none;color:var(--text-tertiary);font-size:.8125rem;cursor:pointer;border-radius:4px;transition:all .15s;text-align:left}.exercise-item.svelte-129hoe0:hover{background:var(--bg-hover);color:var(--text-secondary)}.exercise-item.current.svelte-129hoe0{background:var(--selection-bg);color:var(--text-primary)}.exercise-item.completed.svelte-129hoe0,.exercise-item.completed.svelte-129hoe0:hover{color:#4ade80}.status-icon.svelte-129hoe0{width:16px;text-align:center;font-size:.75rem}.exercise-item.completed.svelte-129hoe0 .status-icon:where(.svelte-129hoe0){color:#4ade80}.exercise-item.current.svelte-129hoe0 .status-icon:where(.svelte-129hoe0){color:#60a5fa}.exercise-id.svelte-129hoe0{font-family:monospace;font-size:.75rem;color:var(--text-muted);min-width:2rem}.exercise-item.current.svelte-129hoe0 .exercise-id:where(.svelte-129hoe0){color:#93c5fd}.exercise-name.svelte-129hoe0{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:1024px){aside.svelte-129hoe0{width:240px;min-width:240px}}@media(max-width:768px){.backdrop.svelte-129hoe0{display:block;position:fixed;inset:0;background:#00000080;z-index:40}aside.svelte-129hoe0{position:fixed;top:0;left:0;bottom:0;width:280px;min-width:280px;z-index:50;transform:translate(-100%);transition:transform .3s ease}aside.open.svelte-129hoe0{transform:translate(0)}.close-btn.svelte-129hoe0{display:flex;align-items:center;justify-content:center}}.editor-container.svelte-c4vs74{width:100%;height:100%;min-height:300px}.results-container.svelte-1wg06n2{padding:1rem;background:var(--bg-secondary);border-top:1px solid var(--border-color);max-height:300px;overflow-y:auto}.status.svelte-1wg06n2{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:6px;font-size:.875rem}.status.running.svelte-1wg06n2{background:var(--bg-tertiary);color:#fbbf24}.status.success.svelte-1wg06n2{background:var(--success-bg);color:#4ade80}.status.error.svelte-1wg06n2{background:var(--error-bg);color:#f87171}.status.idle.svelte-1wg06n2{background:var(--bg-tertiary);color:var(--text-tertiary)}.icon.svelte-1wg06n2{font-size:1.25rem}.message.svelte-1wg06n2{display:flex;flex-direction:column;gap:.25rem}.message.svelte-1wg06n2 strong:where(.svelte-1wg06n2){font-weight:600}.message.svelte-1wg06n2 span:where(.svelte-1wg06n2){font-size:.8125rem;opacity:.8}.error-detail.svelte-1wg06n2{font-family:monospace;font-size:.75rem!important}.spinner.svelte-1wg06n2{width:16px;height:16px;border:2px solid #fbbf24;border-top-color:transparent;border-radius:50%;animation:svelte-1wg06n2-spin 1s linear infinite}@keyframes svelte-1wg06n2-spin{to{transform:rotate(360deg)}}.test-details.svelte-1wg06n2{margin-top:.75rem;display:flex;flex-direction:column;gap:.25rem}.test-item.svelte-1wg06n2{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.8125rem;border-radius:4px}.test-item.passed.svelte-1wg06n2{background:var(--success-bg);color:#4ade80}.test-item.failed.svelte-1wg06n2{background:var(--error-bg);color:#f87171}.check.svelte-1wg06n2{color:#4ade80}.cross.svelte-1wg06n2{color:#f87171}.js-habits.svelte-1wg06n2{margin-top:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:6px;border-left:3px solid #fbbf24}.js-habits.svelte-1wg06n2 h4:where(.svelte-1wg06n2){margin:0 0 .5rem;font-size:.8125rem;color:#fbbf24}.js-habits.svelte-1wg06n2 ul:where(.svelte-1wg06n2){margin:0;padding:0 0 0 1.25rem;font-size:.8125rem;color:var(--text-secondary)}.js-habits.svelte-1wg06n2 li:where(.svelte-1wg06n2){margin-bottom:.25rem}.output-details.svelte-1wg06n2{margin-top:.75rem}.output-details.svelte-1wg06n2 summary:where(.svelte-1wg06n2){cursor:pointer;font-size:.8125rem;color:var(--text-tertiary);padding:.375rem}.output-details.svelte-1wg06n2 summary:where(.svelte-1wg06n2):hover{color:var(--text-secondary)}.output.svelte-1wg06n2{margin:.5rem 0 0;padding:.75rem;background:var(--bg-primary);border-radius:4px;font-size:.75rem;color:var(--text-secondary);overflow-x:auto;white-space:pre-wrap;word-break:break-word}kbd.svelte-1wg06n2{display:inline-block;padding:.125rem .375rem;background:var(--bg-active);border-radius:3px;font-family:monospace;font-size:.75rem;color:var(--text-secondary);border:1px solid var(--border-color)}.exercise-view.svelte-wc1ygd{flex:1;display:flex;overflow:hidden}.instructions-panel.svelte-wc1ygd{width:400px;min-width:300px;max-width:500px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.exercise-header.svelte-wc1ygd{width:100%;padding:1rem;border:none;border-bottom:1px solid var(--border-color);background:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem;cursor:default;text-align:left}.header-left.svelte-wc1ygd{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.header-right.svelte-wc1ygd{display:flex;align-items:center;gap:.5rem}.expand-icon.svelte-wc1ygd{display:none;font-size:.75rem;color:var(--text-tertiary)}.exercise-number.svelte-wc1ygd{font-size:.875rem;font-weight:600;color:#60a5fa;background:#1e3a5f;padding:.25rem .5rem;border-radius:4px;font-family:monospace;flex-shrink:0}.exercise-header.svelte-wc1ygd h2:where(.svelte-wc1ygd){margin:0;font-size:1.125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-badge.svelte-wc1ygd{font-size:.6875rem;color:var(--text-tertiary);background:var(--bg-active);padding:.25rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.instructions-content.svelte-wc1ygd{flex:1;overflow-y:auto;padding:1rem}.instructions.svelte-wc1ygd{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-wrap:break-word;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.loading.svelte-wc1ygd{padding:2rem;text-align:center;color:var(--text-tertiary)}.editor-panel.svelte-wc1ygd{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.editor-toolbar.svelte-wc1ygd{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.toolbar-left.svelte-wc1ygd{display:flex;align-items:center;gap:.5rem;color:var(--text-tertiary);font-size:.875rem}.file-icon.svelte-wc1ygd{font-size:1rem}.file-name.svelte-wc1ygd{font-family:monospace}.toolbar-right.svelte-wc1ygd{display:flex;gap:.5rem}.btn.svelte-wc1ygd{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn.svelte-wc1ygd:disabled{opacity:.5;cursor:not-allowed}.btn-secondary.svelte-wc1ygd{background:var(--bg-active);color:var(--text-secondary)}.btn-secondary.svelte-wc1ygd:hover:not(:disabled){background:var(--bg-hover)}.btn-primary.svelte-wc1ygd{background:#2563eb;color:#fff}.btn-primary.svelte-wc1ygd:hover:not(:disabled){background:#1d4ed8}.editor-wrapper.svelte-wc1ygd{flex:1;min-height:0}@media(max-width:1024px){.instructions-panel.svelte-wc1ygd{width:320px;min-width:280px;max-width:350px}.exercise-header.svelte-wc1ygd h2:where(.svelte-wc1ygd){font-size:1rem}}@media(max-width:768px){.exercise-view.svelte-wc1ygd{flex-direction:column}.instructions-panel.svelte-wc1ygd{width:100%;min-width:100%;max-width:100%;border-right:none;border-bottom:1px solid var(--border-color);max-height:none;flex-shrink:0}.instructions-panel.svelte-wc1ygd:not(.expanded){max-height:60px}.instructions-panel.svelte-wc1ygd:not(.expanded) .instructions-content:where(.svelte-wc1ygd){display:none}.exercise-header.svelte-wc1ygd{cursor:pointer}.exercise-header.svelte-wc1ygd:hover{background:var(--bg-hover)}.expand-icon.svelte-wc1ygd{display:block}.category-badge.svelte-wc1ygd{display:none}.instructions-panel.expanded.svelte-wc1ygd{max-height:40vh}.editor-panel.svelte-wc1ygd{min-height:0;flex:1}.editor-toolbar.svelte-wc1ygd{padding:.5rem}.toolbar-left.svelte-wc1ygd{display:none}.btn.svelte-wc1ygd{padding:.5rem .75rem;font-size:.8125rem}}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-secondary);overflow:hidden}*{box-sizing:border-box}.app.svelte-1uha8ag{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}main.svelte-1uha8ag{flex:1;display:flex;overflow:hidden;position:relative}@media(max-width:768px){main.svelte-1uha8ag{flex-direction:column}}
