:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#fffff8;overflow-x:hidden}html{overflow-x:hidden}.app{min-height:100vh;padding:28px 16px 40px;display:flex;flex-direction:column;align-items:center;gap:12px;background:#fffff8;color:#111;font-family:ET Book,Palatino,Palatino Linotype,Book Antiqua,Georgia,serif}@media(max-width:520px){.app{padding:16px 10px 24px;gap:8px}.app h1{font-size:22px}.app-subtitle{font-size:12px}}.app h1{margin:0;font-size:28px;letter-spacing:-.3px;font-weight:400}.app-subtitle{margin:0;font-size:14px;color:#5a554b;letter-spacing:.2px}.scrubber-nav{display:flex;gap:20px;justify-content:flex-end;margin-bottom:16px;padding:12px 0}.scrubber-nav a{color:#06c;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.scrubber-nav a:hover{color:#004999;text-decoration:underline}.compiler-scrubber{--paper: #fffdf4;--wash: #f4f0e6;--ink: #111111;--muted: #55544f;--accent: #2a623d;--accent-strong: #1f4d2f;--accent-warm: #8b0000;--line: #111111;--line-soft: #c9c3b7;--grid: #e1dbcf;width:min(1100px,100%);padding:0;border-radius:0;border:none;background:transparent;color:var(--ink);font-family:ET Book,Palatino,Palatino Linotype,Book Antiqua,Georgia,serif;box-shadow:none;animation:none}.scrubber-header{display:flex;flex-direction:column;gap:16px}.scrubber-controls{display:flex;gap:16px;align-items:flex-start;justify-content:flex-start;flex-wrap:wrap}.stage-controls{flex:0 1 auto;display:flex;flex-direction:column;gap:12px;min-width:0}.stage-pill-row{position:relative;display:flex;gap:8px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;touch-action:pan-x;overscroll-behavior-x:contain;scrollbar-width:none;-ms-overflow-style:none;padding-top:42px;padding-bottom:20px;margin-bottom:-20px;isolation:isolate}.stage-pill-row:after{content:"";position:absolute;top:42px;right:0;bottom:20px;width:1px;pointer-events:none;z-index:8;opacity:0;transition:none;background:transparent;box-shadow:12px 0 14px -8px #0000006b}.stage-pill-row.show-right-fade:after{opacity:1}.stage-why-link{position:absolute;top:-38px;left:50%;transform:translate(-50%);border:none;background:transparent;color:#2a5f9a;font-size:13px;font-weight:600;line-height:1;padding:0;cursor:pointer;text-decoration:underline}.stage-pill-row::-webkit-scrollbar{width:0;height:0;display:none}.stage-pill{--pill-bg: #ffffff;--pill-border: var(--line);--pill-border-width: 2px;--pill-arrow: 12px;--pill-notch: 10px;--pill-arrow-inner: calc(var(--pill-arrow) - var(--pill-border-width));--pill-notch-inner: calc(var(--pill-notch) + var(--pill-border-width));display:inline-flex;flex:0 0 190px;width:190px;align-items:center;justify-content:flex-start;gap:8px;padding:5px calc(var(--pill-arrow) + 5px) 5px calc(var(--pill-notch) + 8px);height:36px;box-sizing:border-box;border:none;background:transparent;color:var(--ink);font-size:11px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:none;position:relative;margin-right:0;z-index:1;isolation:isolate;line-height:1}.stage-pill:before,.stage-pill:after{content:"";position:absolute;inset:0;pointer-events:none;clip-path:polygon(0 0,calc(100% - var(--pill-arrow)) 0,100% 50%,calc(100% - var(--pill-arrow)) 100%,0 100%,var(--pill-notch) 50%)}.stage-pill:before{background:var(--pill-border);z-index:0}.stage-pill:after{inset:var(--pill-border-width);background:var(--pill-bg);z-index:1;clip-path:polygon(0 0,calc(100% - var(--pill-arrow-inner)) 0,100% 50%,calc(100% - var(--pill-arrow-inner)) 100%,0 100%,var(--pill-notch-inner) 50%)}.stage-pill>*{position:relative;z-index:2}.stage-pill>.stage-why-link{position:absolute;z-index:4}.stage-pill:hover{z-index:3;transform:none}.stage-pill:active{transform:none}.stage-pill:hover:not(.active){--pill-bg: #ffffff}.stage-pill-row .stage-pill:first-child{margin-left:0}.stage-pill-row .stage-pill:last-child{margin-right:0}.stage-pill.active{--pill-bg: var(--accent);--pill-border: var(--accent);color:#fff}.stage-pill-index{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:1px solid var(--line);background:#fffdf4;color:var(--ink);font-size:11px;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;line-height:1}.stage-pill.active .stage-pill-index{background:#fff}.stage-pill-label{display:block;flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased}.stage-slider-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.play-button{border:1.5px solid var(--line);border-radius:8px;padding:7px 14px;background:var(--accent);color:#fff;font-weight:600;font-size:12px;cursor:pointer;transition:background .2s ease,opacity .2s ease;box-shadow:none}.play-button:hover{background:var(--accent-strong);opacity:.9}.play-button:active{opacity:.8}.play-button.playing{background:var(--accent-warm)}.stage-slider-row input[type=range]{flex:1 1 240px;accent-color:var(--accent)}.stage-index-readout{font-size:12px;color:var(--muted);font-weight:600;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.view-toggle{display:inline-flex;gap:6px;padding:2px;border-radius:8px;background:#fff;border:1.5px solid var(--line)}.view-toggle-button{border:1px solid transparent;background:transparent;padding:5px 12px;border-radius:6px;font-weight:600;color:var(--muted);cursor:pointer;font-size:12px;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;transition:background .12s ease,color .12s ease,border .12s ease}.view-toggle-button.active{background:#f2efe7;color:var(--ink);border-color:var(--line)}.stage-summary{padding:12px 14px;border-radius:10px;background:var(--wash);border:1.5px solid var(--line);border-left:6px solid var(--accent);display:grid;gap:6px;animation:fade-up .5s ease}@keyframes fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.stage-summary-title{font-size:18px;font-weight:400}.stage-summary-liner{color:var(--muted);font-size:14px}.stage-summary-highlights{margin:6px 0 0;padding-left:18px;color:var(--ink);font-size:13px;display:grid;gap:4px}.stage-summary-highlights li{animation:highlight-in .48s ease;animation-fill-mode:both}.stage-summary-highlights li:nth-child(1){animation-delay:80ms}.stage-summary-highlights li:nth-child(2){animation-delay:.14s}.stage-summary-highlights li:nth-child(3){animation-delay:.2s}.stage-summary-highlights li:nth-child(4){animation-delay:.26s}@keyframes highlight-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.main-content{margin-top:14px;display:grid;grid-template-columns:1fr 260px;gap:14px}.pane{background:#fffdf6;border-radius:10px;border:1.5px solid var(--line);display:flex;flex-direction:column;min-height:450px;overflow:hidden;animation:pane-in .5s ease}.single-pane{min-height:400px}@keyframes pane-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.pane-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border-bottom:1.5px solid var(--line);background:#f2efe7;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.pane-header-actions{display:inline-flex;align-items:center;gap:6px}.pane-mac-controls{display:inline-flex;align-items:center;gap:8px;padding:0 2px}.pane-mac-dot{width:11px;height:11px;border-radius:999px;border:1px solid rgba(0,0,0,.24);display:inline-block}.pane-mac-dot-red{background:#ff5f57}.pane-mac-dot-yellow{background:#febc2e}.pane-mac-dot-green{background:#28c840}.pane-body{padding:14px;flex:1;display:flex}.empty-pane{margin:auto;color:var(--muted);font-size:14px}.code-block{width:100%;display:flex;flex-direction:column;background:#fbf7ef;border-radius:10px;overflow:hidden;border:1.5px solid var(--line)}.code-toolbar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f1ecdf;color:var(--ink);font-size:11px;border-bottom:1.5px solid var(--line)}.code-title{font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.copy-button{border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;padding:3px 10px;font-size:11px;cursor:pointer;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.copy-button:hover{background:#f2efe7}.code-content{padding:14px;overflow:auto;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;line-height:1.55;color:#111}.code-line{display:grid;grid-template-columns:minmax(28px,auto) 42px 1fr;gap:12px;padding:2px 4px 2px 6px;border-radius:6px;transition:background .16s ease}.code-line-ops{display:flex;gap:3px;flex-wrap:nowrap;align-items:center;justify-content:center;min-height:18px}.op-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:999px;font-size:10px;font-weight:700;line-height:1;box-shadow:1px 1px 0 var(--line);font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;transition:transform .15s ease,box-shadow .15s ease}.code-line.op-highlighted .op-badge{transform:scale(1.15);box-shadow:2px 2px 0 var(--line)}.code-line.op-dimmed{opacity:.35}.code-line.op-highlighted{background:#2a623d1f;border-radius:4px}.code-line-number{text-align:right;color:#8a857c}.code-line.match{background:#2a623d24;box-shadow:inset 3px 0 0 var(--accent)}.code-line.similar{background:#2a623d14;box-shadow:inset 3px 0 #2a623d73}.code-line.match .code-line-number{color:#2a623d}.code-line.similar .code-line-number{color:#6b4b1f}.code-line-content{white-space:pre}.code-line-content.highlighted{background:#2a623d33;padding:2px 4px;border-radius:3px}.token.highlighted{background:#2a623d40}.token-keyword{color:var(--accent);font-weight:600}.token-comment{color:#7b746b;font-style:italic}.graph-view-wrapper{display:flex;flex-direction:column;width:75%;height:100%;margin:0 auto;gap:4px;overflow:hidden}.graph-view{position:relative;width:100%;flex:1;min-height:638px;overflow:auto;border-radius:10px;background-color:#f7f3ea;background-image:radial-gradient(#ded7cb .8px,transparent .8px);background-size:18px 18px;border:1.5px solid var(--line)}.graph-view.graph-view-dark{background-color:#f7f3ea;background-image:radial-gradient(#ded7cb .8px,transparent .8px);border-color:var(--line)}.graph-view-image{background-color:#f7f3ea;background-image:radial-gradient(#ded7cb .8px,transparent .8px)}.graph-canvas{width:100%;height:100%;cursor:grab;touch-action:none;overflow:auto;contain:strict}.graph-canvas.panning{cursor:grabbing}.operation-highlight{fill:none;stroke:red;stroke-width:.15;stroke-linecap:round;stroke-linejoin:round;animation:highlight-pulse 1.5s ease-out forwards;pointer-events:none}@keyframes highlight-pulse{0%{stroke:red;stroke-width:.2;filter:drop-shadow(0 0 8px #ff0000) drop-shadow(0 0 4px #ff0000)}50%{stroke-width:.15;filter:drop-shadow(0 0 6px #ff0000) drop-shadow(0 0 2px #ff0000)}to{stroke:red;stroke-width:.15;filter:drop-shadow(0 0 4px #ff0000) drop-shadow(0 0 1px #ff0000)}}.graph-view svg{width:100%;height:100%;will-change:transform}.graph-view svg g{will-change:transform;transform-origin:0 0}.graph-edge{stroke:var(--line);stroke-width:1.6}.graph-edge-arrow{fill:var(--line)}.graph-node rect{fill:#fff;stroke:var(--line);stroke-width:1.4}.graph-node text{font-size:12px;fill:var(--ink);font-weight:600;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.graph-node:hover rect{fill:#f0ece2}.graph-tooltip{position:absolute;background:#111;color:#fffdf4;padding:6px 10px;border-radius:6px;font-size:11px;pointer-events:none;max-width:220px;box-shadow:0 6px 14px #0003}.graph-controls{display:none;align-items:center;justify-content:flex-end;gap:6px;padding:0 0 2px}.graph-control-button{border:1px solid var(--line);background:#fff;border-radius:4px;width:24px;height:24px;font-size:14px;font-weight:600;color:var(--ink);cursor:pointer;transition:background .15s ease,transform .15s ease,box-shadow .15s ease;display:flex;align-items:center;justify-content:center}.graph-control-button:hover{background:#f0ece2;transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.graph-control-button:active{transform:translateY(0);box-shadow:none}.graph-control-button.reset-button{width:auto;padding:0 8px;font-size:11px;font-weight:600;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.graph-zoom-readout{font-size:11px;font-weight:600;color:var(--ink);padding:0 4px;min-width:40px;text-align:center;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.graph-view.graph-view-dark .graph-controls{background:#f7f3eaeb;border-color:var(--line)}.graph-view.graph-view-dark .graph-control-button{background:#fffaf0;color:var(--ink);border-color:var(--line)}.graph-view.graph-view-dark .graph-zoom-readout{color:var(--ink)}.graph-view.graph-view-dark .graph-edge{stroke:var(--line)}.graph-view.graph-view-dark .graph-edge-arrow{fill:var(--line)}.graph-view.graph-view-dark .graph-node rect{fill:#fff;stroke:var(--line)}.graph-view.graph-view-dark .graph-node text{fill:var(--ink)}.graph-view.graph-view-dark .graph-node:hover rect{fill:#f0ece2}.graph-node[data-tone=input] rect,.graph-edge[data-tone=input]{stroke:#f4a340}.graph-node[data-tone=input] text{fill:#f8c57d}.graph-node[data-tone=q] rect,.graph-edge[data-tone=q]{stroke:#2dd36f}.graph-node[data-tone=q] text{fill:#7df0ae}.graph-node[data-tone=k] rect,.graph-edge[data-tone=k]{stroke:#2f9bff}.graph-node[data-tone=k] text{fill:#7dc0ff}.graph-node[data-tone=v] rect,.graph-edge[data-tone=v]{stroke:#ff5e5e}.graph-node[data-tone=v] text{fill:#ff9b9b}.graph-node[data-tone=scores] rect,.graph-edge[data-tone=scores]{stroke:#9d7bff}.graph-node[data-tone=scores] text{fill:#c4b3ff}.graph-node[data-tone=scale] rect,.graph-edge[data-tone=scale]{stroke:#55d6a6}.graph-node[data-tone=scale] text{fill:#97f0cc}.graph-node[data-tone=softmax] rect,.graph-edge[data-tone=softmax]{stroke:#38c3ff}.graph-node[data-tone=softmax] text{fill:#8fdcff}.graph-node[data-tone=output] rect,.graph-edge[data-tone=output]{stroke:#f5c542}.graph-node[data-tone=output] text{fill:#ffe09a}.bench-panel{margin-top:14px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.bench-metric{padding:10px 12px;background:#fffdf6;border-radius:10px;border:1.5px solid var(--line);display:grid;gap:8px}.bench-metric-header{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.bench-metric-label{font-size:11px;color:var(--muted);font-weight:600;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.bench-metric-value{font-size:14px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.bench-bar{height:8px;border-radius:999px;background:#e6e1d5;overflow:hidden}.bench-bar-fill{height:100%;border-radius:999px;transition:width .5s ease;background:var(--accent)}.bench-time_ms .bench-bar-fill{background:#8b0000}.bench-speedup_x .bench-bar-fill{background:#2a623d}@media(max-width:900px){.compiler-scrubber{display:flex;flex-direction:column}.scrubber-nav{order:1}.scrubber-header{gap:10px;order:2}.scrubber-controls{gap:8px}.stage-controls{flex:1 1 auto}.bench-panel{grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;order:3}.operation-legend{position:static;order:4;padding:6px 10px;border-radius:8px;flex-direction:row!important;align-items:center;gap:8px}.legend-title{display:none}.legend-grid{display:flex;flex-direction:row!important;flex-wrap:wrap;gap:4px;justify-content:flex-start;flex:1}.legend-item-wrapper{width:auto!important}.legend-item{padding:3px 6px 3px 4px!important;border:1px solid var(--line-soft)!important;background:#fff!important;flex:0 0 auto;border-radius:4px!important;gap:4px!important;width:auto!important}.legend-item:hover:not(:disabled){transform:none;background:#f8f6ef!important}.legend-item.inactive{display:none!important}.legend-item.highlighted{background:#f0ece2!important;border-color:var(--accent)!important;box-shadow:0 1px 4px #0000001a!important}.legend-label{display:inline!important;font-size:10px!important}.legend-badge{min-width:16px!important;height:16px!important;font-size:9px!important;cursor:pointer}.legend-clear{margin-top:0;padding:6px 10px;font-size:11px;white-space:nowrap;flex-shrink:0}.inline-tooltip{position:fixed;inset:auto 12px 12px;transform:none;width:auto;max-width:none;padding:10px 12px;font-size:12px;border-radius:8px;animation:tooltip-slide-up .15s ease-out}.inline-tooltip:before{display:none}@keyframes tooltip-slide-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.pane-header{display:none}.pane{min-height:0!important;height:auto!important;animation:none}.single-pane{min-height:0!important;height:auto!important}.pane-body{min-height:0!important;height:auto!important;flex:0 0 auto!important;padding:8px!important}.graph-view-wrapper{height:auto!important;min-height:0!important}.graph-view{min-height:300px!important;height:auto!important}.code-block{max-height:none;overflow:visible}.code-content{max-height:700px;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.stage-summary{padding:8px 10px}.stage-summary-highlights{display:none}.main-content{order:5;display:flex!important;flex-direction:column!important;width:100%!important}.pane{width:100%!important;max-width:100%!important}.article-layout{order:6}.compiler-scrubber-footnote{order:7}.compiler-scrubber,.pane,.stage-summary{animation:none!important}}@media(max-width:700px){.scrubber-controls{flex-direction:column;align-items:stretch;gap:8px}.view-toggle{align-self:flex-start}.stage-summary-liner{font-size:12px}.legend-label{display:none}.legend-item{padding:4px 5px}.legend-badge{min-width:20px;height:20px;font-size:10px}.code-block{max-height:none;overflow:visible}.code-content{padding:8px;font-size:11px;max-height:600px;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.code-line{grid-template-columns:minmax(22px,auto) 28px 1fr;gap:5px}.bench-panel{margin-top:8px}.bench-metric{padding:8px}}@media(max-width:520px){.compiler-scrubber{padding:10px;border-radius:8px;box-shadow:0 4px 12px #00000014}.pane,.single-pane{min-height:0!important;height:auto!important}.pane-body{min-height:0!important;height:auto!important;flex:0 0 auto!important;padding:6px!important}.scrubber-nav{margin-bottom:6px;padding:6px 0;gap:12px}.scrubber-nav a{font-size:11px}.stage-pill-row{gap:4px;overflow-x:hidden}.stage-pill-label{display:none}.stage-pill{--pill-arrow: 12px;--pill-notch: 6px;width:calc((100% - 24px) / 7);flex:0 0 calc((100% - 24px) / 7);min-width:42px;justify-content:center;gap:0;padding:4px calc(var(--pill-arrow) + 6px) 4px calc(var(--pill-notch) + 6px)}.stage-pill-index{width:14px;height:14px;font-size:9px}.stage-summary{padding:6px 8px}.stage-summary-title{font-size:14px}.stage-summary-liner{font-size:11px;line-height:1.3}.operation-legend{padding:4px 6px;gap:6px}.legend-grid{gap:3px}.legend-badge{min-width:20px;height:20px;font-size:10px}.legend-clear{padding:3px 6px;font-size:9px}.code-block{max-height:none;overflow:visible;border-radius:6px}.code-toolbar{padding:5px 8px}.code-title{font-size:10px}.copy-button{padding:3px 8px;font-size:10px}.code-content{padding:6px;font-size:9px;line-height:1.35;max-height:600px;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.code-line{grid-template-columns:minmax(16px,auto) 22px 1fr;gap:3px;padding:1px 2px}.code-line-number{font-size:8px}.op-badge{min-width:14px;height:14px;font-size:7px;padding:0 2px}.bench-panel{margin-top:8px;gap:6px}.bench-metric{padding:6px 8px}.bench-metric-label{font-size:9px}.bench-metric-value{font-size:12px}.bench-bar{height:6px}.play-button{padding:5px 10px;font-size:10px}.view-toggle-button{padding:4px 8px;font-size:10px}.legend-clear{padding:5px 8px;font-size:9px}.compiler-scrubber-footnote{margin-top:12px;padding-top:12px;font-size:11px}}.operation-legend{background:#fffdf6;border-radius:10px;border:1.5px solid var(--line);padding:12px;display:flex;flex-direction:column;gap:10px;height:fit-content;overflow:visible}.legend-title{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.legend-grid{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.legend-item{display:flex;align-items:center;gap:5px;padding:4px 8px 4px 5px;border-radius:5px;border:1px solid var(--line-soft);background:#fff;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease,opacity .12s ease;text-align:left;width:130px;justify-content:flex-start}.legend-item:hover:not(:disabled){transform:translate(2px);background:#f8f6ef;border-color:var(--line)}.legend-item.inactive{opacity:.4;cursor:not-allowed}.legend-item.highlighted{background:#f0ece2;border-color:var(--accent);box-shadow:0 2px 8px #0000001a}.legend-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--op-bg);color:var(--op-text);font-size:10px;font-weight:700;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace;flex-shrink:0}.legend-label{font-size:11px;font-weight:500;color:var(--ink);white-space:nowrap}.legend-clear{margin-top:4px;padding:8px 12px;border-radius:6px;border:1px solid var(--line);background:var(--wash);color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;transition:background .12s ease,color .12s ease;font-family:IBM Plex Mono,SFMono-Regular,Consolas,Liberation Mono,monospace}.legend-item-wrapper{position:static;display:block;width:100%;align-self:stretch}.inline-tooltip{position:relative;margin-top:6px;width:100%;max-width:none;padding:8px 10px;background:#111111f2;color:#ffffffeb;border-radius:6px;font-size:11px;line-height:1.35;letter-spacing:0;box-shadow:0 1px 4px #00000026;z-index:2;animation:none;pointer-events:auto}.inline-tooltip:before{content:none}.inline-tooltip-text{display:block}@keyframes tooltip-pop{0%{opacity:0;transform:translateY(-50%) scale(.96)}to{opacity:1;transform:translateY(-50%) scale(1)}}.legend-clear:hover{background:#e6e1d5;color:var(--ink)}.compiler-scrubber-footnote{margin-top:48px;padding:18px 0 10px;border-top:1px solid #d0c8b8;text-align:center;font-size:12px;line-height:1.45;letter-spacing:.01em;color:#6f6b63}.compiler-scrubber-footnote p{margin:0 auto 8px;max-width:780px}.compiler-scrubber-footnote a{color:#2a5f9a;text-decoration:none;font-weight:500}.compiler-scrubber-footnote a:hover{text-decoration:underline}.article-layout{width:100%;margin:0;padding:0;display:block}.motivation-article{max-width:860px;margin:64px auto 0;padding:0 24px;font-family:Georgia,Times New Roman,serif;font-size:18px;line-height:1.8;color:#222}.motivation-article h2{font-family:Georgia,Times New Roman,serif;font-size:30px;font-weight:700;letter-spacing:-.01em;color:#111;margin-top:72px;margin-bottom:20px}.motivation-article h2:first-child{margin-top:0}.motivation-article h3{font-family:Georgia,Times New Roman,serif;font-size:22px;font-weight:700;letter-spacing:0;color:#111;margin-top:52px;margin-bottom:14px}.motivation-article h4{font-family:Georgia,Times New Roman,serif;font-size:18px;font-weight:700;letter-spacing:0;color:#222;margin-top:44px;margin-bottom:10px}.section-heading-row{display:block;margin-top:52px}.section-heading-row h2,.section-heading-row h3{margin-top:0;margin-right:0}.section-heading-row h2[id],.section-heading-row h3[id],.motivation-article h2[id],.motivation-article h3[id]{scroll-margin-top:64px}.article-bottom-toc{position:fixed;left:10px;top:193px!important;transform:none;width:150px;margin:0;padding:10px 14px;border:1px solid #d5cebd;border-radius:8px;background:#fffdf7f5;display:flex;flex-direction:column;align-items:flex-start;gap:8px;z-index:50;max-height:calc(100vh - 140px);overflow:auto}.article-bottom-toc-title{font-weight:700;color:#111;margin-right:10px}.article-bottom-toc a{color:#2a5f9a;text-decoration:none;white-space:normal;font-size:13px;transition:font-size .14s ease,font-weight .14s ease,color .14s ease,text-decoration-color .14s ease}.article-bottom-toc a:hover{text-decoration:underline}.article-bottom-toc a.active{font-size:15px;font-weight:700;color:#18467f;text-decoration:underline}.toc-speed-box{margin-top:6px;width:100%;border:1px solid #d5cebd;border-radius:6px;background:#fffdf7;padding:6px 8px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.toc-speed-line{display:inline-flex;align-items:center;gap:6px}.toc-speed-label{font-size:11px;color:#333;text-transform:lowercase}.toc-speed-value{font-size:12px;font-weight:700;color:#111}.toc-speed-delta{font-size:12px;font-weight:700}.toc-speed-delta.faster{color:#1d7a35}.toc-speed-delta.slower{color:#b42323}.toc-speed-delta.neutral{color:#666}.go-back-link{border:none;background:transparent;color:#2a5f9a;font-size:13px;font-weight:600;text-decoration:underline;cursor:pointer;white-space:nowrap;padding:0;display:inline-block;margin:0 0 2px}.motivation-article p{margin-bottom:22px;color:#222;text-align:justify;text-justify:inter-word}.motivation-article li,.compiler-scrubber-footnote p{text-align:justify;text-justify:inter-word}.motivation-article em{font-style:italic;color:#555}.motivation-article strong{font-weight:700;color:#111}.motivation-article code{font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace;font-size:.82em;background:#f3f1ed;color:#222;padding:2px 6px;border-radius:4px;border:1px solid #e2ddd6}.motivation-article pre{background:#f3f3f5;border:1px solid #8e8e8e;border-radius:8px;padding:16px 18px;overflow-x:auto;margin:28px 0}.motivation-article pre code{background:none;border:none;color:#1f1f1f;padding:0;font-size:13px;line-height:1.65}.article-codeblock{box-shadow:none}.stage-diff-block{margin:12px 0 20px}.code-line-ref{margin-top:-6px;margin-bottom:16px;font-size:15px;color:#5d5750;font-style:normal}.stage-diff-controls{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.stage-diff-label{font-size:12px;color:#666;font-family:IBM Plex Mono,SFMono-Regular,Consolas,monospace}.stage-diff-button{border:1px solid #cfc7b6;background:#fff;color:#2a5f9a;border-radius:6px;font-size:11px;padding:3px 8px;cursor:pointer;text-transform:lowercase}.stage-diff-button:hover{background:#f5f2ea}.article-token{color:#1f1f1f}.article-token-keyword{color:#00f}.article-token-type{color:#267f99}.article-token-string{color:#a31515}.article-token-number{color:#098658}.article-token-comment{color:green;font-style:italic}.article-token-function{color:#795e26}.article-token-variable{color:#001080}.article-token-operator{color:#1f1f1f}.article-token-dialect{color:#af00db}.motivation-article ul,.motivation-article ol{margin-bottom:24px;padding-left:28px;color:#222}.motivation-article li{margin-bottom:10px;line-height:1.75}.motivation-article ul li{list-style-type:disc}.motivation-article ol li{list-style-type:decimal}.motivation-article hr{border:none;border-top:1px solid #e2ddd6;margin:52px 0}.reduction-fun-fact{display:inline-flex;align-items:flex-start;gap:10px;max-width:100%;border:1px solid #d8d0bf;border-radius:10px;background:#fffdf2;padding:10px 12px;margin:6px 0 22px;line-height:1.5}.reduction-fun-fact-icon{font-size:17px;line-height:1.1;margin-top:1px}.final-feedback-callout{display:inline-block;max-width:100%;padding:12px 14px;margin:10px 0 0;border:1px solid #d0c8b8;border-radius:12px;background:#fbf9f4;color:#222;line-height:1.55;overflow-wrap:anywhere}.final-feedback-callout a{color:#2a5f9a;text-decoration:underline}.fusion-diagram{margin:48px 0;text-align:center}.fusion-diagram-img-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:160px}.fusion-diagram-img{max-width:100%;height:auto;max-height:500px;object-fit:contain;opacity:0;position:absolute;top:0;left:0;right:0;margin:auto;transition:none;pointer-events:none;mix-blend-mode:normal;will-change:auto;backface-visibility:visible;transform:none}.fusion-diagram-img.active{opacity:1;position:relative;pointer-events:auto;z-index:1}.fusion-diagram-img.small{max-height:280px}.fusion-diagram-controls{display:inline-flex;align-items:center;gap:10px;margin-top:20px}.fusion-diagram-label{font-family:IBM Plex Mono,Consolas,monospace;font-size:13px;color:#888;min-width:52px;text-align:right;letter-spacing:.02em}.fusion-diagram-buttons{display:flex;gap:6px;align-items:center}.fusion-btn{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;border:1px solid #d6d0c8;background:#fff;color:#333;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.fusion-btn:hover:not(:disabled){background:#f3f1ed;border-color:#b8b2a8}.fusion-btn:disabled{opacity:.25;cursor:default}.fusion-diagram-caption{margin-top:14px!important;margin-bottom:0!important;font-family:-apple-system,BlinkMacSystemFont,Inter,sans-serif;font-size:13px!important;color:#999!important;text-align:center!important;font-style:italic}.fusion-rule-figure{margin:14px 0 26px}.fusion-rule-image{display:block;width:75%;height:auto;border:none;border-radius:0;margin:0 auto}.fusion-rule-caption{margin-top:8px;font-size:14px;color:#5e5950;font-style:italic;text-align:center}.fusion-rule-dropdown{margin:10px 0 22px;border:1px solid #d4cec2;border-radius:10px;background:#fffdf6;padding:10px 12px}.fusion-rule-dropdown>summary{cursor:pointer;font-weight:600;color:#2a5f9a}.fusion-rule-dropdown-content{margin-top:10px}.fusion-rule-dropdown-content p{margin:10px 0}@media(max-width:900px){.article-layout{margin-top:0;padding-bottom:calc(220px + env(safe-area-inset-bottom,0px))}.motivation-article{margin:32px auto 0;padding:0 20px;font-size:16px}.article-bottom-toc{position:fixed;left:8px;right:8px;bottom:calc(8px + env(safe-area-inset-bottom,0px));top:auto!important;width:auto;height:auto;max-height:none;overflow:visible;margin:0;padding:8px 10px;flex-direction:row;flex-wrap:wrap;align-items:flex-start;align-content:flex-start;gap:8px;z-index:60;box-sizing:border-box}.article-bottom-toc-title,.article-bottom-toc a{flex:0 0 auto;white-space:nowrap}.article-bottom-toc-title{flex-basis:100%;font-size:14px;margin-right:4px}.article-bottom-toc a,.article-bottom-toc a.active{font-size:11px}.toc-speed-box{margin-top:0;width:100%;margin-left:0;padding:4px 6px;gap:8px;flex:0 0 auto;flex-wrap:nowrap;justify-content:flex-start}.toc-speed-line{gap:4px;justify-content:flex-start}.toc-speed-label,.toc-speed-value,.toc-speed-delta{font-size:10px}.motivation-article h2{font-size:24px;margin-top:48px}.motivation-article h3{font-size:17px;margin-top:36px}.motivation-article h4{font-size:11px;margin-top:28px}.motivation-article pre{padding:14px 16px}.motivation-article pre code{font-size:11.5px}.fusion-btn{width:34px;height:34px}}.motivation-page{min-height:100vh;padding:28px 16px 60px;background:#fffff8;color:#111;font-family:ET Book,Palatino,Palatino Linotype,Book Antiqua,Georgia,serif}.motivation-nav{max-width:720px;margin:0 auto 32px}.back-link{display:inline-flex;align-items:center;gap:6px;color:#06c;text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}.back-link:hover{color:#004999;text-decoration:underline}.motivation-content{max-width:720px;margin:0 auto;line-height:1.7}.motivation-content h1{font-size:32px;font-weight:400;margin:0 0 40px;letter-spacing:-.5px;color:#111}.motivation-section{margin-bottom:40px}.motivation-section h2{font-size:20px;font-weight:600;margin:0 0 16px;color:#2a623d;letter-spacing:-.2px}.motivation-section p{margin:0 0 16px;font-size:16px;color:#333}.motivation-section ul,.motivation-section ol{margin:0 0 16px;padding-left:24px}.motivation-section li{margin-bottom:10px;font-size:16px;color:#333}.motivation-section ol{counter-reset:list-counter;list-style:none;padding-left:0}.motivation-section ol li{counter-increment:list-counter;position:relative;padding-left:32px}.motivation-section ol li:before{content:counter(list-counter);position:absolute;left:0;top:2px;width:20px;height:20px;background:#2a623d;color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:IBM Plex Mono,monospace}.motivation-section ul li{position:relative;padding-left:20px;list-style:none}.motivation-section ul li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;background:#2a623d;border-radius:50%}@media(max-width:600px){.motivation-page{padding:20px 16px 40px}.motivation-nav{margin-bottom:24px}.motivation-content h1{font-size:24px;margin-bottom:28px}.motivation-section{margin-bottom:28px}.motivation-section h2{font-size:18px;margin-bottom:12px}.motivation-section p,.motivation-section li{font-size:15px}.motivation-section ol li{padding-left:28px}.motivation-section ol li:before{width:18px;height:18px;font-size:10px}}
