.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}*{box-sizing:border-box;margin:0;padding:0}:root{--cow-black: #000000;--cow-dark: #1a1a1a;--cow-gray: #333333;--cow-medium: #666666;--cow-light: #999999;--cow-white: #ffffff;--cow-off-white: #f5f5f5;--primary-green: #4a7c59;--primary-green-light: #e8f0eb;--primary-red: #b85450;--primary-red-light: #faf0f0;--primary-blue: #4a6fa5;--primary-blue-light: #eef2f7;--primary-amber: #b8860b;--primary-amber-light: #fdf8e8;--accent: #8b5a2b;--accent-dark: #5d3a1a;--accent-light: #f5ebe0;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-card: #ffffff;--text-primary: #000000;--text-secondary: #333333;--text-muted: #666666;--border-color: #333333;--border-light: #cccccc;--success: #4a7c59;--warning: #b8860b;--danger: #b85450;--info: #4a6fa5}.wood-texture{background:repeating-linear-gradient(0deg,transparent 0px,transparent 3px,rgba(92,64,40,.3) 3px,rgba(92,64,40,.3) 4px,transparent 4px,transparent 8px,rgba(70,45,25,.2) 8px,rgba(70,45,25,.2) 9px,transparent 9px,transparent 15px,rgba(92,64,40,.25) 15px,rgba(92,64,40,.25) 16px,transparent 16px,transparent 22px,rgba(60,40,20,.15) 22px,rgba(60,40,20,.15) 23px,transparent 23px,transparent 28px),repeating-linear-gradient(0deg,transparent 0px,transparent 5px,rgba(0,0,0,.03) 5px,rgba(0,0,0,.03) 6px),linear-gradient(180deg,#6b4928,#7a5535,#6b4928);box-shadow:inset 0 2px 3px #ffffff26,inset 0 -2px 3px #0003,0 2px 4px #0000004d;border-bottom:3px solid #5a3d25;border-top:1px solid #c4a882}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg-primary);background-image:url(/cow-spots-pattern.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;color:var(--text-primary);line-height:1.5}svg{vertical-align:middle}h1 svg,h2 svg,h3 svg,h4 svg,button svg{margin-right:.4rem}.welcome-screen{min-height:100vh;background:#ffffffd9;padding:2rem}.mobile-warning-banner{display:none;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--primary-amber-light);border:1px solid var(--primary-amber);border-radius:8px;margin-bottom:1rem;color:var(--accent-dark);font-size:.85rem;text-align:center}.welcome-container{max-width:800px;margin:0 auto}.welcome-header{text-align:center;padding:3.5rem 3rem 3rem;background:#fff;border-radius:12px;margin-bottom:1.5rem;border:2px solid var(--cow-black);box-shadow:0 4px 12px #0000001a;position:relative}.farm-icon{margin-bottom:1rem;display:flex;justify-content:center;align-items:center}.welcome-header h1{font-size:2.5rem;color:var(--cow-black);margin-bottom:.5rem;font-weight:700;letter-spacing:-.01em;line-height:1.2}.welcome-header .subtitle{font-size:1.05rem;color:var(--text-muted);font-weight:400;margin:0}.info-section{background:#fffffffa;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:2px solid var(--cow-black);box-shadow:0 4px 12px #0000001a}.info-section h2{color:var(--cow-black);margin-bottom:1rem;font-size:1.3rem}.info-section p{color:var(--text-secondary);margin-bottom:.75rem}.benefit-list{margin-top:1rem}.benefit{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;color:var(--text-secondary)}.benefit-icon{color:var(--primary-green);font-weight:700}.table-types{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.table-type{padding:1rem;border-radius:8px;text-align:center}.table-type.base{background:var(--primary-red-light);border:2px solid var(--primary-red)}.table-type.changes{background:var(--primary-blue-light);border:2px solid var(--primary-blue)}.table-type.view{background:var(--primary-green-light);border:2px dashed var(--primary-green)}.table-type h3{font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}.table-type p{font-size:.85rem;margin-bottom:.5rem}.table-type code{font-size:.8rem;background:#0000001a;padding:.2rem .5rem;border-radius:4px}.scenario-tables{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:1rem 0}.scenario-table{background:var(--bg-secondary);padding:1rem;border-radius:8px;text-align:center}.scenario-table h4{color:var(--cow-black);margin-bottom:.5rem}.scenario-table p{font-size:.85rem;margin:0}.scenario-note{font-style:italic;color:var(--text-muted)}.start-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem 2rem;font-size:1.2rem;color:var(--cow-white);border:none;border-radius:8px;cursor:pointer;transition:filter .2s}.start-button:hover{filter:brightness(1.1)}.sandbox-init{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#ffffffd9}.init-card{background:#fffffffa;padding:3rem;border-radius:16px;text-align:center;border:2px solid var(--cow-black);box-shadow:0 4px 20px #00000026}.init-icon{font-size:4rem;margin-bottom:1rem}.init-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.init-card h2{color:var(--cow-black);margin-bottom:.5rem}.init-card p{color:var(--text-secondary);margin-bottom:1.5rem}.sandbox{height:auto;min-height:100vh;display:flex;flex-direction:column;overflow:visible;width:100%}.sandbox-header{color:var(--cow-white);padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.header-left{display:flex;align-items:center;gap:1rem}.back-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.85rem}.back-button:hover{background:#fff3}.sandbox-header h1{font-size:1.3rem;font-weight:600}.header-right{display:flex;align-items:center;gap:1rem}.session-info{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.session-label{opacity:.8}.session-info code{background:#ffffff26;padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.header-btn{padding:.4rem .8rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background .2s}.header-btn:hover:not(:disabled){background:#fff3}.header-btn.danger{border-color:var(--primary-red)}.header-btn.danger:hover:not(:disabled){background:var(--primary-red)}.header-divider{width:1px;height:24px;background:#ffffff4d;margin:0 .25rem}.header-btn-disabled{opacity:.5;cursor:not-allowed}.sandbox-main{flex:1;display:grid;grid-template-columns:1fr 380px;align-items:stretch;gap:1rem;padding:1rem;background:#f5f5f5f2;overflow:visible;max-height:none}.database-section,.agent-section{display:flex;flex-direction:column;overflow:visible;min-height:0}.database-viewer{background:#fffffffa;border-radius:8px;padding:1rem;border:2px solid var(--cow-black);display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.viewer-header{margin-bottom:1rem}.view-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.view-toggle button{padding:.5rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:all .2s}.view-toggle button:hover{background:var(--border-light)}.view-toggle button.active{color:var(--cow-white)}.view-toggle button.toggle-base.active{background:var(--primary-red);border-color:var(--primary-red)}.view-toggle button.toggle-changes.active{background:var(--primary-blue);border-color:var(--primary-blue)}.view-toggle button.toggle-view.active{background:var(--primary-green);border-color:var(--primary-green)}.view-toggle button.toggle-dependencies.active{background:var(--accent);border-color:var(--accent)}.view-info h3{font-size:1rem;color:var(--text-primary);margin-bottom:.25rem}.view-info p{font-size:.85rem;color:var(--text-muted)}.tables-container{display:flex;flex-direction:column;gap:1.5rem;flex:1 1 auto;min-height:0;overflow-y:auto}.table-section{padding:1rem;border-radius:8px;border:2px solid var(--border-light);background:var(--cow-white)}.table-section-base{background:var(--primary-red-light);border-color:var(--primary-red)}.table-section-changes{background:var(--primary-blue-light);border-color:var(--primary-blue)}.table-section-view{background:var(--primary-green-light);border-color:var(--primary-green)}.table-section h4{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1rem;color:var(--text-primary)}.table-section-base h4{color:var(--primary-red)}.table-section-changes h4{color:var(--primary-blue)}.table-section-view h4{color:var(--primary-green)}.table-name{font-family:monospace;font-size:.75rem;font-weight:400;color:var(--text-muted);background:#ffffffb3;padding:.15rem .4rem;border-radius:3px}.table-section-base .table-name{color:var(--primary-red)}.table-section-changes .table-name{color:var(--primary-blue)}.table-section-view .table-name{color:var(--primary-green)}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:.5rem .75rem;text-align:left;border:1px solid var(--border-light)}th{background:var(--bg-secondary);font-weight:600;color:var(--text-secondary);font-size:.8rem}td{background:var(--bg-card)}td.empty{text-align:center;color:var(--text-muted);font-style:italic;padding:1rem}.changes-table th{background:var(--primary-blue-light);border-bottom:2px solid var(--primary-blue)}.deleted-row td{background:var(--primary-red-light);text-decoration:line-through;color:var(--primary-red)}.id-cell{font-family:monospace;font-size:.75rem;color:var(--text-muted)}.time-cell{font-size:.75rem;color:var(--text-muted)}.low-stock{background:var(--primary-red-light)!important;color:var(--primary-red);font-weight:600}.status-pending{color:var(--primary-amber)}.status-in_progress{color:var(--primary-blue)}.status-done{color:var(--primary-green)}.agent-panel{display:flex;flex-direction:column;gap:1rem;flex:1 1 auto;min-height:0}.panel-section{background:#fffffffa;border-radius:8px;padding:1rem;border:2px solid var(--cow-black);flex:1 1 auto;min-height:0;overflow:auto}.panel-section h2{font-size:1rem;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.form-row{margin-bottom:.75rem}.form-row label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.form-row input,.form-row select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;background:var(--bg-card);color:var(--text-primary)}.form-row input:focus,.form-row select:focus{outline:none;border-color:var(--cow-black)}.form-row input:disabled{background:var(--bg-secondary);color:var(--text-muted)}.execute-btn{width:100%;padding:.75rem;background:var(--accent);color:var(--cow-white);border:none;border-radius:6px;font-size:.95rem;cursor:pointer;transition:background .2s;margin-top:.5rem}.execute-btn:hover:not(:disabled){background:var(--accent-dark)}.execute-btn:disabled{opacity:.6;cursor:not-allowed}.demo-banner{background:var(--cow-off-white);border-bottom:2px solid var(--cow-black);padding:.6rem 1.5rem}.demo-banner-content{display:flex;align-items:center}.demo-banner-idle{display:flex;align-items:center;gap:1.5rem;width:100%}.demo-banner-btn{display:flex;align-items:center;gap:.5rem;padding:.45rem 1rem;background:var(--accent);color:var(--cow-white);border:none;border-radius:5px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.demo-banner-btn:hover:not(:disabled){background:var(--accent-dark)}.demo-banner-btn:disabled{opacity:.6;cursor:not-allowed}.demo-banner-subtext{font-size:.8rem;color:var(--cow-medium);border-left:1px solid var(--cow-light);padding-left:1.5rem}.demo-banner-playing{display:flex;align-items:center;gap:1rem;width:100%}.demo-narration-banner{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--cow-white);border-radius:6px;font-size:.8rem;color:var(--cow-dark);flex:1}.demo-narration-banner .spinning{flex-shrink:0;color:var(--cow-black);animation:spin 1s linear infinite}.demo-progress-banner{width:100px;height:4px;background:var(--cow-light);border-radius:2px;overflow:hidden;flex-shrink:0}.demo-progress-bar-banner{height:100%;background:var(--accent);transition:width .3s ease}.demo-step-indicator{font-size:.75rem;color:var(--cow-medium);font-weight:500;white-space:nowrap}.demo-banner-hint{margin-top:.4rem;font-size:.75rem;color:var(--cow-medium);line-height:1.3;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.demo-banner-hint strong{color:var(--cow-dark);font-weight:600}.demo-tab-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:4px;font-weight:500;color:var(--cow-white)}.demo-tab-badge.tab-base{background:var(--primary-red)}.demo-tab-badge.tab-changes{background:var(--primary-blue)}.demo-tab-badge.tab-view{background:var(--primary-green)}.demo-tab-badge.tab-dependencies{background:var(--accent)}.demo-banner-active .demo-banner-hint{color:var(--cow-dark)}.demo-banner-active .demo-banner-hint strong{color:var(--cow-black)}.demo-tab-badge-complete{background:#0000001a;color:var(--cow-black)}.demo-banner-active{background:var(--cow-white);border-bottom-color:var(--cow-black)}.demo-banner-active .demo-narration-banner{background:var(--cow-off-white);color:var(--cow-dark)}.demo-banner-active .demo-narration-banner .spinning{color:var(--cow-black)}.demo-banner-active .demo-progress-bar-banner{background:var(--accent)}.demo-banner-active .demo-step-indicator{color:var(--cow-dark)}.demo-banner-complete{background:var(--cow-off-white);border-bottom-color:var(--cow-black);padding:.75rem 1.5rem}.demo-complete-header{display:flex;align-items:center;gap:.5rem;color:var(--cow-black)}.demo-complete-header strong{font-size:.95rem}.demo-complete-header span{color:var(--cow-gray);font-size:.85rem}.demo-commit-guide{margin-top:.6rem;padding-top:.6rem;border-top:1px solid var(--cow-light)}.demo-commit-steps{display:flex;flex-direction:column;gap:.4rem}.demo-commit-step{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;color:var(--cow-dark)}.demo-commit-step .step-number{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--accent);color:var(--cow-white);border-radius:50%;font-size:.7rem;font-weight:600;flex-shrink:0}.demo-commit-step strong{color:var(--cow-black)}.demo-commit-note{margin-top:.5rem;font-size:.72rem;color:var(--cow-medium);font-style:italic}.dependencies-link{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:var(--cow-white);border:2px solid var(--cow-black);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;text-align:left;margin-top:auto}.dependencies-link-text{display:flex;flex-direction:column;gap:.15rem;flex:1}.dependencies-link-text strong{font-size:.9rem;color:var(--text-primary)}.dependencies-link-text span{font-size:.75rem;color:var(--text-muted)}.dependencies-link:hover{background:var(--cow-off-white);border-color:var(--cow-black)}.dependencies-link:hover strong{color:var(--cow-black)}.dependencies-link:hover svg{color:var(--cow-black)}.action-buttons{display:flex;gap:.5rem;margin-top:.75rem}.commit-btn,.discard-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1rem;border:none;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.commit-btn{background:var(--primary-green);color:var(--cow-white)}.commit-btn:hover:not(:disabled){background:#3d6a4a;box-shadow:0 4px 8px #4a7c594d;transform:translateY(-1px)}.commit-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #4a7c5933}.discard-btn{background:var(--cow-white);color:var(--primary-red);border:2px solid var(--primary-red)}.discard-btn:hover:not(:disabled){background:var(--primary-red-light);box-shadow:0 4px 8px #b8545033;transform:translateY(-1px)}.discard-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #b8545026}.commit-btn:disabled,.discard-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;background:var(--bg-secondary);color:var(--text-muted)}.dependency-graph-wrapper{display:flex;flex-direction:column;gap:1rem;flex:1;min-height:0;height:100%;max-height:70vh}.dependency-graph-container{width:100%;flex:1;min-height:0;background:#fffffffa;border-radius:8px;border:2px solid var(--cow-black);display:flex;flex-direction:column;overflow:hidden}.dependency-graph-actions{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));background:#fffffffa;border-radius:8px;border:2px solid var(--cow-black)}.dependency-graph-actions .selection-info{font-size:.9rem;color:var(--text-secondary)}.dependency-graph-actions .action-buttons{display:flex;gap:.5rem}.dependency-graph-container .react-flow{border-radius:8px;flex:1 1 auto;min-height:0;height:100%}.dependency-graph-container .react-flow__controls{box-shadow:0 2px 6px #0000001a;border-radius:6px;border:1px solid var(--border-light)}.dependency-graph-container .react-flow__controls-button{background:var(--bg-card);border-bottom:1px solid var(--border-light);width:28px;height:28px}.dependency-graph-container .react-flow__controls-button:hover{background:var(--bg-secondary)}.dependency-graph-container .react-flow__controls-button svg{fill:var(--text-secondary)}.operation-node{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.dependency-graph-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:0;height:100%;background:#fffffffa;border-radius:8px;border:2px solid var(--cow-black);color:var(--text-muted)}.dependency-graph-empty p{margin-top:1rem;font-size:1.1rem;color:var(--text-secondary)}.dependency-graph-empty span{font-size:.85rem}.dependencies-view{display:grid;grid-template-columns:320px 1fr;gap:1rem;flex:1;min-height:0;height:100%}.dependency-graph-section,.actions-log-section{min-width:0;min-height:0;display:flex;flex-direction:column;height:100%}.actions-log{background:#fffffffa;border-radius:8px;border:2px solid var(--cow-black);display:flex;flex-direction:column;flex:1 1 auto;min-height:0;max-height:70vh;overflow:hidden}.actions-log-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-light);background:var(--bg-secondary);border-radius:8px 8px 0 0}.actions-log-header h4{font-size:.95rem;color:var(--text-primary);margin:0}.actions-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-card);padding:.2rem .5rem;border-radius:10px}.actions-log-list{flex:1;overflow-y:auto;padding:.5rem}.action-log-entry{display:flex;gap:.5rem;margin-bottom:.5rem}.action-log-entry:last-child{margin-bottom:0}.action-log-index{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--bg-secondary);color:var(--text-muted);border-radius:50%;font-size:.7rem;font-weight:600;flex-shrink:0;margin-top:.5rem}.action-log-item{flex:1;padding:.6rem .75rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-light);transition:all .15s ease}.action-log-item.committed{opacity:.7;background:var(--bg-card)}.action-log-item.discarded{opacity:.7;background:var(--primary-red-light);border-color:var(--primary-red)}.action-log-item.discarded .action-log-description{text-decoration:line-through}.action-log-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.4rem;background:transparent;padding:0;border:none;border-radius:0}.action-badge-log{padding:.1rem .4rem;border-radius:3px;font-size:.6rem;font-weight:600;text-transform:uppercase}.table-info{display:flex;align-items:center;gap:.25rem;font-size:.72rem;color:var(--text-muted)}.committed-badge{margin-left:auto;font-size:.6rem;background:var(--primary-green-light);color:var(--primary-green);padding:.1rem .4rem;border-radius:3px;font-weight:500}.discarded-badge{margin-left:auto;font-size:.6rem;background:var(--primary-red-light);color:var(--primary-red);padding:.1rem .4rem;border-radius:3px;font-weight:500}.action-log-description{font-size:.8rem;color:var(--text-primary);line-height:1.3;margin-bottom:.4rem}.action-log-description.muted{color:var(--text-muted)}.action-log-fields{background:#00000008;border-radius:4px;padding:.4rem .5rem;margin-bottom:.4rem;font-family:monospace;font-size:.68rem}.action-log-field{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.25rem}.action-log-field:last-child{margin-bottom:0}.field-name{font-weight:600}.field-values{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.old-value{text-decoration:line-through;opacity:.5}.arrow{opacity:.6}.new-value{font-weight:500}.more-fields{color:var(--text-muted);font-size:.65rem;margin-top:.25rem}.action-log-time{font-size:.68rem;color:var(--text-muted)}.actions-log-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:#fffffffa;border-radius:8px;border:2px solid var(--cow-black);color:var(--text-muted);text-align:center}.actions-log-empty p{margin-top:.75rem;font-size:.95rem;color:var(--text-secondary)}.actions-log-empty span{font-size:.8rem}@media(max-width:900px){.sandbox-main{grid-template-columns:1fr;overflow:auto}.scenario-tables,.table-types,.dependencies-view{grid-template-columns:1fr}.actions-log,.actions-log-empty{min-height:350px}}@media(max-width:600px){html,body{overflow-x:hidden;overflow-y:auto;width:100%;max-width:100vw}.welcome-screen{padding:1rem;min-height:auto;height:auto}.mobile-warning-banner{display:flex}.welcome-header{padding:2rem 1.5rem}.welcome-header h1{font-size:1.75rem}.info-section{padding:1rem}.info-section h2{font-size:1.1rem}.start-button{padding:.875rem 1.5rem;font-size:1.1rem;min-height:48px}.sandbox-header{padding:.5rem 1rem;flex-direction:column;align-items:stretch;gap:.75rem}.header-left{justify-content:space-between;width:100%}.header-left h1{font-size:1.1rem}.header-right{flex-wrap:wrap;justify-content:flex-start;gap:.5rem}.session-info{width:100%;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.2);margin-bottom:.25rem}.header-btn,.back-button{padding:.5rem .75rem;min-height:44px;font-size:.8rem}.header-divider{display:none}.demo-banner{padding:.75rem 1rem}.demo-banner-idle{flex-direction:column;align-items:flex-start;gap:.75rem}.demo-banner-btn{width:100%;justify-content:center;padding:.6rem 1rem;min-height:44px}.demo-banner-subtext{border-left:none;padding-left:0;font-size:.75rem;text-align:center;width:100%}.demo-banner-playing{flex-direction:column;align-items:stretch;gap:.75rem}.demo-narration-banner,.demo-progress-banner{width:100%}.demo-step-indicator{text-align:center}.demo-banner-hint{flex-direction:column;align-items:flex-start;gap:.5rem}.demo-banner-complete{padding:1rem}.demo-complete-header{flex-wrap:wrap;gap:.5rem}.demo-complete-header span{width:100%}.demo-commit-step{font-size:.75rem}.sandbox{height:auto;min-height:100vh;overflow:visible;width:100%}.sandbox-header{width:100%;flex-wrap:wrap}.sandbox-main{display:flex;flex-direction:column;padding:.75rem;gap:.75rem;overflow:auto;max-height:none;width:100%;height:auto}.demo-banner{width:100%}.database-viewer{padding:.75rem;overflow:visible;flex:none;height:auto;width:100%;box-sizing:border-box}.viewer-header{flex-shrink:0}.view-toggle{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;width:100%}.view-toggle button{padding:.5rem .4rem;min-height:44px;font-size:.65rem;white-space:normal;line-height:1.2}.tables-container,.database-section{overflow:visible;flex:none;height:auto;width:100%}.agent-section{width:100%}.table-wrapper{display:block;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;max-width:100%}.table-section{overflow:hidden;padding:.5rem;max-width:100%}table{font-size:.7rem;width:max-content;min-width:100%}th,td{padding:.3rem .4rem;white-space:nowrap}th{font-size:.65rem}.id-cell{font-size:.6rem}.changes-table{font-size:.65rem}.changes-table th,.changes-table td{padding:.25rem .35rem}.changes-table th{font-size:.6rem}.panel-section{padding:.75rem}.form-row input,.form-row select{min-height:44px;font-size:1rem}.execute-btn{min-height:48px;font-size:1rem}.dependencies-link{padding:.875rem 1rem;min-height:48px}.dependency-graph-container{min-height:0}.dependency-graph-actions{flex-direction:column;gap:.75rem;padding:.75rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.dependency-graph-actions .selection-info{text-align:center;width:100%}.dependency-graph-actions .action-buttons{width:100%;margin-top:0}.commit-btn,.discard-btn{min-height:48px;font-size:.9rem}.actions-log-header{padding:.6rem .75rem}.action-log-item{padding:.75rem}.dependency-graph-container .react-flow__controls{bottom:10px;left:10px}.dependency-graph-container .react-flow__controls-button{width:36px;height:36px}.dependency-graph-container .react-flow__controls-button svg{max-width:14px;max-height:14px}.operation-node{min-width:200px!important;max-width:280px!important}}@media(max-width:400px){.welcome-header h1{font-size:1.5rem}.header-left h1{font-size:1rem}.view-toggle button{min-width:100%;padding:.5rem}table{font-size:.6rem}th,td{padding:.2rem .3rem}th{font-size:.55rem}.id-cell{font-size:.5rem}.table-section h4{font-size:.8rem}.table-name{font-size:.6rem}.changes-table{font-size:.55rem}.changes-table th,.changes-table td{padding:.2rem .25rem}.changes-table th{font-size:.5rem}.demo-commit-step{flex-direction:column;gap:.25rem}.demo-commit-step .step-number{align-self:flex-start}}
