*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f5f5f5;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex}main{flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.top-nav{color:#fff;background:#2c3e50;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;display:flex}.top-nav a{color:rgba(255,255,255,.85);font-size:.95rem;text-decoration:none}.top-nav a:hover{color:#fff}.top-nav .nav-brand{color:#3498db;margin-right:auto;font-family:Courier New,monospace;font-size:1.2rem;font-weight:700}footer{color:rgba(255,255,255,.6);text-align:center;background:#2c3e50;padding:.5rem 1.5rem;font-size:.85rem}footer a{color:rgba(255,255,255,.6);text-decoration:none}footer a:hover{color:#fff}.main-page{flex-direction:column;flex:1;display:flex;overflow:hidden}.toolbar{background:#ecf0f1;border-bottom:1px solid #ddd;align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.toolbar .tier-selector{font-size:.9rem}.toolbar .tier-selector select{border:1px solid #bdc3c7;border-radius:4px;padding:.25rem .5rem;font-size:.9rem}.toolbar .share-link{color:#2980b9;font-size:.85rem}.toolbar .share-link a{color:#2980b9}.main-layout{background:#ddd;flex:1;grid-template-rows:1fr 1fr;grid-template-columns:1fr 250px;gap:1px;display:grid;overflow:hidden}.editor-panel{background:#fff;flex-direction:column;grid-area:1/1;min-height:0;display:flex}.code-editor{flex-direction:column;flex:1;min-height:0;display:flex}.code-editor .editor-header{background:#f8f9fa;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:.5rem .75rem;display:flex}.code-editor .editor-header h3{color:#666;font-size:.85rem;font-weight:600}.code-editor .editor-header .editor-buttons{gap:.5rem;display:flex}.code-editor .editor-textarea{resize:none;tab-size:4;background:#fafafa;border:none;outline:none;flex:1;padding:.75rem;font-family:Fira Code,Cascadia Code,JetBrains Mono,Consolas,monospace;font-size:14px;line-height:1.5}.code-editor .editor-textarea::placeholder{color:#bbb}.btn{cursor:pointer;background:#fff;border:1px solid #bdc3c7;border-radius:4px;padding:.3rem .75rem;font-size:.85rem}.btn:hover{background:#ecf0f1}.btn.btn-run{color:#fff;background:#27ae60;border-color:#27ae60}.btn.btn-run:hover{background:#219a52}.btn.btn-save{color:#fff;background:#2980b9;border-color:#2980b9}.btn.btn-save:hover{background:#2472a4}.repl-panel{background:#fff;flex-direction:column;grid-area:2/1;min-height:0;display:flex}.repl{flex-direction:column;flex:1;min-height:0;font-family:Fira Code,Cascadia Code,JetBrains Mono,Consolas,monospace;font-size:14px;display:flex}.repl .repl-output{color:#d4d4d4;background:#1e1e1e;flex:1;padding:.5rem .75rem;overflow-y:auto}.repl .repl-entry{margin-bottom:.25rem}.repl .repl-input-line .repl-prompt{color:#569cd6}.repl .repl-result{color:#d4d4d4}.repl .repl-result pre{white-space:pre-wrap;word-wrap:break-word;font:inherit;margin:0}.repl .repl-result.repl-error{color:#f44747}.repl .repl-input-row{background:#252526;border-top:1px solid #333;align-items:center;padding:.5rem .75rem;display:flex}.repl .repl-input-row .repl-prompt{color:#569cd6;white-space:nowrap;margin-right:.5rem}.repl .repl-input-row .repl-input{color:#d4d4d4;font-family:inherit;font-size:inherit;background:0 0;border:none;outline:none;flex:1}.repl .repl-input-row .repl-input::placeholder{color:#555}.stack-panel{background:#fff;flex-direction:column;grid-area:1/2/3;display:flex}.stack-display{flex-direction:column;flex:1;display:flex}.stack-display h3{color:#666;background:#f8f9fa;border-bottom:1px solid #eee;padding:.5rem .75rem;font-size:.85rem;font-weight:600}.stack-display .stack-items{flex:1;padding:.5rem;overflow-y:auto}.stack-display .stack-empty{color:#999;text-align:center;padding:2rem 0;font-style:italic}.stack-display .stack-item{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:.3rem .5rem;font-family:Fira Code,monospace;font-size:14px;display:flex}.stack-display .stack-item:first-child{background:#f0f7ff}.stack-display .stack-item .stack-label{color:#999;min-width:2rem;font-size:.75rem}.stack-display .stack-item .stack-value{color:#2c3e50;font-weight:500}.stack-display .stack-depth{color:#999;background:#f8f9fa;border-top:1px solid #eee;padding:.4rem .75rem;font-size:.8rem}@media (width<=768px){.main-layout{grid-template-rows:1fr 1fr 200px;grid-template-columns:1fr}.stack-panel{grid-area:3/1}}.about-page,.gallery-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.about-page h1,.gallery-page h1{color:#2c3e50;margin-bottom:1rem}.about-page h2,.gallery-page h2{color:#34495e;margin-top:1.5rem;margin-bottom:.75rem}.about-page p,.gallery-page p{margin-bottom:.75rem;line-height:1.6}.about-page a,.gallery-page a{color:#2980b9}.about-page{max-width:700px}.help-page{flex:1;min-height:0;display:flex;overflow:hidden}.help-page h1{color:#2c3e50;margin-bottom:1rem}.help-page h2{color:#34495e;border-bottom:1px solid #ddd;margin-top:1.5rem;margin-bottom:.75rem;padding-bottom:.25rem}.help-page p{margin-bottom:.75rem;line-height:1.6}.help-page a{color:#2980b9}.help-sidebar{background:#f8f9fa;border-right:1px solid #ddd;flex-shrink:0;width:200px;padding:1.5rem 1rem;overflow-y:auto}.help-sidebar h2{color:#2c3e50;border-bottom:none;margin-top:0;margin-bottom:.75rem;font-size:.95rem}.help-sidebar ul{margin:0;padding:0;list-style:none}.help-sidebar li{margin-bottom:.25rem}.help-sidebar a{color:#555;border-radius:4px;padding:.3rem .5rem;font-size:.85rem;text-decoration:none;display:block}.help-sidebar a:hover{color:#2c3e50;background:#ecf0f1}.help-content{scroll-behavior:smooth;flex:1;min-width:0;padding:2rem 2.5rem;overflow-y:auto}.help-content section{max-width:800px}.help-table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.95rem}.help-table th,.help-table td{text-align:left;border:1px solid #ddd;padding:.5rem .75rem}.help-table th{background:#f8f9fa;font-weight:600}.help-table code{background:#f0f0f0;border-radius:3px;padding:.15rem .3rem;font-family:Fira Code,monospace;font-size:.9em}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0;display:grid}.gallery-card{color:inherit;background:#fff;border:1px solid #ddd;border-radius:8px;padding:1.25rem;text-decoration:none;transition:border-color .2s,box-shadow .2s}.gallery-card:hover{border-color:#2980b9;box-shadow:0 2px 8px rgba(0,0,0,.1)}.gallery-card h3{color:#2c3e50;margin-bottom:.5rem;font-size:1rem}.gallery-card .gallery-preview{color:#666;background:#f8f9fa;border-radius:4px;max-height:4em;margin-bottom:.75rem;padding:.5rem;font-family:Fira Code,monospace;font-size:.8rem;line-height:1.4;overflow:hidden}.gallery-card a{color:#2980b9;font-size:.9rem;text-decoration:none}.gallery-card a:hover{text-decoration:underline}@media (width<=768px){.help-page{flex-direction:column;overflow:visible}.help-sidebar{border-bottom:1px solid #ddd;border-right:none;width:100%}.help-content{padding:1.5rem}}