@import"https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap";.shop-page{min-height:100vh;background:linear-gradient(135deg,var(--color-bg, #f5f3ff) 0%,#e8e0ff 100%);font-family:var(--font-body, "Nunito", sans-serif)}.shop-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--color-surface, #ffffff);border-bottom:2px solid var(--color-border, #e0e0e0);box-shadow:0 2px 8px #6c5ce714}.shop-back-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:2px solid var(--color-border, #e0e0e0);border-radius:var(--radius-md, 12px);background:var(--color-surface, #ffffff);color:var(--color-text, #2d3436);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s}.shop-back-btn:hover{border-color:var(--color-primary, #6c5ce7);color:var(--color-primary, #6c5ce7);transform:translate(-2px)}.shop-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:24px;color:var(--color-primary, #6c5ce7);margin:0}.shop-coins{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#ffeaa7,#fdcb6e);border-radius:20px;font-weight:800;font-size:15px;color:#6c5c00;box-shadow:0 2px 8px #fdcb6e66}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding:28px 24px;max-width:900px;margin:0 auto}.shop-card{background:var(--color-surface, #ffffff);border-radius:16px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:10px;border:3px solid var(--color-border, #e0e0e0);box-shadow:0 4px 16px #6c5ce714;transition:transform .2s,box-shadow .2s}.shop-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #6c5ce729}.shop-card.shop-card--active{border-color:var(--color-primary, #6c5ce7);background:#f5f0ff}.shop-card canvas{border-radius:50%;background:#f0ecff}.shop-card-name{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:16px;color:var(--color-text, #2d3436);margin:0}.shop-card-price{font-size:13px;font-weight:700;color:var(--color-text-muted, #888)}.shop-card-price--free{color:var(--color-success, #00b894)}.shop-card-btn{width:100%;padding:10px 14px;border:none;border-radius:var(--radius-md, 12px);font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:transform .1s,opacity .2s}.shop-card-btn:hover:not(:disabled){transform:scale(1.03)}.shop-card-btn:active:not(:disabled){transform:scale(.97)}.shop-card-btn--buy{background:var(--color-primary, #6c5ce7);color:#fff}.shop-card-btn--equip{background:linear-gradient(135deg,#00b894,#00cec9);color:#fff}.shop-card-btn--owned{background:var(--color-border, #e0e0e0);color:var(--color-text-muted, #888);cursor:default}.shop-card-btn:disabled{opacity:.5;cursor:not-allowed}.shop-loading{text-align:center;padding:60px 24px;font-size:18px;font-weight:700;color:var(--color-text-muted, #888)}.shop-error{text-align:center;padding:16px 24px;margin:20px 24px;background:#fff0f0;color:var(--color-danger, #e17055);border-radius:var(--radius-md, 12px);font-size:14px;font-weight:600}.designer-page{min-height:100vh;min-height:100dvh;background:linear-gradient(135deg,#f5f3ff,#e8e0ff,#dbeafe);font-family:var(--font-body, "Nunito", sans-serif);display:flex;flex-direction:column}.designer-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 12px #6c5ce714;flex-shrink:0}.designer-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:20px;color:#6c5ce7;margin:0}.designer-preview{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 16px 12px}.designer-preview-canvas{border-radius:50%;background:#6c5ce70f;border:4px solid #e0e0e0;box-shadow:0 8px 32px #6c5ce71f;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.designer-preview--bounce{animation:designer-bounce .3s cubic-bezier(.34,1.56,.64,1)}@keyframes designer-bounce{0%{transform:scale(1)}40%{transform:scale(1.08)}to{transform:scale(1)}}.designer-surprise-btn{padding:10px 24px;border-radius:24px;border:2px dashed #a78bfa;background:#a78bfa14;color:#6c5ce7;font-size:14px;font-weight:800;font-family:inherit;cursor:pointer;transition:all .2s}.designer-surprise-btn:hover{background:#a78bfa2e;border-color:#6c5ce7;transform:translateY(-1px)}.designer-surprise-btn:active{transform:scale(.96)}.designer-category-tabs{display:flex;gap:6px;padding:0 16px 12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;justify-content:center}.designer-category-tabs::-webkit-scrollbar{display:none}.designer-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 16px;min-width:56px;border:2px solid #e0e0e0;border-radius:14px;background:#fff;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;flex-shrink:0}.designer-tab:hover{border-color:#6c5ce7;transform:translateY(-1px)}.designer-tab--active{border-color:#6c5ce7;background:#6c5ce714;box-shadow:0 2px 8px #6c5ce726}.designer-tab-emoji{font-size:20px}.designer-tab-label{font-size:11px;font-weight:700;color:#2d3436}.designer-options{flex:1;padding:0 16px;overflow-y:auto;max-width:520px;margin:0 auto;width:100%}.designer-option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.designer-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px 10px;min-height:80px;border:3px solid #e0e0e0;border-radius:16px;background:#fff;cursor:pointer;font-family:inherit;transition:all .2s;position:relative}.designer-option:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #6c5ce71f}.designer-option:active:not(:disabled){transform:scale(.96)}.designer-option--selected{border-color:#6c5ce7;background:#6c5ce70f;box-shadow:0 4px 16px #6c5ce733}.designer-option--locked{opacity:.5;cursor:not-allowed}.designer-option:disabled{cursor:not-allowed}.designer-option-emoji{font-size:28px}.designer-option-label{font-size:12px;font-weight:700;color:#2d3436}.designer-option-free{font-size:10px;font-weight:700;color:#00b894}.designer-option-price{font-size:11px;font-weight:700;color:#e17055}.designer-option-owned{font-size:10px;font-weight:700;color:#00b894}.designer-option-lock{position:absolute;top:6px;right:6px;font-size:14px}.designer-option-req{font-size:9px;color:#888;text-align:center;line-height:1.2}.designer-color-section{display:flex;flex-direction:column;gap:20px}.designer-color-group h3{font-size:14px;font-weight:700;color:#2d3436;margin:0 0 10px;display:flex;align-items:center;gap:8px}.designer-free-badge{font-size:10px;font-weight:800;color:#00b894;background:#00b8941a;padding:2px 8px;border-radius:8px}.designer-color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.designer-color-swatch{width:100%;aspect-ratio:1;min-width:40px;min-height:40px;border-radius:50%;border:3px solid #e0e0e0;cursor:pointer;transition:all .2s}.designer-color-swatch:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000001f}.designer-color-swatch:active{transform:scale(.95)}.designer-color-swatch--selected{border-color:#6c5ce7;box-shadow:0 0 0 3px #6c5ce74d;transform:scale(1.1)}.designer-actions{padding:16px;display:flex;flex-direction:column;gap:8px;max-width:520px;margin:0 auto;width:100%;flex-shrink:0}.designer-save-btn{width:100%;padding:16px 32px;font-size:16px;font-weight:800;font-family:inherit;border:none;border-radius:16px;background:linear-gradient(135deg,#6c5ce7,#a78bfa);color:#fff;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #6c5ce74d}.designer-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #6c5ce766}.designer-save-btn:active:not(:disabled){transform:scale(.97)}.designer-save-btn:disabled{opacity:.6;cursor:not-allowed}.designer-cost{text-align:center;font-size:13px;font-weight:600;color:#888}.designer-cost--warn{color:#e17055;font-weight:700}@media (max-width: 600px){.designer-preview-canvas{width:150px!important;height:150px!important}.designer-option-grid{grid-template-columns:repeat(2,1fr)}.designer-color-grid{grid-template-columns:repeat(6,1fr)}.designer-category-tabs{justify-content:flex-start;padding:0 12px 10px}.designer-topbar{padding:12px 14px}.designer-title{font-size:17px}}@media (prefers-reduced-motion: reduce){.designer-preview--bounce{animation:none}.designer-option:hover:not(:disabled){transform:none}.designer-tab:hover{transform:none}}.dashboard{min-height:100vh;background:var(--color-bg);font-family:var(--font-body)}.dashboard-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border-bottom:2px solid var(--color-border);box-shadow:var(--shadow-sm)}.dashboard-back-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);background:var(--color-surface-alt);color:var(--color-primary);font-weight:700;font-size:14px;transition:background .2s,transform .1s}.dashboard-back-btn:hover{background:#e8e0ff;transform:scale(1.03)}.dashboard-title{font-family:var(--font-display);font-size:22px;color:var(--color-text)}.dashboard-content{max-width:900px;margin:0 auto;padding:var(--space-lg)}.dashboard-section{margin-bottom:var(--space-xl)}.dashboard-section h2{font-family:var(--font-display);font-size:18px;color:var(--color-primary);margin-bottom:var(--space-md)}.dashboard-card{background:var(--color-surface);border-radius:var(--radius-md);border:2px solid var(--color-border);padding:var(--space-md) var(--space-lg);margin-bottom:var(--space-md);transition:box-shadow .2s,border-color .2s}.dashboard-card.clickable{cursor:pointer}.dashboard-card.clickable:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.dashboard-card.selected{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.dashboard-card-row{display:flex;justify-content:space-between;align-items:center}.dashboard-card-name{font-weight:700;font-size:16px;color:var(--color-text)}.dashboard-card-code{font-size:13px;color:var(--color-text-muted);background:var(--color-surface-alt);padding:4px 10px;border-radius:var(--radius-sm);font-weight:600}.dashboard-table{width:100%;border-collapse:collapse;margin-top:var(--space-md);font-size:14px}.dashboard-table th{text-align:left;font-weight:700;color:var(--color-text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;border-bottom:2px solid var(--color-border)}.dashboard-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);color:var(--color-text)}.dashboard-table tr:last-child td{border-bottom:none}.dashboard-form{display:flex;gap:var(--space-sm);align-items:flex-end;margin-bottom:var(--space-md)}.dashboard-form input{flex:1;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:14px;color:var(--color-text);background:var(--color-surface);transition:border-color .2s}.dashboard-form input:focus{outline:none;border-color:var(--color-primary)}.dashboard-form button,.dashboard-action-btn{padding:10px 20px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-weight:700;font-size:14px;transition:transform .1s,opacity .2s;white-space:nowrap}.dashboard-form button:hover,.dashboard-action-btn:hover{transform:scale(1.03)}.dashboard-form button:disabled,.dashboard-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.dashboard-success{background:#e6fff6;color:var(--color-success);padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;margin-bottom:var(--space-md)}.dashboard-error{background:#fff0f0;color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;margin-bottom:var(--space-md)}.dashboard-empty{color:var(--color-text-muted);font-size:14px;font-style:italic;padding:var(--space-md) 0}.mastery-bar{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:10px}.mastery-label{font-weight:600;font-size:13px;color:var(--color-text);min-width:100px;text-transform:capitalize}.mastery-track{flex:1;height:12px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.mastery-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width .5s ease}.mastery-pct{font-weight:700;font-size:13px;color:var(--color-text-muted);min-width:40px;text-align:right}.mastery-mini{display:flex;align-items:center;gap:4px}.mastery-mini .mastery-track{width:60px;height:6px}.mastery-mini .mastery-pct{font-size:11px;min-width:32px}.dashboard-stats{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg);flex-wrap:wrap}.dashboard-stat{flex:1;min-width:120px;background:var(--color-surface);border-radius:var(--radius-md);border:2px solid var(--color-border);padding:var(--space-md);text-align:center}.dashboard-stat-value{font-family:var(--font-display);font-size:28px;color:var(--color-primary)}.dashboard-stat-label{font-size:12px;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:4px}.dashboard-loading{text-align:center;padding:var(--space-xl);color:var(--color-text-muted);font-weight:600}.parent-report{padding:16px;max-width:600px;margin:0 auto}.report-back-btn{background:none;border:none;color:var(--color-primary, #6c5ce7);cursor:pointer;font-size:14px;font-weight:700;padding:8px 0;font-family:inherit}.report-title{font-size:20px;font-weight:800;color:var(--color-text, #2d3436);margin:8px 0 4px}.report-date{font-size:12px;color:var(--color-text-muted, #888);margin-bottom:16px}.report-ai-summary{background:linear-gradient(135deg,#6c5ce714,#a78bfa14);border-radius:16px;padding:16px;margin-bottom:16px}.report-ai-summary h3{font-size:14px;font-weight:700;color:var(--color-primary, #6c5ce7);margin:0 0 8px}.report-ai-summary p{font-size:13px;line-height:1.6;color:var(--color-text, #2d3436);margin:0;white-space:pre-line}.report-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.report-stat{background:var(--color-surface, #fff);border:1px solid var(--color-border, #e0e0e0);border-radius:12px;padding:12px 8px;text-align:center;display:flex;flex-direction:column;gap:2px}.report-stat-value{font-size:20px;font-weight:800;color:var(--color-primary, #6c5ce7)}.report-stat-label{font-size:11px;font-weight:600;color:var(--color-text-muted, #888)}.report-skills{margin-bottom:16px}.report-skills h3{font-size:14px;font-weight:700;margin:0 0 8px}.report-skill-bar{display:flex;align-items:center;gap:8px;margin-bottom:6px}.report-skill-name{font-size:12px;font-weight:600;min-width:80px;text-transform:capitalize}.report-skill-track{flex:1;height:8px;background:var(--color-border, #e0e0e0);border-radius:4px;overflow:hidden}.report-skill-fill{height:100%;background:linear-gradient(90deg,#6c5ce7,#a78bfa);border-radius:4px;transition:width .3s}.report-skill-pct{font-size:11px;font-weight:700;min-width:32px;text-align:right}.report-recent{margin-bottom:16px}.report-recent h3{font-size:14px;font-weight:700;margin:0 0 8px}.report-recent-item{display:flex;justify-content:space-between;padding:8px;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e0e0e0);border-radius:8px;margin-bottom:4px;font-size:12px}.report-loading{padding:40px;text-align:center;color:var(--color-text-muted);font-weight:600}.report-error{padding:24px;text-align:center;color:var(--color-danger, #e17055)}.voice-control{display:flex;gap:4px;align-items:center}.voice-btn{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:#ffffff1a;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}.voice-btn:hover{background:#fff3}.voice-btn--active{border-color:#6c5ce799;background:#6c5ce733}.voice-mic-btn--active{border-color:#e1705599;background:#e1705533;animation:voicePulse 1.5s infinite}@keyframes voicePulse{0%,to{box-shadow:0 0 #e170554d}50%{box-shadow:0 0 0 6px #e1705500}}.mobile-editor{display:none;flex-direction:column;flex:1;height:100%;min-height:0;position:relative;overflow:hidden;background:var(--color-bg, #f7f8fc)}@media (max-width: 600px){.mobile-editor{display:flex}}.mobile-challenge{flex-shrink:0;background:#fff;border-bottom:1px solid var(--color-border, #e8e8e8);overflow:hidden;transition:max-height .3s ease}.mobile-challenge--collapsed .mobile-challenge-body{display:none}.mobile-challenge-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 16px;background:none;border:none;font-family:var(--font-body, "Nunito", sans-serif);font-size:14px;font-weight:700;color:var(--color-text, #333);cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-challenge-chevron{font-size:10px;color:var(--color-text-muted, #999)}.mobile-challenge-body{padding:0 16px 12px}.mobile-challenge-objective{margin:0;font-size:13px;color:var(--color-text-muted, #666);line-height:1.4}.mobile-challenge-constraint{display:inline-block;margin-top:6px;padding:2px 8px;font-size:11px;font-weight:700;color:var(--color-warning, #e67e22);background:#fdcb6e33;border-radius:8px}.mobile-editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;flex-shrink:0;border-bottom:1px solid var(--color-border, #e8e8e8);background:#fff}.mobile-editor-toolbar-label{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:15px;color:var(--color-text, #333)}.mobile-editor-toolbar-actions{display:flex;gap:8px}.mobile-editor-toolbar-btn{padding:6px 12px;font-size:12px;font-weight:700;font-family:var(--font-body, "Nunito", sans-serif);color:var(--color-text-muted, #666);background:var(--color-surface-alt, #f0f0f0);border:none;border-radius:8px;cursor:pointer;-webkit-tap-highlight-color:transparent;min-height:36px;min-width:44px}.mobile-editor-toolbar-btn:disabled{opacity:.4}.mobile-editor-toolbar-btn:active:not(:disabled){background:var(--color-border, #ddd)}.mobile-workspace{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.mobile-workspace-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 16px;display:flex;flex-direction:column;gap:4px}.mobile-workspace-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;color:var(--color-text-muted, #999);text-align:center}.mobile-workspace-empty-icon{font-size:40px;line-height:1;margin-bottom:8px;opacity:.4}.mobile-workspace-empty-text{font-size:15px;font-weight:700}.ws-block-wrapper{position:relative}.ws-block-wrapper.ws-block--executing .ws-block{box-shadow:0 0 0 3px #fffc,0 0 12px #ffd70099;animation:ws-block-pulse .6s ease-in-out infinite alternate}@keyframes ws-block-pulse{0%{transform:scale(1)}to{transform:scale(1.02)}}.ws-block{position:relative;display:flex;flex-direction:column;border-radius:12px;color:#fff;box-shadow:0 2px #00000026;z-index:1;-webkit-tap-highlight-color:transparent;touch-action:pan-y}.ws-block-header{display:flex;align-items:center;min-height:56px;padding:0 12px;gap:8px}.ws-block--nested .ws-block-header{min-height:48px}.ws-block-label{font-family:var(--font-body, "Nunito", sans-serif);font-size:15px;font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-block--nested .ws-block-label{font-size:13px}.ws-block-param{display:flex;align-items:center;justify-content:center;min-width:36px;height:32px;padding:0 10px;background:#ffffff40;border:2px solid rgba(255,255,255,.4);border-radius:8px;color:#fff;font-family:var(--font-body, "Nunito", sans-serif);font-size:16px;font-weight:800;cursor:pointer;-webkit-tap-highlight-color:transparent}.ws-block-param:active{background:#fff6}.ws-block-reorder{display:flex;flex-direction:column;gap:2px;margin-left:auto}.ws-block-reorder-btn{width:28px;height:22px;display:flex;align-items:center;justify-content:center;background:#fff3;border:none;border-radius:4px;color:#fff;font-size:12px;cursor:pointer;-webkit-tap-highlight-color:transparent;padding:0}.ws-block-reorder-btn:active{background:#fff6}.ws-block-delete-zone{position:absolute;right:0;top:0;bottom:0;width:80px;display:flex;align-items:center;justify-content:center;background:#e74c3c;border-radius:12px;color:#fff;font-weight:700;font-size:13px;transition:opacity .15s;z-index:0}.ws-block-body{margin-left:16px;padding:6px 0 6px 12px;border-left:4px solid rgba(0,0,0,.15);display:flex;flex-direction:column;gap:4px}.ws-block-else-label{margin-left:16px;padding:4px 12px;font-size:12px;font-weight:800;color:#fff;border-radius:0 0 0 8px;width:fit-content;text-transform:uppercase;letter-spacing:.5px}.ws-insertion-point{display:flex;align-items:center;justify-content:center;width:100%;min-height:48px;border:2px dashed var(--color-primary, #6c5ce7);border-radius:12px;background:#6c5ce70d;color:var(--color-primary, #6c5ce7);font-family:var(--font-body, "Nunito", sans-serif);font-size:14px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s}.ws-insertion-point:active{background:#6c5ce71f;border-color:var(--color-primary-dark, #5a4bd1)}.ws-insertion-point--small{min-height:24px;font-size:16px;border-width:1px;opacity:.5;border-radius:6px}.ws-insertion-point--small:active{opacity:1}.ws-number-picker{padding:8px 12px 12px;background:#0000001a;border-radius:0 0 12px 12px}.ws-number-picker-label{font-size:11px;font-weight:700;margin-bottom:6px;opacity:.8}.ws-number-picker-row{display:flex;gap:6px;flex-wrap:wrap}.ws-number-picker-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:#ffffff26;color:#fff;font-family:var(--font-body, "Nunito", sans-serif);font-size:16px;font-weight:800;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s,background .1s}.ws-number-picker-btn:active{transform:scale(.9)}.ws-number-picker-btn--active{background:#fff;color:#333;border-color:#fff;transform:scale(1.1);box-shadow:0 2px 8px #0003}.mobile-run-btn{display:flex;align-items:center;justify-content:center;margin:8px 16px;padding:0;height:56px;border:none;border-radius:16px;background:linear-gradient(135deg,#00b894,#00a085);color:#fff;font-family:var(--font-display, "Fredoka One", sans-serif);font-size:20px;letter-spacing:1px;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 4px 12px #00b8944d;flex-shrink:0;transition:transform .1s,box-shadow .1s}.mobile-run-btn:active:not(:disabled){transform:scale(.97);box-shadow:0 2px 6px #00b8944d}.mobile-run-btn:disabled{opacity:.4;cursor:default}.mobile-run-btn--stop{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c4d}.block-tray-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:49;-webkit-tap-highlight-color:transparent}.block-tray{position:fixed;bottom:0;left:0;right:0;background:#fff;border-radius:20px 20px 0 0;box-shadow:0 -4px 20px #0000001f;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:50;max-height:45vh;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0px)}.block-tray--open{transform:translateY(0)}.block-tray-handle{width:40px;height:4px;background:#d0d0d0;border-radius:2px;margin:10px auto;flex-shrink:0}.block-tray-list{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4px 16px 16px;display:flex;flex-direction:column;gap:6px;overscroll-behavior:contain}.block-tray-empty{padding:24px 16px;text-align:center;color:var(--color-text-muted, #999);font-size:14px}.category-pills{display:flex;gap:8px;padding:8px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;scrollbar-width:none}.category-pills::-webkit-scrollbar{display:none}.category-pill{flex-shrink:0;padding:8px 16px;border-radius:20px;border:2px solid var(--pill-color, #ccc);background:#fff;color:var(--pill-color, #333);font-family:var(--font-body, "Nunito", sans-serif);font-size:13px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s,color .15s;min-height:40px}.category-pill--active{background:var(--pill-color, #6c5ce7);color:#fff}.category-pill:active{transform:scale(.95)}.block-option{display:flex;align-items:center;min-height:52px;padding:0 16px;border-radius:12px;border:none;color:#fff;font-family:var(--font-body, "Nunito", sans-serif);cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 2px #0000001f;transition:transform .1s;width:100%;text-align:left}.block-option:active{transform:scale(.97)}.block-option-label{font-size:15px;font-weight:700;flex:1}.block-option-badge{font-size:11px;opacity:.7;padding:2px 6px;background:#fff3;border-radius:4px}.block-tray-context{padding:6px 16px;font-size:12px;font-weight:700;color:var(--color-primary, #6c5ce7);background:#6c5ce714;border-bottom:1px solid rgba(108,92,231,.12);text-align:center;flex-shrink:0}.ws-block--cursor-parent>.ws-block{box-shadow:0 0 0 2px #6c5ce780,0 2px 8px #6c5ce733}.ws-block-body--active{border-left-color:var(--color-primary, #6c5ce7)!important;background:#6c5ce70a;border-radius:0 0 8px 8px}.ws-insertion-point--highlight{min-height:40px;border-width:2px;border-color:var(--color-primary, #6c5ce7);background:#6c5ce71a;opacity:1!important;font-size:13px;animation:ws-insertion-pulse 1.2s ease-in-out infinite}@keyframes ws-insertion-pulse{0%,to{border-color:#6c5ce766;background:#6c5ce70f}50%{border-color:#6c5ce7cc;background:#6c5ce724}}.ws-block--dragged{opacity:.85;transform:scale(1.04);z-index:100;box-shadow:0 8px 24px #00000040;pointer-events:none}.ws-drop-zone{height:4px;transition:height .15s ease,border-color .15s ease;border-radius:4px}.ws-drop-zone--active{height:40px;border:2px dashed var(--color-primary, #6c5ce7);background:#6c5ce70f;margin:2px 0}@media (pointer: coarse){.ws-block-reorder{display:none}}@keyframes mobile-block-slide-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ws-block-wrapper{animation:mobile-block-slide-in .2s ease-out}@keyframes dc-float{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}@keyframes dc-fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes dc-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes dc-pulse{0%,to{transform:scale(1);box-shadow:0 0 #fbbf2473}50%{transform:scale(1.06);box-shadow:0 0 0 14px #fbbf2400}}@keyframes dc-starPop{0%{opacity:0;transform:scale(0) rotate(-30deg)}60%{opacity:1;transform:scale(1.3) rotate(8deg)}80%{transform:scale(.9) rotate(-3deg)}to{transform:scale(1) rotate(0)}}@keyframes dc-confettiFall{0%{opacity:1;transform:translateY(-10vh) rotate(0)}to{opacity:0;transform:translateY(105vh) rotate(720deg)}}@keyframes dc-dotPulse{0%,80%,to{opacity:.25;transform:scale(.7)}40%{opacity:1;transform:scale(1)}}@keyframes dc-shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes dc-slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes dc-coinBounce{0%{transform:scale(1)}30%{transform:scale(1.25)}60%{transform:scale(.95)}to{transform:scale(1)}}@keyframes dc-badgePop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes dc-glow{0%,to{box-shadow:0 0 20px #fbbf2426}50%{box-shadow:0 0 40px #fbbf2459}}@keyframes dc-streakPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.dc-page{min-height:100vh;min-height:100dvh;background:linear-gradient(135deg,#1a1a2e,#16213e);font-family:var(--font-body, "Nunito", sans-serif);display:flex;flex-direction:column;color:#fff;overflow-x:hidden;position:relative}.dc-loading-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px 20px}.dc-loading-icon{font-size:64px;animation:dc-float 2.5s ease-in-out infinite;filter:drop-shadow(0 8px 24px rgba(0,0,0,.3))}.dc-loading-dots{display:flex;gap:8px}.dc-dot{width:10px;height:10px;border-radius:50%;background:#fbbf24;animation:dc-dotPulse 1.4s ease-in-out infinite}.dc-dot:nth-child(2){animation-delay:.2s}.dc-dot:nth-child(3){animation-delay:.4s}.dc-loading-msg{font-size:15px;color:#fff9;font-weight:600;animation:dc-fadeIn .4s ease;min-height:1.5em;text-align:center}.dc-reveal-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 24px;text-align:center}.dc-reveal-icon{font-size:80px;animation:dc-float 3s ease-in-out infinite;filter:drop-shadow(0 10px 30px rgba(0,0,0,.35));margin-bottom:8px}.dc-reveal-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:clamp(28px,6vw,44px);color:#fbbf24;margin:0;animation:dc-fadeInUp .6s ease .2s both;text-shadow:0 2px 20px rgba(251,191,36,.3)}.dc-reveal-date{font-size:15px;color:#ffffff8c;font-weight:600;animation:dc-fadeInUp .6s ease .35s both;margin:0}.dc-difficulty-badge{display:inline-block;padding:5px 18px;border-radius:20px;font-size:13px;font-weight:800;color:#1a1a2e;text-transform:uppercase;letter-spacing:.05em;animation:dc-badgePop .4s ease .5s both}.dc-difficulty-badge--sm{padding:2px 10px;font-size:11px;border-radius:12px}.dc-letsgo-btn{margin-top:24px;padding:16px 56px;border:none;border-radius:16px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e;font-family:var(--font-display, "Fredoka One", sans-serif);font-size:20px;font-weight:800;cursor:pointer;animation:dc-pulse 2s ease-in-out infinite .8s;transition:transform .15s ease,filter .15s ease}.dc-letsgo-btn:hover{filter:brightness(1.1);transform:scale(1.04)}.dc-letsgo-btn:active{transform:scale(.97)}.dc-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;z-index:10}.dc-topbar-back{background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#ffffffd9;padding:6px 14px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s ease,transform .1s ease;flex-shrink:0;font-family:var(--font-body, "Nunito", sans-serif)}.dc-topbar-back:hover{background:#ffffff24;transform:translate(-2px)}.dc-topbar-center{text-align:center;min-width:0;flex:1}.dc-topbar-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:16px;color:#fbbf24;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dc-topbar-meta{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:2px}.dc-topbar-date{font-size:11px;color:#ffffff73;font-weight:600}.dc-topbar-coins{display:flex;align-items:center;gap:4px;background:#fbbf241f;border:1px solid rgba(251,191,36,.2);padding:5px 12px;border-radius:10px;font-size:13px;font-weight:800;color:#fbbf24;flex-shrink:0}.dc-topbar-coin-icon{font-size:15px}.dc-error-banner{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:13px;font-weight:600;animation:dc-slideUp .3s ease;flex-shrink:0}.dc-error-icon{flex-shrink:0}.dc-error-dismiss{margin-left:auto;background:none;border:none;color:#ffffff80;cursor:pointer;padding:2px 6px;font-size:14px;border-radius:4px;transition:color .15s ease}.dc-error-dismiss:hover{color:#fff}.dc-description-bar{text-align:center;font-size:13px;color:#fff9;padding:8px 16px;font-weight:600;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.05);flex-shrink:0}.dc-play-area{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:6px;min-height:0;overflow:hidden}.dc-canvas-wrapper{border-radius:14px;overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);min-height:0;display:flex;align-items:center;justify-content:center}.dc-canvas-wrapper canvas{max-width:100%;max-height:100%}.dc-editor-wrapper{border-radius:14px;overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);min-height:0}.dc-action-bar{display:flex;gap:10px;justify-content:center;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:#16213ed9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.08);flex-shrink:0;position:sticky;bottom:0;z-index:10}.dc-action-btn{padding:12px 28px;border:none;border-radius:14px;font-family:var(--font-display, "Fredoka One", sans-serif);font-size:15px;font-weight:800;cursor:pointer;transition:transform .12s ease,filter .12s ease,box-shadow .12s ease}.dc-action-btn:active{transform:scale(.95)}.dc-action-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.dc-action-btn--run{background:linear-gradient(135deg,#55efc4,#00b894);color:#1a1a2e;box-shadow:0 4px 16px #55efc44d;flex:1;max-width:220px}.dc-action-btn--run:hover:not(:disabled){filter:brightness(1.1);box-shadow:0 6px 24px #55efc473;transform:translateY(-1px)}.dc-action-btn--reset{background:#ffffff1a;color:#fffc;border:1px solid rgba(255,255,255,.15)}.dc-action-btn--reset:hover{background:#ffffff29;transform:translateY(-1px)}.dc-completion-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden}.dc-completion-card{background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px 32px;text-align:center;max-width:400px;width:100%;animation:dc-slideUp .5s ease .1s both;display:flex;flex-direction:column;align-items:center;gap:16px}.dc-completion-heading{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:clamp(24px,5vw,32px);color:#fbbf24;margin:0;text-shadow:0 2px 16px rgba(251,191,36,.3)}.dc-stars{display:flex;gap:8px;justify-content:center}.dc-star{font-size:44px;display:inline-block;transition:transform .2s ease}.dc-star--earned{filter:drop-shadow(0 2px 8px rgba(251,191,36,.5))}.dc-star--empty{color:#fff3;font-size:40px}.dc-star--animated{opacity:0;animation:dc-starPop .6s cubic-bezier(.34,1.56,.64,1) forwards}.dc-coin-reward{display:flex;align-items:center;gap:8px;background:#fbbf241a;border:1px solid rgba(251,191,36,.2);padding:10px 20px;border-radius:14px;animation:dc-fadeInUp .5s ease .8s both}.dc-coin-icon{font-size:24px;animation:dc-coinBounce .6s ease 1.2s}.dc-coin-value{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:22px;color:#fbbf24;font-weight:800}.dc-coin-label{font-size:13px;color:#ffffff8c;font-weight:600}.dc-streak-display{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ff6b351a;border:1px solid rgba(255,107,53,.2);border-radius:12px;animation:dc-fadeInUp .5s ease 1s both}.dc-streak-flame{font-size:22px;animation:dc-streakPulse 1.5s ease-in-out infinite}.dc-streak-count{font-weight:800;font-size:15px;color:#ffb347}.dc-streak-best{font-size:11px;font-weight:800;color:#fbbf24;background:#fbbf2426;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.04em}.dc-countdown{display:flex;flex-direction:column;align-items:center;gap:4px;animation:dc-fadeIn .5s ease 1.2s both}.dc-countdown-label{font-size:12px;color:#fff6;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.dc-countdown-time{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:28px;color:#ffffffb3;letter-spacing:.06em;background:linear-gradient(90deg,#ffffff80,#fff,#ffffff80);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:dc-shimmer 3s linear infinite}.dc-completion-actions{display:flex;gap:10px;width:100%;margin-top:8px;animation:dc-fadeInUp .5s ease 1.4s both}.dc-share-btn{flex:1;padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#ffffffd9;font-weight:700;font-size:14px;cursor:pointer;transition:background .15s ease,transform .1s ease;font-family:var(--font-body, "Nunito", sans-serif)}.dc-share-btn:hover{background:#ffffff24;transform:translateY(-1px)}.dc-share-btn:active{transform:scale(.97)}.dc-back-btn{flex:1;padding:12px 16px;border-radius:14px;border:none;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a2e;font-family:var(--font-display, "Fredoka One", sans-serif);font-weight:800;font-size:14px;cursor:pointer;transition:filter .15s ease,transform .1s ease}.dc-back-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.dc-back-btn:active{transform:scale(.97)}.dc-confetti{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:50;overflow:hidden}.dc-confetti-piece{position:absolute;top:-10px;border-radius:2px;animation:dc-confettiFall linear forwards;opacity:0}.dc-already-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}.dc-already-card{background:#ffffff0f;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px 32px;text-align:center;max-width:400px;width:100%;animation:dc-slideUp .5s ease both;display:flex;flex-direction:column;align-items:center;gap:14px}.dc-already-check{font-size:56px;animation:dc-float 3s ease-in-out infinite}.dc-already-heading{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:clamp(22px,5vw,28px);color:#55efc4;margin:0}.dc-already-sub{font-size:14px;color:#ffffff80;margin:0}@media (max-width: 768px){.dc-play-area{grid-template-columns:1fr;grid-template-rows:minmax(220px,40vh) 1fr;gap:4px;padding:4px}.dc-canvas-wrapper{min-height:200px}.dc-editor-wrapper{min-height:220px}.dc-topbar{padding:8px 12px}.dc-topbar-title{font-size:14px}.dc-topbar-date{font-size:10px}.dc-action-bar{padding:10px 12px;padding-bottom:max(10px,env(safe-area-inset-bottom))}.dc-action-btn{padding:10px 20px;font-size:14px}.dc-action-btn--run{max-width:none}.dc-completion-card,.dc-already-card{padding:28px 20px;margin:0 8px;border-radius:20px}.dc-star{font-size:36px}.dc-star--empty{font-size:33px}.dc-countdown-time{font-size:24px}.dc-completion-actions{flex-direction:column}.dc-reveal-icon{font-size:64px}.dc-letsgo-btn{padding:14px 44px;font-size:18px}}@media (max-width: 380px){.dc-topbar-coins{padding:4px 8px;font-size:12px}.dc-topbar-back{padding:5px 10px;font-size:12px}.dc-topbar-title{font-size:13px}.dc-play-area{grid-template-rows:minmax(180px,35vh) 1fr}}@media (min-width: 769px){.dc-play-area{grid-template-columns:1fr 1fr;max-height:calc(100vh - 160px)}.dc-canvas-wrapper,.dc-editor-wrapper{min-height:300px}}@media (min-width: 1200px){.dc-play-area{padding:10px 24px;gap:12px}.dc-action-bar{padding:14px 24px}.dc-topbar{padding:12px 24px}}@media (prefers-reduced-motion: reduce){.dc-reveal-icon,.dc-loading-icon,.dc-already-check,.dc-letsgo-btn{animation:none}.dc-star--animated{animation:dc-fadeIn .3s ease forwards}.dc-confetti-piece{animation:none;display:none}.dc-countdown-time{animation:none;-webkit-text-fill-color:rgba(255,255,255,.7)}.dc-dot{animation:none;opacity:.6}.dc-streak-flame{animation:none}}.sandbox-page{min-height:100vh;min-height:100dvh;background:linear-gradient(145deg,#1a1a2e,#16213e,#0f3460);font-family:var(--font-body, "Nunito", sans-serif);display:flex;flex-direction:column;overflow:hidden}.sandbox-topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;flex-wrap:wrap}.sandbox-back-btn{display:flex;align-items:center;gap:4px;padding:6px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#ffffffd9;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.sandbox-back-btn:hover{background:#ffffff26;color:#fff}.sandbox-brand{display:flex;align-items:center;gap:8px}.sandbox-brand-icon{font-size:22px}.sandbox-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:18px;color:#fff;margin:0;white-space:nowrap}.sandbox-toolbar-controls{display:flex;align-items:center;gap:10px;margin-left:auto;flex-wrap:wrap}.sandbox-control-group{display:flex;align-items:center;gap:4px}.sandbox-select{padding:5px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff1a;color:#fff;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.sandbox-select:hover{background:#ffffff2e}.sandbox-select option{color:#2d3436;background:#fff}.sandbox-select--sm{padding:5px 6px;min-width:60px}.sandbox-size-x{color:#fff6;font-size:11px;font-weight:700}.sandbox-gen-btns{display:flex;gap:6px}.sandbox-gen-btn{padding:5px 12px;border-radius:8px;border:none;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s}.sandbox-gen-btn:hover{transform:translateY(-1px)}.sandbox-gen-btn:active{transform:scale(.96)}.sandbox-gen-btn--empty{background:#ffffff1f;color:#ffffffd9;border:1px solid rgba(255,255,255,.15)}.sandbox-gen-btn--empty:hover{background:#fff3}.sandbox-gen-btn--maze{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff}.sandbox-gen-btn--maze:hover{background:linear-gradient(135deg,#7c6cf7,#b2abfe);box-shadow:0 2px 12px #6c5ce766}.sandbox-content{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;min-height:0;overflow:hidden}.sandbox-panel{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);min-height:0}.sandbox-panel-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff0f;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:700;color:#ffffffe6;flex-shrink:0}.sandbox-panel-icon{font-size:16px}.sandbox-panel-hint{margin-left:auto;font-size:11px;font-weight:500;color:#fff6}.sandbox-stage-panel{position:relative}.sandbox-stage{flex:1;min-height:0;border-radius:0;overflow:hidden}.sandbox-toast{position:absolute;bottom:12px;left:12px;right:12px;display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;font-size:13px;font-weight:700;animation:sandbox-slideUp .3s ease-out;z-index:10}.sandbox-toast--success{background:#00b894e6;color:#fff;box-shadow:0 4px 16px #00b8944d}.sandbox-toast--error{background:#e17055e6;color:#fff;box-shadow:0 4px 16px #e170554d}.sandbox-step-badge{margin-left:auto;padding:2px 10px;border-radius:20px;background:#6c5ce74d;color:#fffc;font-size:11px;font-weight:600}.sandbox-editor-panel{display:flex;flex-direction:column}.sandbox-editor{flex:1;min-height:0;overflow:hidden}.sandbox-editor .panel{border:none;border-radius:0;box-shadow:none;background:transparent;height:100%;display:flex;flex-direction:column}.sandbox-editor .panel-header{display:none}.sandbox-editor .blockly-panel-body{flex:1;min-height:0}.sandbox-action-bar{display:flex;gap:6px;padding:8px 10px;background:#ffffff0f;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.sandbox-action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:10px;border:none;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.sandbox-action-btn:hover{transform:translateY(-1px)}.sandbox-action-btn:active{transform:scale(.96)}.sandbox-action-btn--run{flex:1;background:linear-gradient(135deg,#00b894,#00cec9);color:#fff;box-shadow:0 2px 10px #00b8944d}.sandbox-action-btn--run:hover{box-shadow:0 4px 16px #00b89466}.sandbox-action-btn--run:disabled{opacity:.7;cursor:not-allowed;transform:none}.sandbox-action-btn--running{background:linear-gradient(135deg,#fdcb6e,#f39c12);animation:sandbox-pulse 1.2s infinite}.sandbox-action-btn--reset{background:#ffffff1a;color:#ffffffd9;border:1px solid rgba(255,255,255,.12)}.sandbox-action-btn--reset:hover{background:#ffffff2e}.sandbox-action-btn--clear{background:#e1705526;color:#ffffffb3;border:1px solid rgba(225,112,85,.2)}.sandbox-action-btn--clear:hover{background:#e1705540;color:#fff}@keyframes sandbox-slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes sandbox-pulse{0%,to{box-shadow:0 2px 10px #f39c124d}50%{box-shadow:0 4px 20px #f39c1280}}@media (max-width: 768px){.sandbox-content{grid-template-columns:1fr;gap:8px;padding:8px}.sandbox-stage-panel{max-height:45vh}.sandbox-topbar{gap:8px;padding:8px 12px}.sandbox-brand-icon{display:none}.sandbox-title{font-size:15px}.sandbox-toolbar-controls{width:100%;justify-content:center}.sandbox-action-bar{padding:8px}.sandbox-action-btn{padding:10px 12px;font-size:12px}}@media (max-width: 480px){.sandbox-toolbar-controls{flex-wrap:wrap;gap:6px}.sandbox-gen-btns{width:100%;justify-content:center}}@media (prefers-reduced-motion: reduce){.sandbox-action-btn--running,.sandbox-toast{animation:none}}.wb-page{min-height:100vh;min-height:100dvh;background:linear-gradient(145deg,#1a1a2e,#16213e,#0f3460);font-family:var(--font-body, "Nunito", sans-serif);display:flex;flex-direction:column;overflow:hidden}.wb-topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#ffffff0f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;flex-wrap:wrap}.wb-back-btn{display:flex;align-items:center;gap:4px;padding:6px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#ffffffd9;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.wb-back-btn:hover{background:#ffffff26;color:#fff}.wb-brand{display:flex;align-items:center;gap:8px}.wb-brand-icon{font-size:22px}.wb-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:18px;color:#fff;margin:0;white-space:nowrap}.wb-toolbar-controls{display:flex;align-items:center;gap:10px;margin-left:auto;flex-wrap:wrap}.wb-select{padding:5px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff1a;color:#fff;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s}.wb-select:hover{background:#ffffff2e}.wb-select option{color:#2d3436;background:#fff}.wb-palette{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;flex-shrink:0;justify-content:center;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06)}.wb-palette::-webkit-scrollbar{display:none}.wb-tile-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 12px;min-width:56px;min-height:48px;border-radius:10px;border:2px solid rgba(255,255,255,.1);background:#ffffff0f;color:#ffffffbf;font-size:10px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;flex-shrink:0}.wb-tile-btn:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(-1px)}.wb-tile-btn--active{border-color:#6c5ce7;background:#6c5ce733;color:#fff;box-shadow:0 2px 12px #6c5ce74d}.wb-tile-emoji{font-size:20px}.wb-edit-content{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.wb-canvas-area{flex:1;min-height:0;padding:8px 16px;display:flex;align-items:center;justify-content:center}.wb-settings{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#ffffff0a;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0;flex-wrap:wrap}.wb-input{padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;font-size:13px;font-weight:600;font-family:inherit;min-width:120px}.wb-input::placeholder{color:#ffffff59}.wb-label{font-size:11px;font-weight:700;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.wb-actions{display:flex;gap:8px;padding:10px 16px;flex-shrink:0;flex-wrap:wrap}.wb-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:10px;border:none;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.wb-btn:hover{transform:translateY(-1px)}.wb-btn:active{transform:scale(.96)}.wb-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.wb-btn--test{flex:1;background:linear-gradient(135deg,#00b894,#00cec9);color:#fff;box-shadow:0 2px 10px #00b8944d}.wb-btn--test:hover{box-shadow:0 4px 16px #00b89466}.wb-btn--save{background:linear-gradient(135deg,#6c5ce7,#a78bfa);color:#fff;box-shadow:0 2px 10px #6c5ce74d}.wb-btn--save:hover{box-shadow:0 4px 16px #6c5ce766}.wb-btn--secondary{background:#ffffff1a;color:#ffffffd9;border:1px solid rgba(255,255,255,.12)}.wb-btn--secondary:hover{background:#ffffff2e}.wb-btn--danger{background:#e1705526;color:#ffffffb3;border:1px solid rgba(225,112,85,.2)}.wb-btn--danger:hover{background:#e1705540;color:#fff}.wb-play-content{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;min-height:0;overflow:hidden}.wb-panel{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);min-height:0}.wb-panel-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff0f;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:700;color:#ffffffe6;flex-shrink:0}.wb-stage,.wb-editor{flex:1;min-height:0;overflow:hidden}.wb-editor .panel{border:none;border-radius:0;box-shadow:none;background:transparent;height:100%;display:flex;flex-direction:column}.wb-editor .panel-header{display:none}.wb-editor .blockly-panel-body{flex:1;min-height:0}.wb-play-actions{display:flex;gap:6px;padding:8px 10px;background:#ffffff0f;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.wb-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;font-size:14px;font-weight:700;z-index:100;animation:wb-slideUp .3s ease-out}.wb-toast--success{background:#00b894f2;color:#fff;box-shadow:0 4px 16px #00b8944d}.wb-toast--error{background:#e17055f2;color:#fff;box-shadow:0 4px 16px #e170554d}.wb-blocks-panel{padding:10px 16px;background:#ffffff08;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.wb-blocks-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#ffffffb3;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}.wb-blocks-toggle:hover{background:#ffffff1f}.wb-blocks-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.wb-block-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;border:none;font-family:inherit}.wb-block-chip--on{background:#6c5ce740;color:#c4b5fd}.wb-block-chip--off{background:#ffffff0f;color:#ffffff59;text-decoration:line-through}.wb-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;animation:wb-fadeIn .2s}.wb-modal{background:#1e1e3a;border-radius:16px;border:1px solid rgba(255,255,255,.1);width:90%;max-width:420px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden}.wb-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.wb-modal-title{font-size:16px;font-weight:800;color:#fff}.wb-modal-close{padding:4px 10px;border-radius:8px;border:none;background:#ffffff1a;color:#ffffffb3;font-size:14px;cursor:pointer;font-family:inherit}.wb-modal-body{flex:1;overflow-y:auto;padding:12px}.wb-world-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);margin-bottom:8px;cursor:pointer;transition:all .2s}.wb-world-item:hover{background:#6c5ce726;border-color:#6c5ce74d}.wb-world-name{flex:1;font-size:14px;font-weight:700;color:#fff}.wb-world-date{font-size:11px;color:#fff6}.wb-world-delete{padding:4px 8px;border-radius:6px;border:none;background:#e1705533;color:#fff9;font-size:12px;cursor:pointer;font-family:inherit;transition:all .2s}.wb-world-delete:hover{background:#e1705566;color:#fff}.wb-empty{text-align:center;padding:30px 20px;color:#fff6;font-size:14px;font-weight:600}@keyframes wb-slideUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@keyframes wb-fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.wb-play-content{grid-template-columns:1fr;gap:8px;padding:8px}.wb-topbar{gap:8px;padding:8px 12px}.wb-brand-icon{display:none}.wb-title{font-size:15px}.wb-toolbar-controls{width:100%;justify-content:center}.wb-palette{justify-content:flex-start;padding:8px 12px}.wb-settings,.wb-actions{padding:8px 12px}}@media (max-width: 480px){.wb-toolbar-controls{flex-wrap:wrap;gap:6px}.wb-actions{flex-direction:column}.wb-btn{width:100%}}@media (prefers-reduced-motion: reduce){.wb-toast,.wb-modal-backdrop{animation:none}.wb-tile-btn:hover,.wb-btn:hover{transform:none}}.lb-page{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);font-family:var(--font-body, "Nunito", sans-serif)}.lb-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.1)}.lb-title{font-size:22px;font-weight:800;color:#fbbf24;margin:0;font-family:var(--font-display, "Fredoka One", sans-serif)}.lb-week{font-size:11px;color:#ffffff80}.lb-my-rank{font-size:14px;font-weight:700;color:#fbbf24;background:#fbbf2426;padding:6px 12px;border-radius:20px}.lb-loading,.lb-empty{text-align:center;padding:60px 20px;color:#ffffff80;font-weight:600}.lb-list{padding:12px 16px;display:flex;flex-direction:column;gap:6px;max-width:600px;margin:0 auto}.lb-entry{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#ffffff0f;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.lb-entry--me{background:#6c5ce726;border-color:#6c5ce74d}.lb-entry--top{background:#fbbf2414;border-color:#fbbf2433}.lb-rank{font-size:18px;font-weight:800;min-width:36px;text-align:center;color:#fffc}.lb-user{flex:1;display:flex;flex-direction:column}.lb-name{font-size:14px;font-weight:700;color:#fff}.lb-stats-mini{font-size:11px;color:#ffffff80}.lb-scores{display:flex;gap:12px}.lb-stars{font-size:13px;font-weight:700;color:#fbbf24}.lb-xp{font-size:13px;font-weight:700;color:#a78bfa}.upgrade-page{min-height:100vh;background:linear-gradient(135deg,var(--color-bg, #f5f3ff) 0%,#e8e0ff 100%);font-family:var(--font-body, "Nunito", sans-serif)}.upgrade-topbar{display:flex;align-items:center;gap:16px;padding:16px 24px;background:var(--color-surface, #fff);border-bottom:2px solid var(--color-border, #e0e0e0)}.upgrade-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:22px;color:var(--color-primary, #6c5ce7);margin:0}.upgrade-message{text-align:center;padding:12px;font-weight:700;color:var(--color-primary, #6c5ce7)}.upgrade-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px 16px;max-width:900px;margin:0 auto}.upgrade-card{background:var(--color-surface, #fff);border:2px solid var(--color-border, #e0e0e0);border-radius:20px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;position:relative}.upgrade-card--featured{border-color:var(--color-primary, #6c5ce7);box-shadow:0 8px 32px #6c5ce726;transform:scale(1.05)}.upgrade-card--current{border-color:var(--color-success, #00b894)}.upgrade-badge{position:absolute;top:-10px;background:var(--color-primary, #6c5ce7);color:#fff;font-size:11px;font-weight:800;padding:4px 12px;border-radius:20px}.upgrade-plan-name{font-size:20px;font-weight:800;margin:8px 0 4px;color:var(--color-text, #2d3436)}.upgrade-price{font-size:24px;font-weight:800;color:var(--color-primary, #6c5ce7);margin-bottom:16px}.upgrade-features{list-style:none;padding:0;margin:0 0 20px;width:100%}.upgrade-feature{padding:6px 0;font-size:13px;font-weight:600}.upgrade-feature--yes:before{content:"✓ ";color:var(--color-success, #00b894);font-weight:800}.upgrade-feature--no{opacity:.4;text-decoration:line-through}.upgrade-feature--no:before{content:"✗ ";color:var(--color-danger, #e17055);font-weight:800}.upgrade-btn{width:100%;padding:12px;border-radius:12px;font-size:14px;font-weight:800;cursor:pointer;border:none;font-family:inherit;transition:all .2s}.upgrade-btn--upgrade{background:linear-gradient(135deg,#6c5ce7,#a78bfa);color:#fff;box-shadow:0 4px 16px #6c5ce74d}.upgrade-btn--upgrade:hover{transform:translateY(-2px)}.upgrade-btn--upgrade:disabled{opacity:.6}.upgrade-btn--current{background:var(--color-border, #e0e0e0);color:var(--color-text-muted, #888);cursor:default}.upgrade-note{text-align:center;font-size:12px;color:var(--color-text-muted, #888);padding:16px}.upgrade-message--success{color:var(--color-success, #00b894);background:#00b89414;border-radius:12px}.upgrade-qty{display:flex;align-items:center;gap:10px;margin:8px 0 16px;width:100%}.upgrade-qty label{font-size:13px;font-weight:700;color:var(--color-text, #2d3436)}.upgrade-qty-input{width:64px;padding:6px 8px;border-radius:8px;border:2px solid var(--color-border, #e0e0e0);font-size:14px;font-weight:700;text-align:center;font-family:inherit}.upgrade-qty-input:focus{border-color:var(--color-primary, #6c5ce7);outline:none}.upgrade-qty-total{font-size:14px;font-weight:800;color:var(--color-primary, #6c5ce7)}.upgrade-manage-btn{display:block;margin:8px auto 0;padding:10px 28px;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;border:2px solid var(--color-primary, #6c5ce7);background:transparent;color:var(--color-primary, #6c5ce7);font-family:inherit;transition:all .2s}.upgrade-manage-btn:hover{background:var(--color-primary, #6c5ce7);color:#fff}.upgrade-legal{text-align:center;font-size:11px;color:var(--color-text-muted, #888);padding:0 16px 24px}.upgrade-legal a{color:var(--color-primary, #6c5ce7);text-decoration:underline}.upgrade-legal a:hover{opacity:.8}@media (max-width: 600px){.upgrade-plans{grid-template-columns:1fr}.upgrade-card--featured{transform:none}}.pet-widget{background:var(--color-surface, #fff);border:2px solid var(--color-border, #e0e0e0);border-radius:16px;padding:12px}.pet-widget--empty{display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .2s}.pet-widget--empty:hover{border-color:var(--color-primary, #6c5ce7);transform:scale(1.02)}.pet-egg{font-size:28px}.pet-adopt-text{font-size:13px;font-weight:700;color:var(--color-primary, #6c5ce7)}.pet-adopt-form{padding:16px}.pet-adopt-form h3{font-size:16px;font-weight:800;margin:0 0 12px;text-align:center}.pet-species-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:12px}.pet-species-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border:2px solid var(--color-border, #e0e0e0);border-radius:12px;background:var(--color-surface, #fff);cursor:pointer;font-family:inherit;transition:all .2s}.pet-species-btn:hover{border-color:var(--color-primary)}.pet-species-btn--selected{border-color:var(--color-primary, #6c5ce7);background:#6c5ce714}.pet-species-emoji{font-size:24px}.pet-species-name{font-size:9px;font-weight:700}.pet-name-input{width:100%;padding:10px 12px;border:2px solid var(--color-border, #e0e0e0);border-radius:10px;font-size:14px;font-family:inherit;margin-bottom:12px;box-sizing:border-box}.pet-name-input:focus{outline:none;border-color:var(--color-primary, #6c5ce7)}.pet-adopt-actions{display:flex;gap:8px}.pet-adopt-actions .btn{flex:1;padding:10px;border-radius:10px;font-weight:700}.pet-widget--compact{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer}.pet-emoji{font-size:20px}.pet-emoji-large{font-size:36px}.pet-bounce{animation:petBounce .6s ease}@keyframes petBounce{0%,to{transform:translateY(0)}30%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.pet-happiness-bar-mini{width:30px;height:4px;background:#e0e0e0;border-radius:2px;overflow:hidden}.pet-happiness-fill-mini{height:100%;background:#00b894;border-radius:2px;transition:width .3s}.pet-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.pet-info{display:flex;flex-direction:column}.pet-name{font-size:14px;font-weight:800;color:var(--color-text, #2d3436)}.pet-stage{font-size:11px;color:var(--color-text-muted, #888);font-weight:600}.pet-bars{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.pet-bar-row{display:flex;align-items:center;gap:6px}.pet-bar-label{font-size:10px;font-weight:700;min-width:36px;color:var(--color-text-muted, #888)}.pet-bar-track{flex:1;height:8px;background:var(--color-border, #e0e0e0);border-radius:4px;overflow:hidden}.pet-bar-fill{height:100%;border-radius:4px;transition:width .3s}.pet-bar-fill--happy{background:linear-gradient(90deg,#00b894,#55efc4)}.pet-bar-fill--xp{background:linear-gradient(90deg,#6c5ce7,#a78bfa)}.pet-bar-value{font-size:10px;font-weight:700;min-width:50px;text-align:right}.pet-feed-btn{width:100%;padding:8px;border:2px solid var(--color-border, #e0e0e0);border-radius:10px;background:var(--color-surface, #fff);cursor:pointer;font-size:12px;font-weight:700;font-family:inherit;transition:all .2s}.pet-feed-btn:hover:not(:disabled){border-color:#00b894;background:#00b89414}.pet-feed-btn:disabled{opacity:.5;cursor:not-allowed}.code-review{background:linear-gradient(135deg,#6c5ce714,#22d39a14);border:1px solid rgba(108,92,231,.15);border-radius:12px;padding:12px 16px;margin-top:12px}.code-review--loading{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--color-text-muted, #888);animation:reviewPulse 1.5s infinite}@keyframes reviewPulse{0%,to{opacity:.6}50%{opacity:1}}.code-review-header{display:flex;align-items:center;gap:6px;margin-bottom:6px}.code-review-icon{font-size:18px}.code-review-label{font-size:12px;font-weight:800;color:var(--color-primary, #6c5ce7);text-transform:uppercase;letter-spacing:.5px}.code-review-text{font-size:13px;line-height:1.5;color:var(--color-text, #2d3436);margin:0;font-weight:600}.adaptive-banner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#6c5ce71a,#a78bfa1a);border:1px solid rgba(108,92,231,.2);border-radius:12px;padding:10px 14px;margin:8px 16px}.adaptive-banner-content{display:flex;align-items:center;gap:10px}.adaptive-banner-emoji{font-size:28px}.adaptive-banner-text{display:flex;flex-direction:column;gap:2px}.adaptive-banner-level{font-size:12px;font-weight:800;color:var(--color-primary, #6c5ce7);text-transform:uppercase;letter-spacing:.5px}.adaptive-banner-rec{font-size:12px;color:var(--color-text, #2d3436);font-weight:600}.adaptive-banner-diff{font-size:10px;color:var(--color-text-muted, #888)}.adaptive-banner-dismiss{background:none;border:none;font-size:18px;color:var(--color-text-muted);cursor:pointer;padding:4px;line-height:1}.layout{display:flex;flex-direction:column;height:100%}.layout-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);min-height:56px;box-shadow:0 2px 8px #6c5ce74d}.layout-header h1{font-family:var(--font-display);font-size:22px;font-weight:400;color:#fff;letter-spacing:.5px}.layout-header .subtitle{font-size:13px;font-weight:600;color:#ffffffb3}.layout-main{flex:1;display:flex;flex-direction:column;overflow:auto;background:var(--color-bg)}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;width:100%;background:var(--color-bg)}.app-toolbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);flex-shrink:0;min-height:52px;box-shadow:0 2px 8px #6c5ce74d}.app-toolbar-brand{font-family:var(--font-display);font-size:22px;color:#fff;text-decoration:none;letter-spacing:.5px}.app-toolbar-level{font-size:15px;font-weight:700;color:#ffffffe6;margin-left:var(--space-sm)}.app-toolbar-spacer{flex:1}.app-toolbar-group{display:flex;align-items:center;gap:var(--space-sm)}.app-main{flex:1;display:flex;min-height:0;overflow:hidden;padding:var(--space-sm) var(--space-md);gap:var(--space-md)}.app-left{flex:3;display:flex;flex-direction:column;min-width:0;min-height:0}.app-right{flex:2;display:flex;flex-direction:column;gap:8px;min-width:0;min-height:0;overflow-y:auto}.app-instructions{flex:1;min-height:120px;overflow-y:auto}.app-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:4px 0;flex-shrink:0;flex-wrap:wrap}.panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.panel-header{padding:8px var(--space-md);border-bottom:1px solid var(--color-border);font-size:13px;font-weight:700;color:var(--color-primary);background:var(--color-surface-alt);display:flex;align-items:center;gap:var(--space-sm)}.panel-body{padding:var(--space-md)}.blockly-panel{display:flex;flex-direction:column;flex:1;min-height:300px}.blockly-panel-body{flex:1;min-height:0;position:relative;padding:0}.blockly-container{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%}.instruction-panel{display:flex;flex-direction:column;min-height:0;height:100%}.instruction-panel-body{flex:1;min-height:0;overflow-y:auto;padding:var(--space-sm) var(--space-md);font-size:14px}.btn{padding:10px 20px;border-radius:var(--radius-md);font-family:inherit;font-weight:700;cursor:pointer;border:none;font-size:14px;transition:transform .1s,box-shadow .15s;display:inline-flex;align-items:center;gap:var(--space-sm)}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(1px)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 3px 0 var(--color-primary-dark),var(--shadow-sm)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 0 var(--color-primary-dark),var(--shadow-md)}.btn-accent{background:var(--color-accent);color:#fff;box-shadow:0 3px #e55a8e,var(--shadow-sm)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border);box-shadow:0 3px 0 var(--color-border),var(--shadow-sm)}.btn-success{background:var(--color-success);color:#fff;box-shadow:0 3px #009b77,var(--shadow-sm)}.btn-run{background:var(--color-success);color:#fff;font-size:15px;padding:10px 24px;border-radius:var(--radius-lg);box-shadow:0 4px #009b77,var(--shadow-md)}.btn-run:hover:not(:disabled){box-shadow:0 5px #009b77,var(--shadow-lg)}.btn-reset{background:var(--color-warning);color:var(--color-text);box-shadow:0 3px #dbb45a,var(--shadow-sm)}.btn-hint{background:var(--color-accent);color:#fff;box-shadow:0 3px #e55a8e,var(--shadow-sm)}.btn-toolbar{background:#ffffff26;color:#fff;padding:8px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-toolbar:hover{background:#ffffff40}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.game-canvas-panel{flex:1;min-height:240px;display:flex;flex-direction:column}.game-canvas-panel .panel-body{flex:1;display:flex;align-items:stretch;justify-content:stretch;padding:0;overflow:hidden;border-radius:0 0 var(--radius-md) var(--radius-md)}@media (max-width: 960px){.app-main{flex-direction:column;overflow-y:auto}.app-left{min-height:300px}.app-right{width:100%;flex-shrink:0}.app-instructions{max-height:240px}.blockly-panel{min-height:260px}}.mobile-tab-bar,.mobile-sticky-actions{display:none}@media (max-width: 600px){.app-toolbar{padding:6px var(--space-sm);min-height:44px;gap:var(--space-sm);flex-wrap:nowrap}.app-toolbar-brand{font-size:16px}.app-toolbar-level{display:none}.app-toolbar-xp{padding:2px 8px!important;font-size:11px!important}.app-toolbar-coins{display:none}.app-toolbar-group{gap:4px}.app-toolbar-group select{max-width:100px;font-size:11px;padding:4px 6px}.btn-toolbar{padding:6px 10px;font-size:12px}.app-toolbar-primary .btn-toolbar,.app-toolbar-secondary{display:none}.mobile-menu-wrapper{position:relative}.mobile-menu-toggle{font-size:18px;padding:6px 10px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center}.mobile-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.mobile-menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);min-width:180px;z-index:100;overflow:hidden}.mobile-menu-dropdown button{display:block;width:100%;padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:var(--color-text);background:none;border:none;border-bottom:1px solid var(--color-border);font-family:inherit;cursor:pointer}.mobile-menu-dropdown button:last-child{border-bottom:none}.mobile-menu-dropdown button:active{background:var(--color-surface-alt)}.mobile-tab-bar{display:flex;flex-shrink:0;background:var(--color-surface);border-bottom:2px solid var(--color-border)}.mobile-tab{flex:1;padding:10px 0;font-size:15px;font-weight:700;font-family:inherit;background:none;border:none;border-bottom:3px solid transparent;color:var(--color-text-muted);cursor:pointer;transition:color .15s,border-color .15s}.mobile-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:var(--color-surface-alt)}.mobile-hidden{display:none!important}.app-main{flex:1;flex-direction:column;overflow:hidden;padding:0;gap:0}.app-left{flex:1;min-height:0}.blockly-panel{min-height:0;flex:1}.blockly-panel .panel-header{display:none}.app-right{flex:1;min-height:0;overflow-y:auto;padding:var(--space-sm);gap:var(--space-sm)}.game-canvas-panel{min-height:280px;flex:none;max-height:50vh}.app-actions{display:none}.mobile-sticky-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:6px var(--space-md);background:var(--color-surface);border-top:1px solid var(--color-border);flex-shrink:0;box-shadow:0 -2px 8px #0000000f}.mobile-sticky-actions .btn{flex:1;justify-content:center;min-height:44px;padding:8px 12px;font-size:13px}.panel-header{padding:8px var(--space-sm);font-size:13px}.instruction-panel{min-width:0!important}.instruction-panel-body{padding:var(--space-sm)}.app-instructions{min-height:80px;max-height:none}.btn{min-height:44px;min-width:44px;padding:8px 14px;font-size:13px}.btn-run{font-size:14px;padding:10px 20px}}@keyframes screenShake{0%,to{transform:translate(0)}10%{transform:translate(-3px,-2px)}20%{transform:translate(3px,2px)}30%{transform:translate(-2px,3px)}40%{transform:translate(2px,-2px)}50%{transform:translate(-3px,1px)}60%{transform:translate(3px,-1px)}70%{transform:translate(-1px,3px)}80%{transform:translate(1px,-3px)}90%{transform:translate(-2px,2px)}}.screen-shake{animation:screenShake .4s ease-out}.app-content{width:100%;flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}:root{--color-bg: #f0f4ff;--color-surface: #ffffff;--color-surface-alt: #f7f5ff;--color-primary: #6c5ce7;--color-primary-light: #a29bfe;--color-primary-dark: #5241cc;--color-secondary: #00b894;--color-secondary-light: #55efc4;--color-accent: #fd79a8;--color-warning: #fdcb6e;--color-success: #00b894;--color-danger: #e17055;--color-text: #2d3436;--color-text-muted: #636e72;--color-text-light: #b2bec3;--color-border: #dfe6e9;--block-motion: #4a90d9;--block-control: #f39c12;--block-logic: #00b894;--block-events: #e74c3c;--font-display: "Fredoka One", "Nunito", sans-serif;--font-body: "Nunito", -apple-system, BlinkMacSystemFont, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(108, 92, 231, .08);--shadow-md: 0 4px 12px rgba(108, 92, 231, .12);--shadow-lg: 0 8px 24px rgba(108, 92, 231, .16);--shadow-glow: 0 0 20px rgba(108, 92, 231, .3)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;outline:none}button:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-primary-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,var(--color-bg) 0%,#e8e0ff 100%)}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl, 28px);padding:40px;width:100%;max-width:420px;box-shadow:0 8px 32px #6c5ce726;text-align:center}.auth-logo{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:32px;color:var(--color-primary);margin-bottom:8px}.auth-title{font-family:var(--font-display, "Fredoka One", sans-serif);font-size:24px;color:var(--color-text);margin-bottom:4px}.auth-subtitle{color:var(--color-text-muted);font-size:14px;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:16px;text-align:left}.auth-field label{display:block;font-size:13px;font-weight:600;color:var(--color-text-muted);margin-bottom:4px}.auth-field input{width:100%;padding:12px 16px;border-radius:var(--radius-md, 12px);border:2px solid #e0e0e0;font-family:inherit;font-size:15px;color:var(--color-text);background:#f8f8ff;transition:border-color .2s}.auth-field input:focus{outline:none;border-color:var(--color-primary)}.auth-roles{display:flex;gap:8px}.auth-role-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border-radius:var(--radius-md, 12px);border:2px solid #e0e0e0;background:#f8f8ff;cursor:pointer;font-size:12px;font-weight:600;color:var(--color-text-muted);transition:all .2s}.auth-role-btn.active{border-color:var(--color-primary);background:#f0ecff;color:var(--color-primary)}.auth-role-icon{font-size:24px}.auth-error{background:#fff0f0;color:var(--color-danger, #e17055);padding:10px 14px;border-radius:var(--radius-sm, 8px);font-size:13px;font-weight:600}.auth-submit{width:100%;padding:14px;border:none;border-radius:var(--radius-md, 12px);background:var(--color-primary);color:#fff;font-family:var(--font-display, "Fredoka One", sans-serif);font-size:18px;cursor:pointer;transition:transform .1s,opacity .2s}.auth-submit:hover{transform:scale(1.02)}.auth-submit:active{transform:scale(.98)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{margin-top:20px;font-size:14px;color:var(--color-text-muted)}.auth-switch a{color:var(--color-primary);text-decoration:none;font-weight:600}.auth-switch a:hover{text-decoration:underline}
