*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}#app{height:100vh;overflow:hidden}.app-main{height:100vh;padding:12px 20px;display:flex;flex-direction:column;overflow:hidden;transition:margin-left .2s ease}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-shrink:0}.header h1{font-size:1.4rem}.algo-sidebar{position:fixed;top:0;left:0;width:200px;height:100vh;background:#fff;border-right:1px solid #ddd;display:flex;flex-direction:column;z-index:10;transition:width .2s ease}.algo-sidebar-collapsed{width:28px}.algo-sidebar-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;font-size:18px;color:#888;cursor:pointer;flex-shrink:0;align-self:flex-end}.algo-sidebar-toggle:hover{color:#333;background:#f0f0f0}.algo-sidebar-content{flex:1;overflow-y:auto;padding-bottom:8px}.algo-sidebar-group{display:flex;flex-direction:column}.algo-sidebar-group-header{display:flex;align-items:center;gap:4px;padding:6px 12px;border:none;background:none;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#888;cursor:pointer;text-align:left}.algo-sidebar-group-header:hover{color:#555}.algo-sidebar-chevron{display:inline-block;font-size:10px;transition:transform .15s;width:12px;text-align:center}.algo-sidebar-chevron-open{transform:rotate(90deg)}.algo-sidebar-group-items{display:flex;flex-direction:column}.algo-sidebar-item{display:block;width:100%;padding:5px 12px 5px 28px;border:none;background:none;font-size:13px;color:#444;cursor:pointer;text-align:left;border-radius:0}.algo-sidebar-item:hover{background:#f0f0f0}.algo-sidebar-item-active{background:#e8f0ff;color:#1a5cc8;font-weight:600}.algo-sidebar-item-active:hover{background:#dce8fa}.algo-sidebar-custom{margin-top:4px;padding-top:4px;border-top:1px solid #eee}.main-layout{display:grid;grid-template-columns:400px 0px 1fr;gap:0 20px;flex:1;min-height:0;overflow:hidden}.resize-handle{width:12px;margin:0 -6px;cursor:col-resize;position:relative;z-index:2;display:flex;align-items:center;justify-content:center}.resize-handle:after{content:"";width:4px;height:32px;border-radius:2px;background:#ccc;transition:background .15s,height .15s}.resize-handle:hover:after{background:#999;height:48px}.resize-handle:active:after{background:#6a9fef;height:48px}.code-panel{background:#1e1e1e;border-radius:8px;padding:16px;overflow:auto;min-width:0;min-height:0}.code-panel pre{margin:0;font-size:13px;line-height:1.6}.code-line{padding:1px 8px;border-radius:3px;white-space:pre;color:#d4d4d4}.code-line-active{background:#ffff6426;border-left:3px solid #f0c040;padding-left:5px}.code-line-hovered{background:#64a0ff1f;border-left:3px solid #6a9fef;padding-left:5px}.code-line-active.code-line-hovered{background:#c8c85040;border-left:3px solid #d4a820}.code-line-directive{color:#666;font-style:italic}.code-line-skipped{opacity:.35;text-decoration:line-through;text-decoration-color:#00000040}.directive-line{color:#666;font-style:italic}.line-number{display:inline-block;width:24px;text-align:right;margin-right:12px;color:#666;-webkit-user-select:none;user-select:none}.variables-section{border-top:1px solid #444;margin-top:12px;padding-top:10px;font-family:monospace;font-size:13px;color:#d4d4d4}.variables-title{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#888;margin-bottom:6px}.variable-entry{padding:1px 0}.breakpoint-gutter{display:inline-flex;align-items:center;justify-content:center;width:14px;cursor:pointer;flex-shrink:0}.breakpoint-gutter-empty{cursor:default}.breakpoint-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#e45649;opacity:.85;transition:opacity .15s,background .15s}.breakpoint-dot-disabled{background:#555;opacity:.35}.breakpoint-gutter:hover .breakpoint-dot{opacity:1}.breakpoint-gutter:hover .breakpoint-dot-disabled{background:#888;opacity:.6}.shortcut-label{font-size:10px;color:#999;margin-left:4px}.right-column{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.canvas-wrapper{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.controls{display:flex;align-items:center;gap:12px;margin-top:8px;padding:8px 16px;background:#fff;border-radius:8px;border:1px solid #ddd;flex-shrink:0}.controls button{padding:6px 16px;font-size:14px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.controls button:hover:not(:disabled){background:#e8e8e8}.controls button:disabled{opacity:.4;cursor:default}.controls input[type=range]{flex:1}.step-counter{font-size:13px;color:#666;white-space:nowrap}.description{padding:8px 16px;font-size:14px;background:#fff;border-radius:8px;border:1px solid #ddd;min-height:36px;margin-top:8px;flex-shrink:0;overflow:auto}.description-block{color:#337;font-size:13px;font-weight:500;margin-bottom:2px}.description-previous{color:#aaa;font-size:13px;cursor:default}.description-current{color:#555;cursor:default}.var-pill{display:inline-flex;align-items:center;border:1.5px solid currentColor;border-radius:10px;padding:0 6px;margin:0 1px;font-size:12px;font-family:SF Mono,Fira Code,monospace;gap:3px;vertical-align:baseline;position:relative}.var-pill-has-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#333;color:#eee;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:11px;font-weight:400;padding:4px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .12s .1s}.var-pill-has-tooltip:hover:after,.var-pill-has-tooltip:focus-visible:after{opacity:1}.var-pill-name{opacity:.7;font-weight:500}.var-pill-name:after{content:"=";opacity:.5}.var-pill-name-only{font-weight:600}.var-pill-value{font-weight:700}.editor-panel{background:#1e1e1e;border-radius:8px;padding:16px;min-width:0;min-height:0;display:flex;flex-direction:column;gap:8px;overflow:hidden}.editor-toolbar{display:flex;align-items:center;gap:8px}.editor-toolbar-title{font-size:13px;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-right:auto}.editor-btn{padding:4px 10px;font-size:12px;border:1px solid #555;border-radius:4px;background:#2d2d2d;color:#ccc;cursor:pointer}.editor-btn:hover{background:#3a3a3a;color:#fff}.editor-overlay-container{position:relative;flex:1;border:1px solid #333;border-radius:4px;min-height:200px}.editor-overlay-container:focus-within{border-color:#555}.editor-overlay-pre,.editor-textarea{position:absolute;inset:0;margin:0;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:13px;line-height:1.6;padding:8px;tab-size:2;white-space:pre;overflow-wrap:normal;word-wrap:normal;border:none;border-radius:4px}.editor-overlay-pre{color:#d4d4d4;pointer-events:none;overflow:hidden;z-index:0}.editor-textarea{background:transparent;color:transparent;caret-color:#d4d4d4;resize:none;outline:none;overflow:auto;z-index:1}.editor-textarea::selection{background:#6496ff4d}.editor-input-row{display:flex;align-items:center;gap:8px}.editor-input-label{font-size:12px;color:#888;white-space:nowrap}.editor-input{flex:1;font-family:monospace;font-size:13px;background:#2d2d2d;color:#d4d4d4;border:1px solid #333;border-radius:4px;padding:4px 8px;outline:none}.editor-input:focus{border-color:#555}.editor-error{font-size:12px;color:#f88;background:#ff50501a;border:1px solid rgba(255,80,80,.3);border-radius:4px;padding:6px 8px;white-space:pre-wrap;word-break:break-word}.edit-btn{padding:6px 12px;font-size:14px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.edit-btn:hover{background:#e8e8e8}.dimmed{opacity:.3;pointer-events:none}.code-panel-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:8px}.code-panel-toolbar-title{font-size:13px;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-right:auto}.code-input-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.code-input-label{font-size:12px;color:#888;white-space:nowrap}.code-input{flex:1;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#ddd;font-family:monospace;font-size:13px;padding:3px 8px;min-width:0}.run-btn{padding:4px 14px;font-size:12px;font-weight:600;border:1px solid #4caf50;border-radius:4px;background:#4caf50;color:#fff;cursor:pointer}.run-btn:hover{background:#45a049}.changelog-banner{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;margin-bottom:12px;background:#e8f4fd;border:1px solid #b3d8f0;border-radius:8px;font-size:14px;color:#1a4a6e;flex-shrink:0}.changelog-content{flex:1}.changelog-header{font-size:1.2em;font-weight:700;margin-bottom:8px}.changelog-entry{line-height:1.5}.changelog-items{margin:4px 0 0;padding-left:20px}.changelog-items li{margin-bottom:2px}.changelog-separator{border:none;border-top:1px solid rgba(255,255,255,.2);margin:6px 0}.changelog-dismiss{background:none;border:none;font-size:18px;line-height:1;cursor:pointer;color:#1a4a6e;opacity:.6;padding:0 4px}.changelog-dismiss:hover{opacity:1}.dsl-docs{margin-top:8px;border:1px solid #ddd;border-radius:8px;background:#2d2d2d;flex-shrink:0}.dsl-docs-summary{font-size:13px;color:#999;cursor:pointer;padding:8px 12px;-webkit-user-select:none;user-select:none}.dsl-docs-summary:hover{color:#ccc}.dsl-docs-columns{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 12px 12px}.dsl-docs-col{min-width:0}.dsl-docs-heading{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#888;margin:0 0 6px 8px;font-weight:600}.dsl-docs-heading code{text-transform:none;letter-spacing:0}.dsl-docs-prefix{font-size:12px;color:#aaa}.dsl-docs-table{width:100%;border-collapse:collapse;font-size:12px}.dsl-docs-table td{padding:2px 8px;vertical-align:top}.dsl-docs-table td:first-child{white-space:nowrap}.dsl-docs-table td:last-child{color:#999}.dsl-docs-table code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:#d4d4d4}.dsl-docs-operators{color:#999!important;padding-top:4px!important}.dsl-docs-note{font-size:11px;color:#777;margin:8px 8px 0;line-height:1.4}.dsl-docs-note code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:#aaa}.algo-sidebar-mode-tabs{display:flex;gap:0;margin-bottom:8px;border-bottom:1px solid #ddd}.algo-sidebar-mode-tab{flex:1;padding:6px 4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;background:none;border:none;border-bottom:2px solid transparent;color:#999;cursor:pointer;transition:color .15s,border-color .15s}.algo-sidebar-mode-tab:hover{color:#555}.algo-sidebar-mode-tab-active{color:#333;border-bottom-color:#333}.algo-sidebar-ds-list{padding:4px 0}.ds-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.ds-body{flex:1;display:flex;gap:16px;min-height:0;overflow:hidden}.ds-controls{display:flex;flex-direction:column;gap:10px;flex-shrink:0;width:280px;overflow-y:auto}.ds-controls-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ds-controls-title{font-size:16px;font-weight:700;font-family:SF Mono,Fira Code,monospace;color:#333}.ds-controls-init{display:flex;align-items:center;gap:6px;margin-left:auto}.ds-controls-input{font-family:monospace;font-size:12px;padding:3px 6px;border:1px solid #ccc;border-radius:4px;width:110px}.ds-controls-btn{padding:3px 8px;font-size:11px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.ds-controls-btn:hover{background:#f0f0f0}.ds-controls-ops{display:flex;flex-direction:column;gap:4px}.ds-op{display:flex;align-items:center;gap:0;padding:4px 0}.ds-op-name{font:700 14px SF Mono,Fira Code,monospace;color:#333;white-space:nowrap}.ds-op-paren{font:14px SF Mono,Fira Code,monospace;color:#888;margin:0 1px}.ds-op-comma{font:14px SF Mono,Fira Code,monospace;color:#888;margin:0 4px 0 2px}.ds-op-arg-group{display:flex;flex-direction:column;align-items:center;gap:1px}.ds-op-arg-label{font-size:10px;color:#999;font-family:sans-serif;line-height:1}.ds-op-arg-input{width:36px;padding:2px 4px;font-size:13px;font-family:monospace;text-align:center;border:1px solid #ccc;border-radius:4px;background:#f8f8f8}.ds-op-arg-input:focus{border-color:#888;outline:none;background:#fff}.ds-op-arg-input::-webkit-inner-spin-button,.ds-op-arg-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.ds-op-arg-input{-moz-appearance:textfield}.ds-op-submit{display:flex;align-items:center;justify-content:center;width:26px;height:26px;margin-left:6px;border:1.5px solid #aaa;border-radius:6px;background:#fff;cursor:pointer;color:#555;flex-shrink:0}.ds-op-submit:hover{background:#f0f0f0;color:#333;border-color:#888}.ds-history{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-top:8px;background:#fff;border:1px solid #ddd;border-radius:8px;flex-shrink:0;min-height:36px}.ds-history-nav{display:flex;gap:4px;flex-shrink:0}.ds-history-btn{display:flex;flex-direction:column;align-items:center;padding:4px 8px 2px;font-size:14px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;flex-shrink:0;min-width:32px}.ds-history-btn .ds-btn-icon{font-size:14px;line-height:1}.ds-history-btn .ds-btn-shortcut{font-size:9px;color:#999;line-height:1;margin-top:2px}.ds-history-btn-sub{border-style:dashed}.ds-history-btn:hover:not(:disabled){background:#f0f0f0}.ds-history-btn:disabled{opacity:.3;cursor:default}.ds-history-ops{display:flex;flex-wrap:wrap;gap:6px;flex:1;align-items:flex-start}.ds-history-op-col{display:flex;flex-direction:column;gap:3px}.ds-history-entry{padding:4px 10px;border-radius:6px;background:#f0f0f0;font-size:14px;font-family:monospace;color:#999;cursor:pointer;white-space:nowrap}.ds-history-entry:hover{background:#e4e4e4}.ds-history-current{background:#dce8f3;color:#333;font-weight:600}.ds-history-future{opacity:.4}.ds-history-substeps{display:flex;gap:2px}.ds-substep-rect{flex:1;height:8px;border-radius:3px;background:#e8e8e8;cursor:pointer;transition:background .15s}.ds-substep-rect:hover{background:#d0d0d0}.ds-substep-visited{background:#c8d8e8}.ds-substep-active{background:#b0c8e0}.ds-substep-future{background:#f0f0f0}.ds-body .viz-container{justify-content:flex-start;padding:24px 40px}.ds-body .viz-cell-wrapper,.ds-body .viz-array-label,.ds-body .ds-field-wrapper{transition:none}.ds-viz-column{display:flex;flex-direction:column;align-items:flex-start}.ds-executing-banner{display:flex;align-items:center;gap:12px;padding:6px 12px;background:#fef9e7;border:1px solid #f0d060;border-radius:6px;font-size:13px;margin-top:12px;flex-shrink:0}.ds-executing-label{font-weight:600;font-family:monospace;color:#7a5f00}.ds-executing-step{color:#666;font-style:italic}.ds-field-wrapper{position:absolute;transition:transform .2s ease,opacity .2s}.ds-field-label{display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px}.ds-field-label-text{font:700 13px monospace;color:#333;writing-mode:vertical-lr;transform:rotate(180deg);white-space:nowrap}.ds-field-pointer .viz-cell-value{font-size:24px;line-height:1}.ds-tree-circle{display:flex;align-items:center;justify-content:center;border:1.5px solid #999;border-radius:50%;background:#fff;transition:transform .2s ease,opacity .2s}.ds-tree-circle-label{font:14px monospace;color:#222}.ds-vertical-label{display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;pointer-events:none}.ds-vertical-label-text{font:13px monospace;color:#333;writing-mode:vertical-lr;transform:rotate(180deg);white-space:nowrap}.ds-cell-with-hover{position:relative}.ds-cell-with-hover:hover{z-index:20}.ds-cell-hover-wrapper{position:absolute;left:0;bottom:100%;width:100%;display:flex;justify-content:center;align-items:flex-end;padding-bottom:4px;pointer-events:none;opacity:0;transition:opacity .12s ease;z-index:10}.ds-cell-with-hover:hover .ds-cell-hover-wrapper{opacity:1}.ds-cell-hover-label{font:13px monospace;color:#333;white-space:nowrap;background:#fffffff2;padding:4px 3px;border-radius:2px;box-shadow:0 0 0 1px #0000001f;writing-mode:vertical-lr;transform:rotate(180deg)}.ds-controls-disclaimer{margin-top:16px;padding-top:12px;border-top:1px solid #e5e5e5;font:italic 12px/1.5 system-ui,sans-serif;color:#888}.viz-container{background:#fff;border-radius:8px;border:1px solid #ddd;display:flex;align-items:flex-start;justify-content:safe center;padding:16px;flex:1;min-height:0;min-width:0;overflow:auto}.viz-scene{font-family:monospace}.viz-array-label{position:absolute;font:700 14px monospace;color:#333;white-space:nowrap;transition:transform .2s ease,opacity .2s}.viz-cell-wrapper{position:absolute;transition:transform .2s ease,opacity .2s}.viz-cell{position:relative;background:#fff;border-style:solid;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color .15s,background-color .15s}.viz-cell-value{font:700 18px monospace;color:#222;position:relative;z-index:1;-webkit-user-select:none;user-select:none}.viz-cell-index{font:11px monospace;color:#999;text-align:center;margin-top:2px;-webkit-user-select:none;user-select:none}.viz-cell-gauge{position:absolute;bottom:0;left:0;right:0;background:#3498db59;transition:height .2s}.viz-cell-dot{position:absolute;top:3px;right:3px;width:6px;height:6px;border-radius:50%;background:#6ab0de}.viz-variable-wrapper{position:absolute;transition:transform .2s ease,opacity .2s}.viz-variable-label{font:700 14px monospace;color:#333;white-space:nowrap}.viz-frame{position:absolute;border:1.5px solid #bbb;padding:10px;transition:transform .2s ease,opacity .2s}.viz-frame-label{font:700 13px monospace;color:#555;white-space:nowrap}.viz-frame-refs{font:11px monospace;color:#888;white-space:nowrap;margin-top:4px}.viz-tree-node{position:absolute;border-radius:50%;border-style:solid;background:#fff;display:flex;align-items:center;justify-content:center;z-index:1;transition:transform .2s ease,opacity .2s,border-color .15s}.viz-tree-node-pointers{position:absolute;top:100%;left:50%;transform:translate(-50%);display:flex;gap:4px;margin-top:2px;white-space:nowrap;font:700 11px monospace}.viz-pointer-arrow{position:absolute}.viz-tooltip{position:absolute;transform:translate(-50%,-100%);margin-top:-6px;padding:4px 10px;background:#333;color:#fff;font-size:12px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:10}
