:root{--bg-primary: #1a1625;--bg-secondary: #231d30;--bg-tertiary: #2d2640;--bg-elevated: #352e48;--text-primary: #f0e6ff;--text-secondary: #b8a8d0;--text-muted: #7a6b8a;--text-placeholder: #5a4d6a;--accent-green: #10b981;--accent-green-glow: #10b98140;--accent-purple: #a855f7;--accent-purple-glow: #a855f740;--accent-blue: #3b82f6;--accent-orange: #f97316;--accent-red: #ef4444;--accent-yellow: #fbbf24;--border-color: #3d3554;--border-light: #4a4260;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .5);--transition-fast: .15s ease;--transition-normal: .25s ease;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace;--font-sans: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--header-height: 56px;--footer-height: 40px;--panel-gap: 12px;--panel-padding: 16px;--border-radius: 12px;--border-radius-sm: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100%;background:radial-gradient(ellipse at top left,rgba(168,85,247,.08) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(16,185,129,.06) 0%,transparent 50%),var(--bg-primary)}.app-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--panel-padding);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.app-title{display:flex;align-items:center;gap:8px;font-size:20px;font-weight:700;color:var(--text-primary)}.title-icon{font-size:24px;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.title-text{background:linear-gradient(135deg,var(--accent-green),var(--accent-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{color:var(--text-muted);font-size:13px;font-weight:500}.header-center{display:flex;align-items:center;gap:12px}.header-right{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-family:var(--font-sans);font-size:13px;font-weight:600;border:none;border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{font-size:12px}.kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 5px;margin-left:4px;font-family:var(--font-mono);font-size:10px;font-weight:500;color:inherit;background:#ffffff1a;border-radius:4px;opacity:.7}.btn-run{color:#fff;background:linear-gradient(135deg,var(--accent-green),#059669);box-shadow:0 2px 8px var(--accent-green-glow)}.btn-run:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-green-glow)}.btn-stop{color:#fff;background:linear-gradient(135deg,var(--accent-red),#dc2626);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.btn-reset{color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color)}.btn-reset:hover:not(:disabled){color:var(--text-primary);background:var(--bg-elevated)}.btn-curriculum{color:#fff;background:linear-gradient(135deg,var(--accent-purple),#7c3aed);box-shadow:0 2px 8px var(--accent-purple-glow)}.btn-curriculum:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-purple-glow)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--accent-green),#059669)}.btn-secondary{color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){color:var(--text-primary);background:var(--bg-elevated)}.btn-ghost{color:var(--text-secondary);background:transparent;border:none}.btn-ghost:hover{color:var(--text-primary)}.btn-large{padding:12px 24px;font-size:15px}.btn-small{padding:4px 8px;font-size:11px}.example-select,.speed-select{padding:8px 32px 8px 12px;font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23b8a8d0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.example-select:hover,.speed-select:hover{border-color:var(--accent-purple)}.speed-select-small{padding:4px 24px 4px 8px;font-size:11px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23b8a8d0' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.speed-control{display:flex;align-items:center;gap:8px}.speed-label{font-size:13px;font-weight:500;color:var(--text-secondary)}.app-main{display:flex;flex:1;gap:var(--panel-gap);padding:var(--panel-gap);min-height:0}.left-panel{display:flex;flex-direction:column;flex:1;min-width:0;gap:var(--panel-gap)}.right-panel{display:flex;flex-direction:column;flex:1;min-width:0;background:var(--bg-secondary);border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px var(--panel-padding);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0}.panel-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.turtle-status{font-size:12px;color:var(--text-muted)}.editor-panel{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-secondary);border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden}.editor-container{flex:1;min-height:0;overflow:hidden}.editor-wrapper{display:flex;height:100%;overflow:auto}.line-numbers{display:flex;flex-direction:column;padding:12px 0;background:var(--bg-tertiary);border-right:1px solid var(--border-color);-webkit-user-select:none;user-select:none;overflow:hidden;flex-shrink:0}.line-number{padding:0 12px;font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--text-muted);text-align:right;min-width:40px}.editor-textarea{flex:1;padding:12px 16px;font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--text-primary);background:var(--bg-secondary);border:none;outline:none;resize:none;-moz-tab-size:2;tab-size:2;min-width:0}.editor-textarea::placeholder{color:var(--text-placeholder)}.canvas-container{flex:1;position:relative;background:linear-gradient(90deg,var(--border-color) 1px,transparent 1px),linear-gradient(var(--border-color) 1px,transparent 1px),var(--bg-primary);background-size:40px 40px;background-position:center center;overflow:hidden}.turtle-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.drawing-canvas{z-index:1}.overlay-canvas{z-index:2;pointer-events:none}.canvas-origin-marker{position:absolute;top:50%;left:50%;width:8px;height:8px;margin:-4px 0 0 -4px;background:var(--accent-purple);border-radius:50%;opacity:.4;pointer-events:none}.canvas-controls{display:flex;gap:8px;align-items:center}.console-panel{flex-shrink:0;min-height:120px;max-height:200px;background:var(--bg-secondary);border-radius:var(--border-radius);border:1px solid var(--border-color);overflow:hidden;display:flex;flex-direction:column}.console-container{display:flex;flex-direction:column;height:100%}.console-header{display:flex;align-items:center;justify-content:space-between;padding:8px var(--panel-padding);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0}.console-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.console-clear-btn{padding:2px 8px;font-family:var(--font-sans);font-size:11px;font-weight:500;color:var(--text-muted);background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer}.console-clear-btn:hover{color:var(--text-secondary);border-color:var(--border-light)}.console-output{flex:1;padding:8px var(--panel-padding);font-family:var(--font-mono);font-size:12px;line-height:1.6;overflow-y:auto;color:var(--text-primary)}.console-placeholder{color:var(--text-placeholder);font-style:italic}.console-message{display:flex;align-items:flex-start;gap:6px;padding:2px 0}.console-icon{flex-shrink:0;font-size:11px}.console-text{white-space:pre-wrap;word-break:break-word}.console-error{color:var(--accent-red)}.console-info{color:var(--accent-green)}.app-footer{display:flex;align-items:center;justify-content:center;height:var(--footer-height);padding:0 var(--panel-padding);background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.footer-help{font-size:12px;color:var(--text-muted)}.footer-help code{padding:2px 6px;font-family:var(--font-mono);font-size:11px;color:var(--accent-green);background:var(--bg-tertiary);border-radius:4px;margin:0 2px}.cheat-sheet{background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.cheat-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer}.cheat-sheet-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.cheat-sheet-toggle{color:var(--text-muted);font-size:10px}.cheat-sheet-content{padding:0 12px 12px}.cheat-section{margin-bottom:12px}.cheat-section:last-child{margin-bottom:0}.cheat-section-title{font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.cheat-items{display:flex;flex-direction:column;gap:4px}.cheat-item{display:flex;align-items:baseline;gap:8px;font-size:11px}.cheat-code{font-family:var(--font-mono);color:var(--accent-green);background:var(--bg-secondary);padding:2px 6px;border-radius:4px;white-space:pre}.cheat-desc{color:var(--text-muted)}.sandbox-cheatsheet{flex-shrink:0}.curriculum-app{display:flex;flex-direction:row;height:100%}.curriculum-mode{display:flex;flex-direction:column;width:380px;min-width:380px;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto}.curriculum-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);flex-shrink:0}.curriculum-title{font-size:12px;font-weight:600;color:var(--text-muted)}.curriculum-progress-bar{display:flex;align-items:center;gap:8px}.progress-chapters{display:flex;gap:4px}.progress-chapter{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--text-muted);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:50%}.progress-chapter.current{color:var(--accent-purple);border-color:var(--accent-purple)}.progress-chapter.completed{color:var(--accent-green);border-color:var(--accent-green);background:var(--accent-green-glow)}.curriculum-content{flex:1;overflow-y:auto;padding:16px}.curriculum-workspace{flex:1;display:flex;flex-direction:column;min-width:0}.workspace-editor{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow:hidden}.workspace-right{display:flex;flex-direction:row;flex:1;min-height:0}.workspace-canvas{flex:1;display:flex;flex-direction:column;background:var(--bg-secondary);min-width:0}.workspace-console{width:280px;flex-shrink:0;border-left:1px solid var(--border-color)}.chapter-intro{display:flex;flex-direction:column;align-items:center;text-align:center;padding:20px 0}.chapter-intro-content{max-width:320px}.chapter-badge{display:inline-block;padding:4px 12px;font-size:11px;font-weight:600;color:var(--accent-purple);background:var(--accent-purple-glow);border-radius:20px;margin-bottom:16px}.chapter-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.chapter-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.chapter-story{font-size:14px;line-height:1.7;color:var(--text-secondary);margin-bottom:24px;text-align:left}.chapter-unlocks{text-align:left;margin-bottom:24px}.unlocks-title{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.unlocks-list{display:flex;flex-wrap:wrap;gap:6px}.unlock-tag{padding:4px 10px;font-family:var(--font-mono);font-size:12px;color:var(--accent-green);background:var(--bg-tertiary);border-radius:4px}.chapter-actions{display:flex;gap:12px;justify-content:center}.chapter-decoration{margin-top:20px}.decoration-turtle{font-size:48px;opacity:.5}.challenge-panel{display:flex;flex-direction:column;gap:16px}.challenge-header{display:flex;flex-direction:column;gap:4px}.challenge-number{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.challenge-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.challenge-goal{background:var(--bg-tertiary);padding:12px;border-radius:var(--border-radius-sm)}.goal-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.goal-text{font-size:14px;color:var(--text-primary);margin:0}.challenge-result{display:flex;align-items:center;gap:8px;padding:12px;border-radius:var(--border-radius-sm)}.challenge-result.success{background:#10b98126;border:1px solid var(--accent-green)}.challenge-result.failure{background:#f973161a;border:1px solid var(--accent-orange)}.result-icon{font-weight:700}.challenge-result.success .result-icon{color:var(--accent-green)}.challenge-result.failure .result-icon{color:var(--accent-orange)}.result-message{font-size:14px;color:var(--text-primary)}.challenge-hints{display:flex;flex-direction:column;gap:8px}.hints-header{display:flex;align-items:center;justify-content:space-between}.hints-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.hint-reveal-btn{padding:4px 10px;font-size:11px;font-weight:500;color:var(--accent-blue);background:transparent;border:1px solid var(--accent-blue);border-radius:4px;cursor:pointer}.hint-reveal-btn:hover{background:#3b82f61a}.hints-placeholder{font-size:12px;color:var(--text-muted);font-style:italic}.hints-list{display:flex;flex-direction:column;gap:8px}.hint-card{background:var(--bg-tertiary);padding:10px;border-radius:var(--border-radius-sm);border-left:3px solid var(--accent-blue)}.hint-number{font-size:10px;font-weight:600;color:var(--accent-blue);margin-bottom:4px}.hint-text{font-size:13px;color:var(--text-secondary);margin:0}.hint-code{margin-top:8px;padding:8px;background:var(--bg-secondary);border-radius:4px;font-family:var(--font-mono);font-size:12px;color:var(--accent-green);overflow-x:auto}.challenge-actions{display:flex;gap:8px;justify-content:space-between}.success-celebration{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#1a1625e6;z-index:100;cursor:pointer;animation:fadeIn .3s ease}.success-content{text-align:center;animation:bounceIn .4s ease}.success-emoji{font-size:64px;margin-bottom:16px}.success-text{font-size:32px;font-weight:700;color:var(--accent-green);margin-bottom:8px}.success-hint{font-size:14px;color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes bounceIn{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.btn-success{color:#fff;background:linear-gradient(135deg,var(--accent-green),#059669);box-shadow:0 2px 8px var(--accent-green-glow)}.btn-success:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-green-glow)}.btn-next-prominent{flex:1;padding:12px 20px;font-size:14px;animation:pulseGlow 1.5s ease-in-out infinite}@keyframes pulseGlow{0%,to{box-shadow:0 2px 8px var(--accent-green-glow)}50%{box-shadow:0 4px 20px var(--accent-green-glow)}}.chapter-complete{display:flex;flex-direction:column;align-items:center;padding:20px 0}.complete-content{max-width:320px;text-align:center}.complete-celebration{margin-bottom:24px}.celebration-emoji{font-size:48px;display:block;margin-bottom:12px}.complete-title{font-size:24px;font-weight:700;color:var(--accent-green);margin:0 0 8px}.complete-subtitle{font-size:14px;color:var(--text-secondary);margin:0}.complete-summary{text-align:left;margin-bottom:24px}.complete-summary h3{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px}.learned-list{display:flex;flex-wrap:wrap;gap:6px}.learned-tag{padding:4px 10px;font-size:12px;color:var(--accent-green);background:var(--accent-green-glow);border-radius:4px}.create-prompt-section{text-align:left;background:var(--bg-tertiary);padding:16px;border-radius:var(--border-radius);margin-bottom:20px}.create-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.create-prompt{font-size:14px;color:var(--text-secondary);margin:0 0 16px}.create-suggestions{margin-bottom:16px}.suggestions-label{font-size:11px;font-weight:600;color:var(--text-muted)}.suggestions-list{margin:8px 0 0;padding-left:20px;font-size:13px;color:var(--text-secondary)}.suggestions-list li{margin-bottom:4px}.complete-actions{margin-top:16px}.final-message{font-size:14px;color:var(--text-muted);font-style:italic}.challenges-view{display:flex;flex-direction:column;height:100%}.challenges-sidebar,.create-mode-view{display:flex;flex-direction:column;gap:16px}.create-mode-header{display:flex;flex-direction:column;gap:8px}.create-mode-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.create-mode-header p{font-size:14px;color:var(--text-secondary);margin:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@media (max-width: 1200px){.curriculum-mode{width:320px;min-width:320px}.workspace-console{width:240px}}@media (max-width: 900px){.app-main{flex-direction:column}.left-panel,.right-panel{flex:none;height:50%}.app-subtitle,.footer-help code{display:none}.curriculum-app{flex-direction:column}.curriculum-mode{width:100%;min-width:auto;height:40%;border-right:none;border-bottom:1px solid var(--border-color)}.curriculum-workspace{height:60%}.workspace-right{flex-direction:column}.workspace-console{width:100%;height:120px;border-left:none;border-top:1px solid var(--border-color)}}@media (max-width: 600px){.header-center,.kbd{display:none}}
