*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--header-bg:#1a3a5c;--header-fg:#fff;--accent:#f0a500;--accent-hover:#d4920a;--run-bg:#27ae60;--run-hover:#219150;--danger:#e74c3c;--border:#d0d7de;--surface:#f6f8fa;--console-bg:#1e1e1e;--console-fg:#d4d4d4;--console-error:#f97583;--installed-bg:#dff0d8;--installed-fg:#3c763d;font-family:Trebuchet MS,Helvetica,Arial,sans-serif}body{color:#24292f;background:#fff;overflow:hidden}.app{flex-direction:column;width:100vw;height:100vh;display:flex}.app-header{background:var(--header-bg);color:var(--header-fg);flex-shrink:0;align-items:center;gap:1.5rem;height:52px;padding:0 1rem;display:flex;box-shadow:0 2px 6px #0000004d}.app-title{letter-spacing:.02em;white-space:nowrap;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.app-logo-img{width:70px;height:auto}.app-logo{font-size:1.5rem;line-height:1}.app-body{flex:1;display:flex;overflow:hidden}.editor-pane{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.output-pane{border-left:2px solid var(--border);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.toolbar{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.35rem .85rem;font-family:Trebuchet MS,sans-serif;font-size:.875rem;font-weight:600;transition:background .15s,opacity .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-run{background:var(--run-bg);color:#fff;min-width:7rem}.btn-run:not(:disabled):hover{background:var(--run-hover)}.btn-secondary{color:var(--header-fg);background:#ffffff26;border:1px solid #ffffff4d}.btn-secondary:not(:disabled):hover{background:#ffffff40}.btn-packages{background:var(--accent);color:#1a1a1a}.btn-packages:hover{background:var(--accent-hover)}.loading-message{color:#ffffffbf;margin-left:.5rem;font-size:.8rem;font-style:italic}.output-panel{background:var(--surface);flex-direction:column;height:100%;display:flex}.output-tabs{border-bottom:2px solid var(--border);background:#eaecef;flex-shrink:0;align-items:center;gap:.25rem;height:38px;padding:0 .5rem;display:flex}.tab-btn{cursor:pointer;color:#57606a;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:.3rem;padding:.4rem .75rem;font-family:Trebuchet MS,sans-serif;font-size:.875rem;font-weight:600;transition:color .15s,border-color .15s;display:flex;position:relative;top:2px}.tab-btn:hover{color:#24292f}.tab-btn.active{color:var(--header-bg);border-bottom-color:var(--header-bg)}.tab-badge{background:var(--accent);color:#1a1a1a;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:.65rem;line-height:1;display:flex}.tab-badge.error{background:var(--danger);color:#fff}.btn-clear{border:1px solid var(--border);cursor:pointer;color:#57606a;background:0 0;border-radius:4px;margin-left:auto;padding:.2rem .6rem;font-family:Trebuchet MS,sans-serif;font-size:.75rem}.btn-clear:hover{color:var(--danger);border-color:var(--danger);background:#fff}.tab-content{flex:1;display:none;overflow:hidden}.tab-content.visible{flex-direction:column;display:flex}.tab-content.hidden{display:none}.console-output{background:var(--console-bg);flex:1;padding:.75rem 1rem;font-family:Courier New,Courier,monospace;font-size:13px;line-height:1.6;overflow-y:auto}.console-placeholder{color:#555;font-style:italic}.console-line{white-space:pre-wrap;word-break:break-all}.console-line.text{color:var(--console-fg)}.console-line.error{color:var(--console-error)}.graphics-tab{background:#fff;gap:1rem;padding:.75rem;overflow-y:auto}.turtle-wrapper{border:1px solid var(--border);border-radius:4px;line-height:0;display:inline-block;overflow:hidden}.turtle-canvas{max-width:100%;height:auto;display:block}.plot-wrapper{border:1px solid var(--border);border-radius:4px;display:inline-block;overflow:hidden}.plot-image{max-width:100%;height:auto;display:block}.modal-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;width:min(600px,92vw);max-height:85vh;padding:1.5rem;overflow-y:auto;box-shadow:0 8px 32px #00000040}.modal-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.modal-header h2{color:var(--header-bg);font-size:1.2rem}.modal-close{cursor:pointer;color:#57606a;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:1.25rem;line-height:1}.modal-close:hover{background:var(--surface);color:var(--danger)}.modal-intro{color:#555;margin-bottom:.5rem;font-size:.875rem;line-height:1.5}.modal-intro code{background:#f0f0f0;border-radius:3px;padding:.1em .3em;font-family:Courier New,monospace;font-size:.85em}.modal-intro.note{border-left:3px solid var(--accent);background:#fff8e1;border-radius:0 4px 4px 0;margin-bottom:1rem;padding:.5rem .75rem}.install-error{border:1px solid var(--danger);color:var(--danger);background:#fde8e8;border-radius:4px;margin-bottom:.75rem;padding:.5rem .75rem;font-size:.85rem}.pkg-category{margin-bottom:1rem}.pkg-category h3{text-transform:uppercase;letter-spacing:.08em;color:#57606a;border-bottom:1px solid var(--border);margin-bottom:.4rem;padding-bottom:.25rem;font-size:.8rem}.pkg-list{flex-direction:column;gap:.35rem;display:flex}.pkg-row{border:1px solid var(--border);background:#fafbfc;border-radius:4px;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem .6rem;transition:background .1s;display:flex}.pkg-row.installed{background:var(--installed-bg);border-color:#b2d8b2}.pkg-row:not(.installed):hover{background:#fff}.pkg-info{flex-direction:column;gap:.1rem;min-width:0;display:flex}.pkg-name{font-size:.9rem;font-weight:700}.pkg-desc{color:#57606a;font-size:.78rem}.btn-install{background:var(--header-bg);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;flex-shrink:0;padding:.3rem .8rem;font-family:Trebuchet MS,sans-serif;font-size:.8rem;font-weight:600;transition:background .15s}.btn-install:not(:disabled):hover{background:#145086}.btn-install.installed{background:var(--installed-fg);cursor:default}.btn-install:disabled:not(.installed){opacity:.5;cursor:not-allowed}.drawer-backdrop{z-index:899;background:#00000059;position:fixed;inset:0}.algorithms-drawer{border-left:2px solid var(--border);z-index:900;background:#fff;flex-direction:column;width:620px;max-width:100vw;transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:-4px 0 24px #0000002e}.algorithms-drawer.open{transform:translate(0)}.drawer-header{background:var(--header-bg);color:var(--header-fg);flex-direction:column;flex-shrink:0;gap:.5rem;padding:.85rem 1rem .8rem;display:flex}.drawer-title-row{justify-content:space-between;align-items:center;display:flex}.drawer-title-row h2{font-size:1.1rem;font-weight:700}.drawer-subtitle{opacity:.8;margin-top:-.2rem;font-size:.78rem}.drawer-search{color:#fff;background:#ffffff26;border:none;border-radius:4px;outline:none;width:100%;padding:.4rem .65rem;font-family:Trebuchet MS,sans-serif;font-size:.85rem}.drawer-search::placeholder{color:#ffffff8c}.drawer-search:focus{background:#ffffff40}.category-chips{scrollbar-width:none;flex-wrap:nowrap;gap:.3rem;display:flex;overflow-x:auto}.category-chips::-webkit-scrollbar{display:none}.chip{color:#ffffffd9;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #fff6;border-radius:20px;flex-shrink:0;padding:.18rem .55rem;font-family:Trebuchet MS,sans-serif;font-size:.72rem;font-weight:600;transition:background .15s,color .15s}.chip:hover{color:#fff;background:#fff3}.chip-active{background:var(--accent);border-color:var(--accent);color:#1a1a1a}.drawer-body{flex-direction:column;flex:1;gap:.35rem;min-height:0;padding:.5rem;display:flex;overflow-y:scroll}.drawer-empty{text-align:center;color:#888;margin-top:2.5rem;font-size:.9rem;font-style:italic}.algo-card{border:1px solid var(--border);background:#fafbfc;border-radius:6px;overflow:hidden}.algo-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.6rem;width:100%;padding:.65rem .75rem;font-family:Trebuchet MS,sans-serif;transition:background .12s;display:flex}.algo-header:hover{background:var(--surface)}.algo-title{color:#24292f;text-align:left;flex:1;font-size:.9rem;font-weight:700}.algo-badge{color:#fff;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:.15rem .5rem;font-size:.62rem;font-weight:700}.algo-toggle{color:#888;flex-shrink:0;font-size:.65rem}.algo-body{border-top:1px solid var(--border);background:#fff;flex-direction:column;gap:.75rem;max-height:68vh;padding:.75rem;display:flex;overflow-y:auto}.algo-desc{color:#444;font-size:.875rem;line-height:1.5}.teaching-notes h4,.algo-challenges h4{text-transform:uppercase;letter-spacing:.07em;color:#57606a;margin-bottom:.35rem;font-size:.75rem}.teaching-notes ul{flex-direction:column;gap:.25rem;padding-left:1.1rem;display:flex}.teaching-notes li{color:#444;font-size:.82rem;line-height:1.5}.algo-code-block{border:1px solid var(--border);border-radius:4px;overflow:hidden}.code-block-header{color:#57606a;background:#eaecef;justify-content:space-between;align-items:center;padding:.35rem .6rem;font-size:.75rem;font-weight:600;display:flex}.algo-code{background:var(--console-bg);color:var(--console-fg);white-space:pre;margin:0;padding:.6rem .75rem;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.5;overflow-x:auto}.btn-load-code{background:var(--header-bg);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.2rem .6rem;font-family:Trebuchet MS,sans-serif;font-size:.75rem;font-weight:600;transition:background .15s}.btn-load-code:hover{background:#145086}.algo-challenges{flex-direction:column;gap:.35rem;display:flex}.challenge-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;overflow:hidden}.challenge-header{cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;width:100%;padding:.45rem .65rem;font-family:Trebuchet MS,sans-serif;transition:background .12s;display:flex}.challenge-header:hover{background:#f0f4f8}.challenge-title{color:#24292f;font-size:.84rem;font-weight:700}.challenge-toggle{color:#888;font-size:.65rem}.challenge-body{background:#fff;border-top:1px solid #e2e8f0;flex-direction:column;gap:.5rem;padding:.6rem .65rem;display:flex}.challenge-desc{color:#444;font-size:.82rem;line-height:1.5}.btn-load-starter{background:var(--accent);color:#1a1a1a;cursor:pointer;border:none;border-radius:4px;align-self:flex-start;padding:.22rem .65rem;font-family:Trebuchet MS,sans-serif;font-size:.75rem;font-weight:600;transition:background .15s}.btn-load-starter:hover{background:var(--accent-hover)}.drawer-footer{background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;padding:.6rem 1rem}.drawer-footer p{color:#57606a;font-size:.72rem;line-height:1.5}.drawer-footer a{color:var(--header-bg);text-decoration:underline}.drawer-footer a:hover{color:var(--accent)}.btn-algorithms{color:#fff;background:#6d28d9;border:none}.btn-algorithms:hover{background:#5b21b6}
