:root{--ruby: #CC342D;--bg: #0f0f13;--surface: #16161e;--surface2: #1e1e2a;--border: #2a2a3a;--text: #e8e8f0;--muted: #888899;--accent: #f0c060;--run-button-loading: #555;--error-text: #ff7a73}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:"Source Serif 4",serif;font-weight:300;line-height:1.6;min-height:100vh}header{padding:3rem 2rem 2rem;text-align:center;background:linear-gradient(180deg,#0a0a10 0%,var(--bg) 100%);border-bottom:1px solid var(--border);position:relative;overflow:hidden}h1{font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:900;letter-spacing:-.02em;line-height:1.1;margin-bottom:.5rem}.subtitle{color:var(--muted);font-style:italic;font-size:1rem;margin-bottom:1.5rem}.legend{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .9rem;border-radius:999px;font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500;letter-spacing:.05em}.pill.ruby{background:#cc342d33;border:1px solid rgba(204,52,45,.5);color:#ff7a73}.pill.note{background:#f0c06026;border:1px solid rgba(240,192,96,.4);color:var(--accent)}.noscript-warning{position:fixed;top:0;left:0;right:0;z-index:9999;padding:.9rem 1.5rem;background:#5a3a00;border-bottom:2px solid #c87800;color:#ffe0a0;font-size:1rem;text-align:center}.noscript-warning strong{color:#ffd060}.pill.loading{background:#80808014!important;border-color:#80808040!important;color:var(--muted)!important}.pill.unavailable{background:#8080800d!important;border-color:#80808033!important;color:#8888998c!important}.site-nav{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(.1rem,.5vw,.4rem);padding:.45rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}.nav-link{display:inline-flex;align-items:center;gap:clamp(.15rem,.3vw,.3rem);padding:.2rem clamp(.25rem,.9vw,.65rem);border-radius:999px;font-family:JetBrains Mono,monospace;font-size:.67rem;font-weight:500;letter-spacing:.04em;text-decoration:none;color:var(--muted);border:1px solid transparent;transition:color .15s,background .15s,border-color .15s}.nav-link:hover{color:var(--text);background:#ffffff0d;border-color:var(--border)}.nav-home{color:#cc342db3}.nav-home:hover{color:#ff7a73;background:#cc342d1a;border-color:#cc342d59}.nav-separator{width:1px;height:1.2em;background:var(--border);align-self:center;flex-shrink:0;margin:0 .15rem}@keyframes toggle-spin{to{transform:rotate(360deg)}}.offline-toggle{position:relative;display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .55rem .18rem .4rem;border-radius:999px;font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:500;letter-spacing:.04em;background:none;border:1px solid transparent;cursor:pointer;transition:color .2s,background .2s,border-color .2s;white-space:nowrap}.offline-toggle svg{width:.85rem;height:.85rem;flex-shrink:0}.offline-toggle[data-state=online]{color:#4ade80;border-color:#4ade8073;background:#4ade8014}.offline-toggle[data-state=online]:hover{color:#fbbf24;border-color:#fbbf248c;background:#fbbf241a}.offline-toggle[data-state=transitioning]{color:#fbbf24;border-color:transparent;cursor:default;pointer-events:none}.offline-toggle[data-state=offline]{color:#f0c060;border-color:#f0c06073;background:#f0c06014}.offline-toggle[data-state=offline]:hover{color:#4ade80;border-color:#4ade8073;background:#4ade801a}.offline-dialog-backdrop{display:none;position:fixed;inset:0;background:#0000008c;backdrop-filter:blur(4px);z-index:9000;align-items:center;justify-content:center;padding:1.5rem}.offline-dialog-backdrop.visible{display:flex}.offline-dialog{background:#1a1a24;border:1px solid #3a3a50;border-radius:12px;padding:1.6rem 1.75rem 1.4rem;max-width:380px;width:100%;box-shadow:0 24px 64px #0009,0 0 0 1px #ffffff0a}.offline-dialog-icon{width:2rem;height:2rem;margin-bottom:.9rem;color:#f0c060}.offline-dialog-title{font-family:Playfair Display,serif;font-size:1.05rem;font-weight:700;color:#e8e8f0;margin-bottom:.6rem;line-height:1.25}.offline-dialog-body{font-family:"Source Serif 4",serif;font-size:.88rem;font-weight:300;color:#9999b0;line-height:1.6;margin-bottom:1.25rem}.offline-dialog-detail{font-family:JetBrains Mono,monospace;font-size:.7rem;color:#666680;background:#ffffff08;border:1px solid #2a2a3a;border-radius:6px;padding:.5rem .7rem;margin-top:.7rem;line-height:1.55}.offline-dialog-actions{display:flex;gap:.6rem;justify-content:flex-end;flex-wrap:wrap}.offline-dialog-btn{font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:500;padding:.4rem 1rem;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.offline-dialog-btn.secondary{background:transparent;border-color:#3a3a50;color:#889}.offline-dialog-btn.secondary:hover{border-color:#666680;color:#e8e8f0}.offline-dialog-btn.primary{background:#cc342d;border-color:#cc342d;color:#fff}.offline-dialog-btn.primary:hover{background:#e03d36;border-color:#e03d36}[data-offline-disabled]{opacity:.35!important;cursor:not-allowed!important;pointer-events:none!important}.nav-link[data-offline-capable=false][data-offline-dimmed]{opacity:.3;pointer-events:none}.nav-ruby.active{background:#cc342d26;border-color:#cc342d66;color:#ff7a73}.nav-python.active{background:#4b8bbe26;border-color:#4b8bbe66;color:#90c8f0}.nav-go.active{background:#00add826;border-color:#00add866;color:#5dd4f0}.nav-js.active{background:#f7df1e26;border-color:#f7df1e66;color:#f5e57a}.nav-ts.active{background:#3178c626;border-color:#3178c666;color:#7ab8f5}.nav-rust.active{background:#d3451626;border-color:#d3451666;color:#f5a878}.nav-swift.active{background:#f0513826;border-color:#f0513866;color:#ffb098}.nav-c.active{background:#659ad326;border-color:#659ad366;color:#93c4ef}.nav-zig.active{background:#f7a41d26;border-color:#f7a41d66;color:#f5c96a}.nav-dart.active{background:#0175c226;border-color:#0175c266;color:#64b8f5}.nav-kotlin.active{background:#7f52ff26;border-color:#7f52ff66;color:#c4aeff}.nav-crystal.active{background:#5fd9bb26;border-color:#5fd9bb66;color:#7fe8cc}.nav-clojure.active{background:#5881d826;border-color:#5881d866;color:#90aaee}.nav-csharp.active{background:#9b4f9626;border-color:#9b4f9666;color:#d490dc}.nav-java.active{background:#0074bd26;border-color:#0074bd66;color:#6cc4f8}.nav-perl.active{background:#39457e26;border-color:#39457e66;color:#7888cc}.nav-lua.active{background:#00007c26;border-color:#00007c66;color:#8090d8}.nav-sql.active{background:#00395626;border-color:#00395666;color:#7ecef4}.nav-haskell.active{background:#5e518726;border-color:#5e518766;color:#c8b8f0}.nav-bash.active{background:#4eaa2526;border-color:#4eaa2566;color:#7dd85a}.nav-cobol.active{background:#004b8d26;border-color:#004b8d66;color:#8ab8e0}.nav-fortran.active{background:#734c9426;border-color:#734c9466;color:#d0a8f0}.nav-vb.active{background:#004e8c26;border-color:#004e8c66;color:#80c8ff}.nav-pascal.active{background:#00339926;border-color:#0396;color:#80aaff}.lang-icon{width:1.875em;height:1.875em;flex-shrink:0;vertical-align:-.4em;display:inline-block}.pill.go{position:relative;padding-left:3.7em;overflow:hidden}.col-headers .ch-go{position:relative;padding-left:3.7em}.gopher-peek-wrap{position:absolute;left:.3em;top:.5em;bottom:0;width:3.5em;overflow:hidden;display:flex;justify-content:center;align-items:flex-start}.col-headers .gopher-peek-wrap{top:.1rem;bottom:-.4rem;width:3.5em}.lang-icon.gopher-peek{width:3.7em;height:3.7em;flex-shrink:0;display:block;vertical-align:0;top:.7rem}.col-headers .lang-icon.gopher-peek{width:3.7em;height:3.7em}#filterNav{position:sticky;top:0;z-index:100;background:#0f0f13f2;backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:.75rem 1.5rem;display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;justify-content:center}.filter-btn{background:transparent;border:1px solid var(--border);color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.7rem;letter-spacing:.06em;padding:.3rem .75rem;border-radius:4px;cursor:pointer;transition:all .15s;text-transform:uppercase}.filter-btn:hover,.filter-btn.active{background:var(--surface2);border-color:var(--accent);color:var(--accent)}.search-wrap{display:flex;justify-content:center;padding:1rem 1.5rem 0}#search{background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:JetBrains Mono,monospace;font-size:.85rem;padding:.5rem 1rem;width:100%;max-width:500px;outline:none;transition:border-color .2s}#search:focus{border-color:var(--accent)}#search::placeholder{color:var(--muted)}main{max-width:1400px;margin:0 auto;padding:1.5rem 1rem 4rem}.section-header{font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700;color:var(--accent);padding:2rem 0 .75rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--border);margin-bottom:0;letter-spacing:-.01em}.section-header:before{content:"";display:inline-block;width:4px;height:1.4rem;background:var(--accent);border-radius:2px;flex-shrink:0}.col-headers{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0 .75rem;padding:.4rem 1rem;background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:130px;z-index:10;font-family:JetBrains Mono,monospace;font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.col-headers .ch-ruby{color:#ff7a73}.col-headers .ch-python{color:#90c8f0}.col-headers .ch-go{color:#5dd4f0}.col-headers .ch-js{color:#f5e57a}.col-headers .ch-ts{color:#7ab8f5}.col-headers .ch-rust{color:#f5a878}.col-headers .ch-swift{color:#ffb098}.col-headers .ch-c{color:#93c4ef}.col-headers .ch-zig{color:#f5c96a}.col-headers .ch-dart{color:#64b8f5}.col-headers .ch-kotlin{color:#c4aeff}.col-headers .ch-crystal{color:#7fe8cc}.col-headers .ch-clojure{color:#90aaee}.col-headers .ch-csharp{color:#d490dc}.col-headers .ch-java{color:#6cc4f8}.col-headers .ch-perl{color:#7888cc}.col-headers .ch-lua{color:#8090d8}.col-headers .ch-sql{color:#7ecef4}.col-headers .ch-haskell{color:#c8b8f0}.col-headers .ch-bash{color:#7dd85a}.col-headers .ch-cobol{color:#8ab8e0}.col-headers .ch-fortran{color:#d0a8f0}.col-headers .ch-vb{color:#80c8ff}.col-headers .ch-pascal{color:#80aaff}@media(max-width:900px){.col-headers{display:none}}.concept-row{border-bottom:1px solid var(--border);transition:background .1s;font-size:.875rem}.concept-row:hover{background:#ffffff05}.concept-row.hidden{display:none}.concept-label{font-family:JetBrains Mono,monospace;font-size:.78rem;font-weight:500;color:var(--text);padding:.6rem 1rem .25rem}.concept-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0 .75rem;padding:0 .5rem .5rem}.col{padding:.25rem .5rem;line-height:1.5;min-width:0;overflow:hidden}code,pre{font-family:JetBrains Mono,monospace;font-size:.78rem;line-height:1.6}.code-wrap{position:relative}.run-status{margin-left:auto;font-size:.75rem;letter-spacing:0;text-transform:none;font-weight:400}.run-status:empty{display:none}.run-status.success{font-size:0;display:inline-block;width:.875rem;height:.875rem;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='11' fill='%230a280a' fill-opacity='.92' stroke='%234ade80' stroke-opacity='.4' stroke-width='1.5'/%3E%3Cpath d='M7 12.5l3.5 3.5 6.5-7' stroke='%234ade80' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") center / contain no-repeat}.run-status.exit-zero{color:#5ecf5e;font-size:.6rem}.run-status.exit-nonzero{color:var(--error-text);font-size:.6rem}.code-ruby[contenteditable]{cursor:text;outline:none;transition:box-shadow .15s}.code-ruby[contenteditable]:focus{box-shadow:inset 0 0 0 1px #ffffff26}.code-ruby[contenteditable]:hover{box-shadow:inset 0 0 0 1px #ffffff14}.code-ruby{background:#cc342d14;border-left:2px solid rgba(204,52,45,.5);padding:.5rem .75rem;border-radius:0 4px 4px 0;display:block;white-space:pre;overflow-x:auto;color:#ffb3ae;scrollbar-width:thin;scrollbar-color:rgba(204,52,45,.5) rgba(204,52,45,.08)}.code-ruby::-webkit-scrollbar{height:4px}.code-ruby::-webkit-scrollbar-track{background:#cc342d14}.code-ruby::-webkit-scrollbar-thumb{background:#cc342d80;border-radius:3px}.code-wrap .code-ruby{border-radius:0 4px 0 0}.run-button-ruby{display:flex;align-items:center;gap:.35rem;background:#6e2a2a;border:none;border-radius:0 0 4px 4px;color:#eec8c8;cursor:pointer;font-family:JetBrains Mono,monospace;font-size:.65rem;font-weight:600;letter-spacing:.07em;padding:.25rem .6rem;text-transform:uppercase;transition:background .15s;width:100%;border-left:2px solid rgba(204,52,45,.5)}.run-button-ruby:hover{background:#8e3a3a}.run-button-ruby.loading{background:var(--run-button-loading);cursor:wait;color:#aaa}.run-button-ruby.loading .run-icon:after{content:"⏳"}.run-button-ruby:not(.loading) .run-icon:after{content:"▶"}.rb-output{display:none;background:#1a0a0a;border:1px solid #4a2a2a;border-top:none;border-radius:0 0 4px 4px;padding:.4rem .75rem;font-family:JetBrains Mono,monospace;font-size:.75rem;line-height:1.6;color:#db7d7d;white-space:pre-wrap;word-break:break-word;border-left:2px solid #4a2a2a}.rb-output.visible{display:block}.rb-output.error-out{color:var(--error-text);border-color:#cc342d66}.rb-return-value{color:var(--muted);font-style:italic}.norun-notice{display:flex;align-items:center;gap:.4rem;background:var(--surface2);border:none;border-radius:0 0 4px 4px;border-left:2px solid rgba(204,52,45,.5);color:var(--muted);font-family:JetBrains Mono,monospace;font-size:.62rem;font-style:italic;letter-spacing:.03em;padding:.3rem .6rem;width:100%}.norun-notice:before{content:"ℹ";font-style:normal}.sim-notice{margin-top:.6rem;font-size:.72rem;color:var(--muted);border-left:2px solid var(--accent);padding-left:.5rem;line-height:1.4}.info-block{display:block;padding:.5rem .75rem;font-family:"Source Serif 4",serif;font-size:.82rem;font-style:italic;line-height:1.6;color:var(--muted);white-space:pre-line}.info-block a{color:var(--accent);text-decoration:none;font-style:italic}.info-block a:hover{text-decoration:underline}.dir-listing{display:block;padding:.5rem .75rem;font-family:JetBrains Mono,monospace;font-size:.75rem;line-height:1.8;color:var(--muted);white-space:pre}.dir-listing span{color:#ffffff59}.shell-block{background:#ffffff0a;border-left:2px solid rgba(160,160,180,.4);padding:.5rem .75rem;border-radius:0 4px 4px 0;display:block;white-space:pre;overflow-x:auto;font-family:JetBrains Mono,monospace;font-size:.78rem;line-height:1.6;color:#b0b0c0}.shell-label{display:block;font-family:JetBrains Mono,monospace;font-size:.55rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#a0a0b480;margin-bottom:.2rem}.concept-foreword,.concept-afterword{padding:.35rem 1rem;color:var(--muted);font-size:.82rem;font-style:italic;line-height:1.6}.concept-foreword{border-left:2px solid rgba(255,255,255,.12);margin:0 .5rem .25rem;padding-left:.75rem}.concept-afterword{border-top:1px solid var(--border);margin:0 .5rem;padding-top:.4rem;padding-bottom:.5rem}.concept-foreword strong,.concept-afterword strong{color:var(--accent);font-style:normal;font-weight:600}.concept-foreword code,.concept-afterword code{font-style:normal;background:var(--surface2);padding:.1rem .3rem;border-radius:3px;color:var(--text);font-size:.75rem}footer{text-align:center;padding:2rem;color:var(--muted);font-size:.8rem;border-top:1px solid var(--border)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media(max-width:900px){.concept-grid{grid-template-columns:1fr}.col{padding:.4rem .5rem}.col-ruby:before{display:block;font-family:JetBrains Mono,monospace;font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem;font-style:normal;content:"RUBY";color:#ff7a73}}.coming-soon{display:flex;justify-content:center;align-items:center;min-height:50vh;padding:3rem 1rem}.coming-soon-card{text-align:center;max-width:480px;padding:3rem 2.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px}.coming-soon-icon{width:64px;height:64px;opacity:.7;margin-bottom:1rem}.coming-soon-card h2{font-size:1.6rem;margin:0 0 .5rem}.coming-soon-label{font-size:1rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin:0 0 .75rem}.coming-soon-date{font-size:.9rem;color:var(--muted);margin:0 0 1rem}.coming-soon-blurb{font-size:.9rem;color:var(--muted);line-height:1.6;margin:0}
