:root{--bg:#faf8f2;--fg:#1e1c18;--muted:#7a756c;--accent:#b3500e;--border:#e5e0d4;--code-bg:#f3f0e6;--sim-good:#3f8a3d;--sim-warn:#b06000;--sim-bad:#b3261e;--sidebar-w:16rem;--toc-w:14rem}:root[data-theme=dark]{--bg:#14151a;--fg:#d8d5cc;--muted:#8a857a;--accent:#e08a4e;--border:#2a2c34;--code-bg:#1c1e25;--sim-good:#98c379;--sim-warn:#d19a66;--sim-bad:#e06c75}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;margin:0;font-family:Iowan Old Style,Palatino Linotype,Palatino,Georgia,serif;font-size:17px;line-height:1.7}a{color:var(--accent)}#progress{position:fixed;background:var(--accent);transform-origin:left;z-index:200;pointer-events:none;height:3px;top:0;left:0;right:0;transform:scaleX(0)}#nav-toggle,#theme-toggle{position:fixed;z-index:120;background:var(--bg);color:var(--fg);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:.35rem .6rem;font-size:1.1rem;line-height:1;top:.75rem;box-shadow:0 1px 4px #0000001f}#nav-toggle{left:.75rem}#theme-toggle{right:.75rem}#nav-toggle:hover,#theme-toggle:hover{background:var(--code-bg)}#sidebar{position:fixed;width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--border);overflow-y:auto;z-index:110;transition:transform .24s,box-shadow .24s;top:0;bottom:0;left:0;transform:translate(-100%)}#sidebar.open{transform:translate(0);box-shadow:4px 0 20px #0000002e}.sidebar-inner{padding:3.5rem 0 2rem}#toc{display:none}main{max-width:46rem;margin:0 auto;padding:3.5rem 1.25rem 6rem}@media (min-width:1100px){body{display:grid;grid-template-columns:var(--sidebar-w)1fr var(--toc-w);align-items: start;min-height:100vh}#nav-toggle{display:none}#theme-toggle{position:fixed;top:.6rem;right:.75rem}#sidebar{position:sticky;box-shadow:none;grid-column:1;grid-row:1;z-index:1;height:100vh;transition:none;top:0;transform:none}.sidebar-inner{padding:2rem 0}main{grid-column:2;grid-row:1;padding:3rem 2rem 6rem}#toc{display:block;position:sticky;grid-column:3;grid-row:1;align-self: start;padding:2rem 1rem 2rem .5rem;font-family:-apple-system,Segoe UI,system-ui,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:.78rem;line-height:1.45;top:2rem}}.nav-design{border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem}.nav-design:first-child{border-top:none;margin-top:0}.nav-h{display:block;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);padding:.9rem 1.1rem .2rem;font-family:-apple-system,Segoe UI,system-ui,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:.68rem;font-weight:600}.navlink{display:block;color:var(--fg);text-decoration:none;border-left:2px solid #0000;padding:.3rem 1.1rem;transition:color .16s,background .16s;font-family:-apple-system,Segoe UI,system-ui,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:.875rem;line-height:1.4}.navlink:hover{background:var(--code-bg)}.navlink.active{color:var(--accent);border-left-color:var(--accent);background:color-mix(in srgb,var(--accent)8%,transparent)}.spine{font-weight:700}.nav-children{border-left:1px solid var(--border);margin-left:1.1rem;padding-left:.65rem}.nav-children .navlink{padding-left:.65rem;font-size:.83rem}.toc-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.6rem;font-size:.68rem;font-weight:600}#toc ol{list-style:none;border-left:1px solid var(--border);margin:0;padding:0}#toc li{margin:0}#toc a{display:block;color:var(--muted);text-decoration:none;border-left:2px solid #0000;margin-left:-1.5px;padding:.25rem 0 .25rem .85rem;transition:color .16s}#toc a:hover{color:var(--fg)}#toc a.active{color:var(--accent);border-left-color:var(--accent)}h1{letter-spacing:-.02em;margin:0 0 1.5rem;font-size:2rem;line-height:1.2}h2{margin:3rem 0 1rem;scroll-margin-top:2rem;font-size:1.4rem;line-height:1.25}h3{margin:2rem 0 .75rem;scroll-margin-top:2rem;font-size:1.1rem}p{margin:0 0 1.1rem}ul,ol{margin:0 0 1.1rem;padding-left:1.4rem}li{margin-bottom:.4rem}blockquote{border-left:3px solid var(--accent);background:var(--code-bg);color:var(--muted);border-radius:0 6px 6px 0;margin:1.5rem 0;padding:.3rem 1.25rem}blockquote p:last-child{margin-bottom:0}hr{border:none;border-top:1px solid var(--border);width:55%;margin:2.5rem auto}table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.875rem}th,td{text-align:left;vertical-align:top;border:1px solid var(--border);padding:.45rem .7rem}th{background:var(--code-bg);font-weight:600}pre{background:var(--code-bg);border:1px solid var(--border);overflow-x:auto;border-radius:8px;margin:1.4rem 0;padding:1rem 1.1rem;font-size:13px;line-height:1.35}pre code{display:block;background:0 0;border:none;padding:0;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace}code{background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:.08em .35em;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.83em}.hljs-comment,.hljs-quote{color:#9d998f;font-style:italic}.hljs-keyword,.hljs-selector-tag,.hljs-literal,.hljs-meta{color:#a0269c}.hljs-string,.hljs-regexp{color:#3f8a3d}.hljs-number,.hljs-symbol{color:#b06000}.hljs-title,.hljs-title.function_{color:#2f62c4}.hljs-built_in,.hljs-attr,.hljs-property{color:#0a7ca3}:root[data-theme=dark] .hljs-comment,:root[data-theme=dark] .hljs-quote{color:#5f6370}:root[data-theme=dark] .hljs-keyword,:root[data-theme=dark] .hljs-selector-tag,:root[data-theme=dark] .hljs-literal,:root[data-theme=dark] .hljs-meta{color:#c678dd}:root[data-theme=dark] .hljs-string,:root[data-theme=dark] .hljs-regexp{color:#98c379}:root[data-theme=dark] .hljs-number,:root[data-theme=dark] .hljs-symbol{color:#d19a66}:root[data-theme=dark] .hljs-title,:root[data-theme=dark] .hljs-title.function_{color:#61afef}:root[data-theme=dark] .hljs-built_in,:root[data-theme=dark] .hljs-attr,:root[data-theme=dark] .hljs-property{color:#56b6c2}.sim{border:1px solid var(--border);background:var(--code-bg);border-radius:8px;margin:1.5rem 0;padding:.9rem 1rem;font-family:-apple-system,Segoe UI,system-ui,BlinkMacSystemFont,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:.82rem}.sim canvas{display:block;max-width:100%;height:auto}.sim-controls{display:flex;flex-wrap:wrap;align-items: center;gap:.75rem;margin-bottom:.5rem}.sim-stat{color:var(--muted);font-variant-numeric:tabular-nums;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:.78rem}.sim button{font:inherit;background:var(--bg);border:1px solid var(--border);color:var(--fg);cursor:pointer;border-radius:6px;padding:.2rem .6rem}.sim button:hover{border-color:var(--accent)}.sim button.active{background:var(--accent);border-color:var(--accent);color:var(--bg)}.sim label{display:flex;color:var(--muted);align-items: center;gap:.4rem}.sim input[type=range]{accent-color:var(--accent);width:7rem}.sim-caption{font-weight:600}figure.mermaid{overflow-x:auto;text-align:center;margin:1.5rem 0}.loading{color:var(--muted);text-align:center;padding:4rem 0}#colophon{border-top:1px solid var(--border);color:var(--muted);margin-top:4rem;padding-top:1.25rem;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.72rem}.video{position:relative;aspect-ratio:16/9;margin:1.5rem 0}.video iframe{position:absolute;border:0;border-radius:8px;width:100%;height:100%;inset:0}.home-intro{color:var(--muted);max-width:42rem;margin-bottom:2rem}.home-design{margin:1.75rem 0}.home-design>h2{border:0;margin-bottom:.5rem}.home-list{columns:2;column-gap:2rem}@media (max-width:700px){.home-list{columns:1}}.home-list li{margin:.15rem 0}.home-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:.6rem}.home-card{display:block;border:1px solid var(--border);background:var(--code-bg);text-decoration:none;border-radius:8px;padding:.6rem .8rem}.home-card:hover{border-color:var(--accent)}.home-card h3{margin:0;font-size:.92rem}.nav-home{margin-bottom:.5rem;font-weight:600}.dead-link{color:var(--muted);text-decoration:none;cursor:default;border-bottom:1px dotted var(--border)}.home-cta{margin:1.25rem 0 2rem}.home-cta a{display:inline-block;border:1px solid var(--accent);color:var(--accent);text-decoration:none;border-radius:.5rem;padding:.6rem 1rem;font-weight:600}.home-cta a:hover{background:var(--accent);color:var(--bg)}.fc{max-width:46rem;margin:0 auto}.fc-title{margin:0 0 1rem}.fc-decks{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem}.fc-chip{border:1px solid var(--border);color:var(--fg);cursor:pointer;background:0 0;border-radius:999px;padding:.3rem .75rem;transition:all .12s;font-size:.85rem}.fc-chip:hover{border-color:var(--accent)}.fc-chip.on{background:var(--accent);border-color:var(--accent);color:var(--bg)}.fc-chip .fc-n{opacity:.6;font-variant-numeric:tabular-nums}.fc-chip.on .fc-n{opacity:.85}.fc-meta{display:flex;color:var(--muted);align-items: center;gap:1rem;margin-bottom:.75rem;font-size:.85rem}.fc-toggle{cursor:pointer;user-select:none}.fc-count{font-variant-numeric:tabular-nums;margin-left:auto}.fc-card{border:1px solid var(--border);background:var(--code-bg);display:flex;text-align:center;cursor:pointer;border-radius:.75rem;justify-content:center;align-items: center;min-height:14rem;padding:2rem 1.75rem;box-shadow:0 1px 3px #0000000f}.fc-card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.fc-face{animation:fc-in .18s ease;width:100%}.fc-card:not(.flip) .fc-back,.fc-card.flip .fc-front{display:none}@keyframes fc-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}.fc-deck-tag{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.9rem;font-size:.7rem}.fc-known-tag{color:var(--sim-good)}.fc-q{font-size:1.25rem;font-weight:600;line-height:1.4}.fc-a{text-align:left;font-size:1.05rem;line-height:1.55}.fc-hint{color:var(--muted);margin-top:1.1rem;font-size:.8rem}.fc-controls{display:flex;gap:.5rem;margin-top:1rem}.fc-btn{border:1px solid var(--border);color:var(--fg);cursor:pointer;background:0 0;border-radius:.5rem;flex:1;padding:.55rem .5rem;transition:all .12s;font-size:.9rem}.fc-btn:hover{border-color:var(--accent);color:var(--accent)}.fc-known-btn{color:var(--sim-good)}.fc-progress{background:var(--border);overflow:hidden;border-radius:2px;height:4px;margin-top:1rem}.fc-progress-fill{background:var(--accent);height:100%;transition:width .2s}.fc-help{text-align:center;color:var(--muted);margin-top:.9rem;font-size:.78rem}.fc-help kbd{background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:0 .35rem;font-family:inherit;font-size:.72rem}.fc-empty{border:1px dashed var(--border);text-align:center;color:var(--muted);border-radius:.75rem;padding:3rem 1.5rem}
