@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT,WONK@0,9..144,300..900,0..100,0..1;1,9..144,300..900,0..100,0..1&family=JetBrains+Mono:wght@400;500;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.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 .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.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:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;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:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.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.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@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}.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-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.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:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.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{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.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:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform: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:#3367d9;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%}:root{--paper: #f3ebdc;--paper-2: #ece2cc;--paper-3: #e2d6ba;--card: #fbf6ea;--ink: #141821;--ink-2: #2a2f3a;--ink-3: #4a4f5b;--ink-muted: #6d6a5f;--ink-faint: #8a8574;--prussian: #0b2a4a;--transmit: #d8271a;--transmit-2: #a81810;--lime: #b8d64a;--amber: #e8a72a;--violet: #6a4aa8;--ok-bg: #dfe8c8;--ok-ink: #3c5b10;--bad-bg: #f4d2cf;--bad-ink: #8a1710;--idle-bg: #e2d6ba;--idle-ink: #6d6a5f;--font-display: "Fraunces", "Times New Roman", Georgia, serif;--font-sans: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--fvs-display: "opsz" 144, "SOFT" 0, "WONK" 1;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 24px;--sp-6: 32px;--sp-7: 48px;--sp-8: 72px;--shadow-card: 4px 4px 0 var(--ink);--shadow-lift: 6px 6px 0 var(--transmit)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);color:var(--ink);background:var(--paper);font-size:14px}.app{display:flex;height:100vh}.content-area{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--paper)}.sidebar{width:240px;background:var(--paper-2);border-right:2px solid var(--ink);padding:14px;overflow-y:auto;flex-shrink:0}.sidebar-title{border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:12px}.sidebar-title strong{display:block;font-family:var(--font-display);font-weight:900;font-stretch:75%;font-size:34px;letter-spacing:-.04em;color:var(--ink);line-height:.9;font-variation-settings:var(--fvs-display);text-transform:lowercase}.sidebar-title strong:after{content:"·";color:var(--transmit)}.sidebar-title p{margin:4px 0 0;font-family:var(--font-mono);font-size:9px;color:var(--ink-muted);letter-spacing:.18em;text-transform:uppercase;line-height:1.5}.sidebar h2{margin:16px 0 6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--transmit);display:flex;align-items:center;gap:6px;font-weight:500}.sidebar h2:before{content:"";height:2px;width:18px;background:var(--ink)}.sidebar ul{list-style:none;padding:0;margin:0}.sidebar li{margin:0}.sidebar-dev{margin-top:18px;border-top:1px dashed var(--ink-faint);padding-top:6px}.sidebar-dev>summary{list-style:none;cursor:pointer;padding:8px 0 4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-muted);-webkit-user-select:none;user-select:none}.sidebar-dev>summary::-webkit-details-marker{display:none}.sidebar-dev>summary:before{content:"▸ ";display:inline-block;transition:transform .12s;margin-right:4px}.sidebar-dev[open]>summary:before{transform:rotate(90deg)}.sidebar-dev>summary:hover{color:var(--ink)}.sidebar-dev h2{margin-top:12px}.sidebar-link{display:block;padding:5px 8px;font-size:14px;color:var(--ink);text-decoration:none;font-weight:500;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-family:inherit;border-radius:0}.sidebar-link:hover{background:var(--paper-3)}.sidebar-link.active{background:var(--ink);color:var(--paper)}.sidebar-action{display:block;margin-top:4px;padding:5px 8px;border:1.5px dashed var(--ink);background:transparent;color:var(--ink);font-family:var(--font-sans);font-size:12px;font-weight:500;letter-spacing:0;text-transform:none}.sidebar-action:hover{background:var(--ink);color:var(--paper);border-style:solid}.github-status{margin-bottom:16px}.login-btn{width:100%;padding:8px 12px;border:2px solid var(--ink);background:var(--ink);color:var(--paper);cursor:pointer;font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:14px;letter-spacing:.08em;text-transform:uppercase;box-shadow:3px 3px 0 var(--transmit)}.login-btn:hover{transform:translate(1px,1px);box-shadow:2px 2px 0 var(--transmit)}.user-chip{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--card);border:1.5px solid var(--ink);font-size:13px}.user-chip img{width:20px;height:20px}.user-chip span{flex:1;font-weight:500;font-family:var(--font-mono);font-size:11px}.user-chip button{border:none;background:transparent;cursor:pointer;font-size:16px;color:var(--ink-muted);line-height:1}.user-chip button:hover{color:var(--transmit)}.doc-content{padding:32px 44px;overflow-y:auto;max-width:900px}.doc-content h1{font-family:var(--font-display);font-weight:800;font-size:44px;font-stretch:85%;letter-spacing:-.02em;line-height:1;margin:0 0 8px;font-variation-settings:"opsz" 144;color:var(--ink)}.doc-content h2{font-family:var(--font-sans);font-weight:600;font-size:20px;margin:24px 0 8px;display:flex;align-items:center;gap:10px;color:var(--ink)}.doc-content h2:before{content:"";width:24px;height:2px;background:var(--transmit)}.doc-content p{font-size:15px;line-height:1.5;color:var(--ink-2);max-width:72ch}.doc-content ul{padding-left:0;list-style:none}.doc-content ul li{padding:6px 0 6px 22px;border-bottom:1px dotted var(--ink-faint);font-size:14px;line-height:1.5;color:var(--ink-2);position:relative}.doc-content ul li:before{content:"▸";color:var(--transmit);font-family:var(--font-mono);font-size:11px;position:absolute;left:4px;top:8px}.doc-content ul li strong{color:var(--ink);font-weight:700}.doc-content ul li a{color:var(--transmit)}.doc-content pre{background:var(--paper-3);padding:12px;overflow-x:auto;border:1.5px solid var(--ink);font-family:var(--font-mono);font-size:12px;color:var(--ink)}.doc-content code{font-family:var(--font-mono);font-size:12px;background:var(--paper-3);padding:1px 5px;color:var(--ink)}.doc-content pre code{background:none;padding:0}.doc-content table{border-collapse:collapse;border:2px solid var(--ink);margin:16px 0;font-size:13px;background:var(--card);box-shadow:var(--shadow-card)}.doc-content thead{background:var(--ink);color:var(--paper)}.doc-content th{text-align:left;padding:8px 12px;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;border-right:1px solid var(--paper)}.doc-content th:last-child{border-right:none}.doc-content td{padding:8px 12px;border-top:1px dashed var(--ink);border-right:1px dashed var(--ink);color:var(--ink-2);vertical-align:top}.doc-content td:last-child{border-right:none}.doc-content tbody tr:first-child td{border-top:2px solid var(--ink)}.board{display:flex;flex-direction:column;height:100%;background:var(--paper)}.board-header{padding:14px 22px;background:var(--paper);border-bottom:2px solid var(--ink);display:flex;align-items:center;gap:14px}.board-header h1{margin:0;font-family:var(--font-display);font-weight:800;font-size:26px;font-stretch:85%;letter-spacing:-.015em;color:var(--ink)}.columns{display:flex;gap:14px;padding:16px;overflow-x:auto;flex:1;align-items:flex-start;background:var(--paper)}.column{background:var(--paper-2);border:2px solid var(--ink);width:290px;flex-shrink:0;display:flex;flex-direction:column;max-height:100%;box-shadow:var(--shadow-card)}.column-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--ink);color:var(--paper)}.column-header h2{margin:0;font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.2em;color:var(--paper)}.column-header .count{background:var(--transmit);color:var(--paper);font-family:var(--font-mono);font-size:10px;padding:1px 6px;margin-left:auto;letter-spacing:.1em}.column-body{padding:8px;min-height:40px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1}.column-body .empty{color:var(--ink-faint);font-family:var(--font-mono);font-size:10px;padding:10px;text-align:center;letter-spacing:.2em;text-transform:uppercase}.add-btn{margin:0 8px 8px;padding:6px 10px;border:1.5px dashed var(--ink);background:transparent;color:var(--ink);text-align:center;cursor:pointer;font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase}.add-btn:hover{background:var(--paper-3)}.card{background:var(--card);border:1.5px solid var(--ink);padding:10px 12px;box-shadow:3px 3px 0 var(--ink);cursor:grab;-webkit-user-select:none;user-select:none}.card:hover{box-shadow:4px 4px 0 var(--transmit)}.card.overlay{box-shadow:6px 6px 0 var(--transmit);transform:rotate(1.5deg)}.card-title{font-family:var(--font-display);font-weight:700;font-stretch:88%;font-size:16px;letter-spacing:-.01em;line-height:1.15;color:var(--ink)}.card-body{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);margin-top:6px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1418218c;display:flex;align-items:center;justify-content:center;z-index:10}.modal{background:var(--card);border:2px solid var(--ink);width:560px;max-width:90vw;padding:20px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-lift)}.modal-title{font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:22px;letter-spacing:-.015em;border:none;border-bottom:2px solid var(--ink);padding:6px 0;outline:none;background:transparent;color:var(--ink)}.modal select{width:fit-content;padding:6px 10px;border:2px solid var(--ink);background:var(--paper);font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;border-radius:0;color:var(--ink)}.modal-body{border:2px solid var(--ink);padding:10px;font-family:var(--font-mono);font-size:12px;resize:vertical;outline:none;background:var(--paper);color:var(--ink)}.modal-body:focus{background:#fff;box-shadow:4px 4px 0 var(--transmit)}.modal-actions{display:flex;gap:8px;align-items:center}.modal-actions button{padding:8px 14px;border:2px solid var(--ink);background:var(--paper);cursor:pointer;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink)}.modal-actions button:hover{background:var(--paper-3)}.modal-actions .primary{background:var(--transmit);color:var(--paper);font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:14px;letter-spacing:.08em;box-shadow:3px 3px 0 var(--ink)}.modal-actions .primary:hover{background:var(--transmit-2);transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}.modal-actions .danger{color:var(--transmit);border-color:var(--transmit)}.modal-actions .danger:hover{background:var(--bad-bg)}.chat-fab{position:fixed;bottom:24px;right:24px;width:68px;height:68px;border:2px solid var(--ink);background:var(--transmit);color:var(--paper);font-family:var(--font-display);font-weight:900;font-stretch:75%;font-size:28px;cursor:pointer;box-shadow:4px 4px 0 var(--ink);z-index:20;letter-spacing:-.04em}.chat-fab:hover{transform:translate(1px,1px);box-shadow:3px 3px 0 var(--ink)}.chat-panel{position:fixed;bottom:108px;right:24px;width:400px;height:560px;max-height:calc(100vh - 140px);background:var(--card);border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink);display:flex;flex-direction:column;z-index:20;overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:2px solid var(--ink);background:var(--ink);color:var(--paper)}.chat-header strong{font-family:var(--font-display);font-weight:800;font-stretch:80%;font-size:18px;color:var(--paper)}.chat-status{color:var(--lime);font-family:var(--font-mono);font-size:10px;margin-left:8px;letter-spacing:.14em;text-transform:uppercase}.chat-header button{border:1px solid var(--paper);background:transparent;cursor:pointer;color:var(--paper);width:24px;height:24px;font-family:var(--font-mono)}.chat-header button:hover{background:var(--transmit);border-color:var(--transmit)}.chat-body{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;background:var(--paper)}.chat-empty{color:var(--ink-muted);font-family:var(--font-mono);font-size:10px;text-align:center;padding:24px;letter-spacing:.2em;text-transform:uppercase}.msg{display:flex;flex-direction:column;gap:4px}.msg.user{align-items:flex-end}.msg-bubble{max-width:85%;padding:8px 12px;font-size:13px;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;border:1.5px solid var(--ink);box-shadow:3px 3px 0 var(--ink)}.msg.user .msg-bubble{background:var(--transmit);color:var(--paper)}.msg.assistant .msg-bubble{background:var(--card);color:var(--ink)}.msg-tool{font-family:var(--font-mono);font-size:10px;background:var(--amber);border:1.5px solid var(--ink);padding:3px 8px;display:flex;gap:6px;align-items:center;box-shadow:3px 3px 0 var(--ink);letter-spacing:.04em}.tool-name{font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.1em}.tool-args{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-input{display:flex;gap:8px;padding:10px;border-top:2px solid var(--ink);background:var(--paper-2)}.chat-input textarea{flex:1;border:2px solid var(--ink);padding:6px 8px;font-family:var(--font-sans);font-size:13px;resize:none;outline:none;background:var(--paper);color:var(--ink);border-radius:0}.chat-input textarea:focus{background:#fff;box-shadow:3px 3px 0 var(--transmit)}.chat-input button{padding:0 14px;border:2px solid var(--ink);background:var(--transmit);color:var(--paper);cursor:pointer;font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:14px;letter-spacing:.08em;text-transform:uppercase;box-shadow:3px 3px 0 var(--ink)}.chat-input button:hover:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}.chat-input button:disabled{background:var(--paper-3);color:var(--ink-faint);box-shadow:none;cursor:default}.diagram{display:flex;flex-direction:column;height:100%;background:var(--paper)}.diagram-toolbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--paper);border-bottom:2px solid var(--ink)}.diagram-title{font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:22px;letter-spacing:-.015em;border:none;outline:none;flex:1;padding:4px 6px;background:transparent;color:var(--ink)}.diagram-title:focus{background:var(--paper-3)}.diagram-toolbar button{padding:6px 12px;border:2px solid var(--ink);background:var(--paper);cursor:pointer;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}.diagram-toolbar button:hover{background:var(--paper-3)}.save-state{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);min-width:80px;text-align:right}.save-state.saving{color:var(--amber)}.save-state.dirty{color:var(--ink-muted)}.save-state.error{color:var(--transmit)}.save-state.saved{color:var(--ok-ink)}.diagram-canvas{flex:1}.agent-sandbox{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto 1fr;gap:14px;padding:16px;height:100%;overflow:hidden;background:var(--paper);position:relative}.agent-sandbox-info{grid-column:1 / -1;display:flex;align-items:stretch;border:2px solid var(--ink);background:var(--card)}.agent-sandbox-info-cell{padding:6px 14px;border-right:1.5px solid var(--ink);display:flex;flex-direction:column;gap:3px;flex:1}.agent-sandbox-info-cell:last-child{border-right:none}.agent-sandbox-info-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--transmit);font-weight:500}.agent-sandbox-info-val{font-family:var(--font-mono);font-size:12px;color:var(--ink);display:flex;gap:8px;align-items:center;font-weight:500}.agent-sandbox-info-cell strong{font-family:var(--font-display);font-stretch:80%;font-weight:800;font-size:18px;letter-spacing:-.01em}.agent-sandbox-info code{font-family:var(--font-mono);font-size:11px;color:var(--ink-2);background:transparent;padding:0}.agent-sandbox-info-copy{border:1px solid var(--ink);background:var(--paper);font-family:var(--font-mono);font-size:10px;padding:1px 6px;cursor:pointer;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}.agent-sandbox-info-copy:hover{background:var(--paper-3)}.agent-sandbox-pane{display:flex;flex-direction:column;gap:8px;min-height:0;overflow:auto;padding:14px;background:var(--card);border:2px solid var(--ink);box-shadow:var(--shadow-card)}.agent-sandbox-pane h2{margin:0 0 4px;font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:22px;letter-spacing:-.015em;color:var(--ink);display:flex;align-items:center;gap:10px}.agent-sandbox-pane h3{margin:14px 0 6px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;color:var(--transmit);letter-spacing:.2em;font-weight:500;display:flex;align-items:center;gap:6px}.agent-sandbox-pane h3:before{content:"";height:2px;width:18px;background:var(--ink)}.agent-sandbox-pane p{margin:0;font-size:13px;color:var(--ink-3)}.agent-sandbox-form{display:flex;flex-direction:column;gap:10px}.agent-sandbox-form label{display:flex;flex-direction:column;gap:4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--transmit);font-weight:500}.agent-sandbox-form input,.agent-sandbox-form textarea,.agent-sandbox-form select{padding:8px 10px;border:2px solid var(--ink);background:var(--paper);font-family:var(--font-sans);font-size:13px;color:var(--ink);text-transform:none;letter-spacing:0;outline:none;border-radius:0}.agent-sandbox-form select{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em}.agent-sandbox-form input:focus,.agent-sandbox-form textarea:focus{background:#fff;box-shadow:4px 4px 0 var(--transmit)}.agent-sandbox-form button{padding:9px 14px;border:2px solid var(--ink);background:var(--transmit);color:var(--paper);font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:16px;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;box-shadow:3px 3px 0 var(--ink)}.agent-sandbox-form button:hover:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px 0 var(--ink)}.agent-sandbox-form button:disabled{opacity:.4;cursor:not-allowed;background:var(--paper-3);color:var(--ink-muted);box-shadow:none}.agent-sandbox-list{list-style:none;padding:0;margin:0;border:1.5px solid var(--ink);background:var(--paper)}.agent-sandbox-list li{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px dashed var(--ink);font-size:13px;color:var(--ink)}.agent-sandbox-list li:last-child{border-bottom:none}.agent-sandbox-list li strong{font-family:var(--font-display);font-weight:800;font-stretch:80%;font-size:17px;letter-spacing:-.01em;color:var(--ink)}.agent-sandbox-list code{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);background:transparent;padding:0}.agent-sandbox-list .muted{font-family:var(--font-mono);font-size:9px;color:var(--ink-muted);letter-spacing:.14em;text-transform:uppercase}.agent-sandbox-list button{margin-left:auto;padding:2px 6px;font-family:var(--font-mono);font-size:10px;border:1px solid currentColor;background:transparent;color:inherit;cursor:pointer;letter-spacing:.1em;text-transform:uppercase}.agent-sandbox-agent-row{cursor:pointer}.agent-sandbox-agent-row:hover{background:var(--paper-3)}.agent-sandbox-agent-row.selected{background:var(--ink);color:var(--paper)}.agent-sandbox-agent-row.selected strong,.agent-sandbox-agent-row.selected code,.agent-sandbox-agent-row.selected .muted{color:var(--lime)}.agent-sandbox-agent-row.stopped{opacity:.55}.agent-sandbox-agent-row.stopped:hover{opacity:.8}.agent-sandbox-messages{list-style:none;padding:0;margin:0;font-family:var(--font-mono);font-size:11px;border-top:1px dashed var(--ink)}.agent-sandbox-messages li{padding:4px 6px;border-bottom:1px dashed var(--ink);line-height:1.4;color:var(--ink)}.agent-sandbox-messages li:last-child{border-bottom:none}.agent-sandbox-messages li strong{color:var(--transmit);font-weight:700}.agent-sandbox-error{color:var(--bad-ink);background:var(--bad-bg);border:1.5px solid var(--transmit);font-family:var(--font-mono);font-size:11px;padding:6px 8px;margin:0}.status{font-family:var(--font-mono);font-size:9px;padding:2px 6px;text-transform:uppercase;letter-spacing:.14em;border:1px solid var(--ink);font-weight:500}.status-idle,.status-connecting{background:var(--paper-3);color:var(--ink-muted)}.status-connected{background:var(--lime);color:var(--ink)}.status-disconnected,.status-error{background:var(--transmit);color:var(--paper);border-color:var(--transmit)}.muted{color:var(--ink-muted)}.agent-model-badge{font-family:var(--font-mono);font-size:10px;padding:1px 6px;background:var(--violet);color:var(--paper);letter-spacing:.04em;white-space:nowrap;border:1px solid var(--ink)}.agent-drawer{position:absolute;top:0;left:0;bottom:0;padding-left:calc(280px + var(--sp-3) * 2);box-sizing:content-box;display:flex;flex-direction:row;z-index:5;pointer-events:none;animation:agent-drawer-slide-in .22s ease-out}.agent-drawer>*{pointer-events:auto}@keyframes agent-drawer-slide-in{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}.agent-drawer.closing{animation:agent-drawer-slide-out .18s ease-in forwards}@keyframes agent-drawer-slide-out{0%{clip-path:inset(0 0 0 0)}to{clip-path:inset(0 100% 0 0)}}.agent-drawer-dimmer.closing{animation:agent-drawer-dim-out .18s ease-in forwards}@keyframes agent-drawer-dim-out{0%{opacity:1}to{opacity:0}}.agent-drawer-main{width:420px;max-width:calc(95vw - 44px);background:var(--paper);border-right:2px solid var(--ink);box-shadow:6px 0 0 var(--ink);display:flex;flex-direction:column}.agent-drawer-head{padding:10px 14px;border-bottom:2px solid var(--ink);display:flex;align-items:center;gap:12px;background:var(--ink);color:var(--paper)}.agent-drawer-avatar{flex:0 0 36px;width:36px;height:36px;border:1.5px solid var(--paper);background:var(--paper-3);overflow:hidden;display:flex;align-items:center;justify-content:center}.agent-drawer-avatar img{width:100%;height:100%;object-fit:cover;display:block}.agent-drawer-avatar span{font-family:var(--font-display);font-stretch:75%;font-weight:900;font-size:20px;color:var(--ink)}.agent-drawer-title{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.agent-drawer-title strong{font-size:14px}.agent-drawer-title code{font-family:var(--font-mono);font-size:10px;color:var(--paper-3);overflow:hidden;text-overflow:ellipsis}.agent-drawer-close{background:transparent;border:1.5px solid var(--paper);color:var(--paper);width:24px;height:24px;font-size:18px;line-height:1;cursor:pointer;padding:0}.agent-drawer-close:hover{background:var(--transmit);border-color:var(--transmit)}.agent-drawer-sidetabs{order:2;display:flex;flex-direction:column;align-items:flex-start;padding-top:0;margin-left:-2px}.agent-drawer-sidetab{writing-mode:vertical-rl;display:inline-flex;align-items:center;gap:10px;padding:18px 6px 18px 8px;background:var(--paper-2);color:var(--ink-muted);border:2px solid var(--ink);border-left:none;border-radius:0 8px 8px 0;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;margin-top:-2px;transition:background .12s ease,color .12s ease,padding-right .12s ease}.agent-drawer-sidetab:first-child{margin-top:0}.agent-drawer-sidetab svg{writing-mode:horizontal-tb;flex-shrink:0}.agent-drawer-sidetab:hover:not(.active){color:var(--ink);padding-right:10px}.agent-drawer-sidetab.active{background:var(--paper);color:var(--ink);padding-right:12px;box-shadow:4px 4px 0 var(--ink);z-index:1}.agent-drawer-panel{flex:1;overflow-y:auto;background:var(--paper);position:relative}.agent-drawer-panel .agent-profile,.agent-drawer-panel .agent-inspector{padding:14px}.agent-drawer-panel .agent-inspector{padding:0;display:flex;flex-direction:column;min-height:100%}.room-tile-avatar.selectable{cursor:pointer}.room-tile-avatar.selectable:hover{outline:2px solid var(--transmit);outline-offset:1px}.agent-inspector{display:flex;flex-direction:column}.agent-inspector header{padding:10px 14px;border-bottom:2px solid var(--ink);display:flex;justify-content:space-between;align-items:center;gap:12px;background:var(--ink);color:var(--paper)}.agent-inspector header strong{font-family:var(--font-display);font-stretch:80%;font-weight:800;font-size:20px;color:var(--paper);margin-right:8px}.agent-inspector header code{font-family:var(--font-mono);font-size:10px;color:var(--lime);background:transparent;padding:0;margin-right:8px}.agent-inspector header button{padding:3px 8px;border:1px solid var(--paper);background:transparent;color:var(--paper);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}.agent-inspector header button:hover{background:var(--transmit);border-color:var(--transmit)}.agent-inspector .ai-raw-toggle{font-family:var(--font-mono);font-size:10px;color:var(--lime);display:inline-flex;gap:4px;align-items:center;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;margin-right:10px}.agent-inspector-body{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:6px}.agent-inspector-activity{display:flex;gap:14px;align-items:center;padding:8px 14px;border-bottom:2px solid var(--ink);background:var(--paper-2);font-family:var(--font-mono);font-size:11px}.ai-stat{display:inline-flex;align-items:center;gap:6px;padding:2px 6px;transition:background .4s ease;border:1px solid transparent}.ai-stat.flash{background:var(--lime);border-color:var(--ink)}.ai-stat-label{font-size:9px;text-transform:uppercase;letter-spacing:.2em;color:var(--transmit);font-weight:500}.ai-stat strong{font-variant-numeric:tabular-nums;font-size:13px;color:var(--ink)}.ai-stat .muted{font-size:10px;font-variant-numeric:tabular-nums;color:var(--ink-muted)}.ai-pulse{margin-left:auto;color:var(--transmit);font-size:14px;line-height:1;animation:ai-pulse-anim 1s ease-in-out infinite}@keyframes ai-pulse-anim{0%,to{opacity:.3}50%{opacity:1}}.ai-row{padding:6px 10px;border-left:4px solid var(--ink);font-size:12px}.ai-label{display:inline-block;font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--transmit);margin-bottom:3px;font-weight:500}.ai-row pre{margin:3px 0 0;white-space:pre-wrap;word-wrap:break-word;font-family:var(--font-mono);font-size:11px;color:var(--ink-2)}.ai-row-user{background:#dde6f0;border-left-color:var(--prussian)}.ai-row-assistant{background:#e1ecd3;border-left-color:var(--lime)}.ai-row-assistant .ai-text{white-space:pre-wrap}.ai-row-tool-call{background:#f5e7c1;border-left-color:var(--amber)}.ai-row-tool-result{background:var(--paper-3);border-left-color:var(--ink-muted)}.ai-row-err{background:var(--bad-bg);border-left-color:var(--transmit);color:var(--bad-ink)}.ai-row-log{background:var(--paper-2);color:var(--ink-muted);font-family:var(--font-mono);font-size:11px;border-left-color:var(--ink-muted)}.ai-row-exit,.ai-row-meta,.ai-row-turn{color:var(--ink-muted);font-family:var(--font-mono);font-size:10px;text-align:center;letter-spacing:.2em;text-transform:uppercase;padding:4px;border-left-color:transparent}.ai-thinking summary{cursor:pointer;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);letter-spacing:.14em;text-transform:uppercase}.ai-thinking pre{color:var(--ink-muted);font-style:italic}.ai-raw{font-family:var(--font-mono);font-size:11px;white-space:pre-wrap;word-wrap:break-word;color:var(--ink)}.ai-mode{display:inline-flex;margin-right:10px;border:1px solid var(--ink)}.ai-mode button{background:var(--paper);color:var(--ink);border:none;padding:3px 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}.ai-mode button.on{background:var(--ink);color:var(--paper)}.wf-empty{padding:20px;font-family:var(--font-mono);font-size:12px;color:var(--ink-muted)}.wf-layout{display:grid;grid-template-columns:130px 1fr;gap:10px;height:100%}.wf-picker{border-right:1px solid var(--ink);overflow-y:auto;padding-right:6px}.wf-picker ul{list-style:none;margin:0;padding:0}.wf-picker-item{padding:6px 8px;border-bottom:1px dashed var(--ink-faint);cursor:pointer;font-family:var(--font-mono);font-size:11px}.wf-picker-item:hover{background:var(--paper-2)}.wf-picker-item.selected{background:var(--ink);color:var(--paper)}.wf-picker-item.compaction{font-style:italic;color:var(--violet)}.wf-picker-head{display:flex;justify-content:space-between;gap:6px}.wf-picker-head code{font-size:10px;color:var(--ink-muted)}.wf-picker-item.selected .wf-picker-head code,.wf-picker-item.selected .wf-picker-meta small{color:var(--paper-3)}.wf-picker-meta{display:flex;gap:6px;font-size:10px;color:var(--ink-muted);margin-top:2px}.wf-main{overflow-y:auto;padding:4px 8px}.wf{display:flex;flex-direction:column;gap:4px}.wf-stage{border:1.5px solid var(--ink);padding:8px 10px;background:var(--paper-2)}.wf-stage-head{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}.wf-stage-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--paper);font-size:10px;border:1px solid var(--ink)}.wf-arrow{text-align:center;color:var(--ink-muted);font-family:var(--font-mono);font-size:14px}.wf-kv{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;font-family:var(--font-mono);font-size:11px}.wf-kv small{display:block;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;font-size:9px}.wf-kv strong{display:block;font-weight:400;color:var(--ink)}.wf-sections{display:flex;flex-direction:column;gap:3px;margin-top:8px}.wf-section{border-left:3px solid;background:var(--paper)}.wf-section-head{display:flex;align-items:center;gap:6px;width:100%;background:transparent;border:none;padding:4px 8px;cursor:pointer;font-family:var(--font-mono);font-size:11px;text-align:left}.wf-section-head:hover{background:var(--paper-2)}.wf-section-caret{font-size:9px}.wf-section-label{flex:1;text-transform:uppercase;letter-spacing:.08em;font-size:10px}.wf-section-size{color:var(--ink-muted);font-size:10px}.wf-section-body{margin:0;padding:6px 10px;background:var(--paper-3);font-family:var(--font-mono);font-size:11px;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}.wf-budget{padding:6px 4px;margin-bottom:8px;font-family:var(--font-mono);font-size:11px}.wf-budget-stats{display:flex;gap:20px;margin-bottom:6px}.wf-budget-stats small{display:block;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;font-size:9px}.wf-budget-stats strong{font-weight:700;color:var(--ink);margin-right:6px}.wf-budget-bar{display:flex;height:14px;border:1px solid var(--ink);background:var(--paper);overflow:hidden}.wf-budget-seg{height:100%}.wf-budget-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;font-size:10px}.wf-budget-key{display:inline-flex;align-items:center;gap:4px;color:var(--ink-muted)}.wf-budget-swatch{width:10px;height:10px;border:1px solid var(--ink)}.wf-budget.level-amber .wf-budget-stats strong{color:var(--amber)}.wf-budget.level-red .wf-budget-stats strong{color:var(--transmit)}.wf-thinking summary{cursor:pointer;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}.wf-thinking pre{font-family:var(--font-mono);font-size:11px;color:var(--ink-muted);font-style:italic;white-space:pre-wrap;background:var(--paper-3);padding:6px 10px;margin:0 0 6px}.wf-assistant-text{white-space:pre-wrap;font-family:var(--font-serif, var(--font-mono));font-size:13px;line-height:1.4;color:var(--ink)}.wf-usage{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:8px;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted)}.wf-usage small{text-transform:uppercase;letter-spacing:.1em}.wf-usage code{color:var(--ink)}.wf-tool{border:1px dashed var(--ink-muted);background:var(--paper);padding:4px 8px;margin-bottom:4px}.wf-tool.error{border-color:var(--transmit);background:var(--bad-bg, var(--paper))}.wf-tool-head{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted)}.wf-tool pre{margin:2px 0 0;font-family:var(--font-mono);font-size:11px;white-space:pre-wrap;color:var(--ink);max-height:200px;overflow-y:auto}.wf-compaction{border-style:dashed}.testing-view{display:grid;grid-template-columns:300px 1fr;height:100%;overflow:hidden;background:var(--paper)}.testing-sidebar{border-right:2px solid var(--ink);overflow-y:auto;background:var(--paper-2)}.testing-sidebar-header{padding:12px 14px;border-bottom:2px solid var(--ink);display:flex;justify-content:space-between;align-items:center;background:var(--ink);color:var(--paper)}.testing-sidebar-header h2{margin:0;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--paper);font-weight:500}.testing-sidebar-header button{border:1px solid var(--paper);background:transparent;cursor:pointer;padding:2px 10px;font-family:var(--font-mono);font-size:11px;color:var(--paper)}.testing-sidebar-header button:hover{background:var(--transmit);border-color:var(--transmit)}.testing-session-list{list-style:none;margin:0;padding:0}.testing-session-item{padding:10px 14px;border-bottom:1px dashed var(--ink);cursor:pointer}.testing-session-item:hover{background:var(--paper-3)}.testing-session-item.active{background:var(--ink);color:var(--paper)}.testing-session-item.active .testing-session-meta{color:var(--lime)}.testing-session-name{font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:15px;letter-spacing:-.01em;display:flex;gap:6px;align-items:center}.testing-session-meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);margin-top:4px;letter-spacing:.06em}.testing-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;padding:1px 6px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;border:1px solid var(--ink)}.testing-badge.pass{background:var(--lime);color:var(--ink)}.testing-badge.fail{background:var(--transmit);color:var(--paper);border-color:var(--transmit)}.testing-main{overflow-y:auto;padding:24px;background:var(--paper)}.testing-empty{padding:60px 20px;text-align:center;color:var(--ink-muted);font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}.testing-session-header{margin-bottom:16px}.testing-session-header h2{margin:0 0 4px;font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:28px;letter-spacing:-.02em;color:var(--ink)}.testing-test-card{border:2px solid var(--ink);margin-bottom:14px;overflow:hidden;background:var(--card);box-shadow:var(--shadow-card)}.testing-test-card.fail{box-shadow:4px 4px 0 var(--transmit)}.testing-test-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--ink);background:var(--paper-2)}.testing-test-title{font-family:var(--font-display);font-weight:800;font-stretch:85%;font-size:16px;letter-spacing:-.01em;display:flex;gap:8px;align-items:center;color:var(--ink)}.testing-test-duration{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);letter-spacing:.1em;background:transparent;padding:0}.testing-video{background:var(--ink);padding:6px}.testing-video video{width:100%;max-height:480px;display:block}.testing-no-video{padding:16px;text-align:center;color:var(--ink-faint);font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase}.testing-error-box{margin:8px 12px 12px;padding:10px;background:var(--bad-bg);border:1.5px solid var(--transmit);font-family:var(--font-mono);font-size:11px;color:var(--bad-ink);white-space:pre-wrap;word-wrap:break-word}.testing-error{color:var(--bad-ink);font-family:var(--font-mono);font-size:11px;padding:10px 14px}.agent-library{padding:24px 32px;overflow-y:auto}.agent-library header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.agent-library h1{margin:0;font-size:20px}.agent-library-new{display:flex;gap:8px}.agent-library-new input{padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:13px;min-width:240px}.agent-library-new button{padding:6px 14px;border:1px solid #0066cc;background:#06c;color:#fff;border-radius:4px;cursor:pointer;font-size:13px}.agent-library-new button:disabled{opacity:.5;cursor:not-allowed}.agent-library-error{color:#c00;font-size:13px}.agent-library-table{width:100%;border-collapse:collapse;font-size:13px;background:#fff;border:1px solid #e5e5e5;border-radius:6px}.agent-library-table th,.agent-library-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #eee;vertical-align:middle}.agent-library-table th{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#666;background:#fafafa;font-weight:600}.agent-library-table code{font-size:11px;color:#666}.agent-library-actions{display:flex;gap:6px}.agent-library-actions button{padding:3px 10px;border:1px solid #ddd;background:#fff;border-radius:3px;cursor:pointer;font-size:12px}.agent-library-actions button:hover:not(:disabled){background:#f0f0f0}.agent-library-actions button:disabled{opacity:.4;cursor:not-allowed}.agent-library-actions button.danger{color:#c00;border-color:#f0c0c0}.agent-library-actions button.danger:hover{background:#fff0f0}.sandbox2{display:grid;grid-template-columns:340px 1fr;grid-template-rows:auto 1fr;gap:16px;padding:16px;height:100%;overflow:hidden}.sandbox2-info{grid-column:1 / -1;display:flex;align-items:center;gap:24px;padding:10px 14px;background:#fafafa;border:1px solid #e5e5e5;border-radius:6px;font-size:13px;flex-wrap:wrap}.sandbox2-cards{display:flex;flex-direction:column;gap:8px;min-height:0;padding:12px;overflow:hidden;background:#fafafa;border:1px solid #e5e5e5;border-radius:6px}.sandbox2-cards header{display:flex;justify-content:space-between;align-items:center;padding-bottom:8px;border-bottom:1px solid #eee}.sandbox2-cards header h2{margin:0;font-size:15px}.sandbox2-cards header button{padding:4px 12px;border:1px solid #0066cc;background:#06c;color:#fff;border-radius:4px;cursor:pointer;font-size:12px}.sandbox2-cards header button:hover{background:#0056b3}.sandbox2-card-list{list-style:none;margin:0;padding:2px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.sandbox2-card{display:flex;gap:10px;background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:10px;cursor:grab;-webkit-user-select:none;user-select:none;position:relative;box-shadow:0 1px 2px #1018280a,0 1px #ffffff80 inset;transition:transform .18s cubic-bezier(.2,.9,.3,1.2),box-shadow .18s,border-color .18s}.sandbox2-card:hover{transform:translateY(-2px) rotate(-.4deg);box-shadow:0 6px 18px #10182814,0 2px 4px #1018280a;border-color:#c4d2ef}.sandbox2-card:active{cursor:grabbing;transform:translateY(0) rotate(0)}.sandbox2-card.running{border-color:#8fd0a8;background:linear-gradient(180deg,#f3fbf5,#fff 70%)}.sandbox2-card-portrait{position:relative;flex:0 0 72px;width:72px;height:72px;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);display:flex;align-items:center;justify-content:center}.sandbox2-card-portrait img{width:100%;height:100%;object-fit:cover;display:block}.sandbox2-card-portrait-fallback{font-size:28px;font-weight:700;color:#4f46e5;font-family:-apple-system,Segoe UI,Roboto,sans-serif}.sandbox2-card-runtime-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #fff,0 0 0 3px #22c55e66;animation:sandbox2-pulse 1.4s ease-in-out infinite}@keyframes sandbox2-pulse{0%,to{box-shadow:0 0 0 2px #fff,0 0 0 3px #22c55e66}50%{box-shadow:0 0 0 2px #fff,0 0 0 6px #22c55e00}}.sandbox2-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.sandbox2-card-name{font-size:14px;font-weight:600;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sandbox2-card-about{margin:0;font-size:12px;color:#555;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sandbox2-card-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:6px;padding-top:4px}.sandbox2-card-footer .agent-model-badge{max-width:140px;overflow:hidden;text-overflow:ellipsis}.sandbox2-card-actions{display:inline-flex;gap:4px}.sandbox2-card-actions button{padding:3px 10px;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:11px}.sandbox2-card-actions button:hover{background:#f0f0f0}.sandbox2-card-actions button.primary{border-color:#06c;background:#06c;color:#fff}.sandbox2-card-actions button.primary:hover{background:#0056b3}.sandbox2-card-actions button.primary:disabled{opacity:.5;cursor:not-allowed}.sandbox2-card-actions button.danger{color:#c00;border-color:#f0c0c0}.sandbox2-card-actions button.danger:hover{background:#fff0f0}.sandbox2-room{display:flex;flex-direction:column;min-height:0;background:#fff;border:1px solid #e5e5e5;border-radius:6px;overflow:hidden}.sandbox2-room header{padding:10px 14px;border-bottom:1px solid #eee;background:#fafafa}.sandbox2-room header h2{margin:0;font-size:15px}.sandbox2-room-body{flex:1;overflow-y:auto;padding:12px 14px}.sandbox2-room-body h3{margin:12px 0 6px;font-size:12px;text-transform:uppercase;color:#666;letter-spacing:.5px}.sandbox2-room-body h3:first-child{margin-top:0}.sandbox2-tip{margin-top:16px;font-size:12px}.sandbox2-tip a{color:#06c}.agent-profile{display:flex;flex-direction:column;gap:var(--sp-3);padding:var(--sp-3)}.agent-profile-card{display:flex;gap:var(--sp-3);background:var(--paper);border:1.5px solid var(--ink);box-shadow:var(--shadow-card);padding:var(--sp-3)}.agent-profile-card-portrait-col{display:flex;flex-direction:column;align-items:stretch;gap:6px;flex:0 0 96px}.agent-profile-card-portrait{position:relative;width:96px;height:96px;background:var(--paper-3);border:1.5px solid var(--ink);overflow:hidden;display:flex;align-items:center;justify-content:center}.agent-profile-avatar-btn{padding:4px 6px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;line-height:1.2}.agent-profile-avatar-btn:hover:not(:disabled){background:var(--ink);color:var(--paper)}.agent-profile-avatar-btn:disabled{opacity:.45;cursor:not-allowed}.agent-profile-card-portrait img{width:100%;height:100%;object-fit:cover;display:block}.agent-profile-card-portrait-fallback{font-family:var(--font-display);font-stretch:75%;font-weight:900;font-size:48px;color:var(--prussian)}.agent-profile-card-portrait-spinner{display:flex;align-items:center;justify-content:center;color:var(--ink-muted)}.agent-profile-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.agent-profile-name{font-family:var(--font-display);font-stretch:85%;font-weight:700;font-size:18px;color:var(--ink);background:transparent;border:none;border-bottom:1.5px dashed transparent;padding:2px 0;outline:none}.agent-profile-name:hover,.agent-profile-name:focus{border-bottom-color:var(--ink-muted)}.agent-profile-about{font-family:var(--font-mono);font-size:12px;line-height:1.45;color:var(--ink);background:transparent;border:1.5px dashed transparent;padding:4px 6px;resize:vertical;min-height:72px;outline:none}.agent-profile-about:hover,.agent-profile-about:focus{border-color:var(--ink-muted)}.agent-profile-card-npub{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);word-break:break-all;margin-top:auto;text-decoration:none;border-bottom:1px dashed var(--ink-faint);padding-bottom:1px;cursor:pointer;align-self:flex-start}.agent-profile-card-npub:hover{color:var(--transmit);border-bottom-color:var(--transmit)}.agent-profile-card-npub:after{content:" ↗";color:var(--ink-faint)}.agent-profile-card-npub:hover:after{color:var(--transmit)}.agent-profile-error{font-family:var(--font-mono);font-size:11px;color:var(--transmit);background:var(--paper-2);border-left:3px solid var(--transmit);padding:6px 10px;margin:0}.agent-profile-actions{display:flex;gap:var(--sp-2);align-items:center;padding:0;margin:0;border:none;background:transparent}.agent-profile-actions button{padding:6px 14px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:transform .12s,box-shadow .12s}.agent-profile-actions button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink)}.agent-profile-actions button.primary{background:var(--ink);color:var(--paper)}.agent-profile-actions button.primary:hover:not(:disabled){box-shadow:2px 2px 0 var(--transmit)}.agent-profile-actions button.danger{color:var(--transmit);border-color:var(--transmit)}.agent-profile-actions button.danger:hover:not(:disabled){background:var(--transmit);color:var(--paper)}.agent-profile-actions button:disabled{opacity:.45;cursor:not-allowed}.agent-profile-danger{margin:var(--sp-3) 0 0;border:1.5px dashed var(--transmit);padding:var(--sp-2) var(--sp-3) var(--sp-3);background:var(--paper-2);display:flex;flex-direction:column;gap:var(--sp-2)}.agent-profile-danger legend{padding:0 6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--transmit);font-weight:700}.agent-profile-danger .muted{font-size:11px;line-height:1.4;margin:0;color:var(--ink-muted)}.agent-profile-danger button.danger{align-self:flex-start;padding:6px 14px;border:1.5px solid var(--transmit);background:var(--paper);color:var(--transmit);font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:transform .12s,box-shadow .12s}.agent-profile-danger button.danger:hover:not(:disabled){background:var(--transmit);color:var(--paper);transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink)}.relay-feed-view{padding:24px 32px;overflow-y:auto}.relay-feed-view header{margin-bottom:16px}.relay-feed-view h1{margin:0 0 6px;font-size:20px}.relay-feed-meta{display:flex;gap:12px;align-items:center;font-size:12px;color:#666}.relay-feed-meta code{font-size:11px}.relay-feed-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.relay-feed-list li{padding:10px 14px;background:#fff;border:1px solid #e5e5e5;border-radius:6px}.relay-feed-author{display:flex;gap:8px;align-items:baseline;margin-bottom:6px;flex-wrap:wrap}.relay-feed-author time{font-size:11px;color:#888;font-variant-numeric:tabular-nums}.relay-feed-author-link{color:inherit;text-decoration:none}.relay-feed-author-link:hover strong{text-decoration:underline}.relay-feed-jumble-link{margin-left:auto;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);text-decoration:none;border:1px solid var(--ink-faint);padding:1px 5px;border-radius:3px}.relay-feed-jumble-link:hover{color:var(--ink);border-color:var(--ink);background:var(--paper-2)}.relay-feed-content{font-size:13px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.agent-profile-generate{margin:0;border:1.5px solid var(--ink);background:var(--paper-2);padding:var(--sp-2) var(--sp-3) var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-2)}.agent-profile-generate legend{padding:0 6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700}.agent-profile-generate-btn{padding:10px 16px;border:1.5px solid var(--ink);background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;cursor:pointer;align-self:stretch;transition:transform .12s,box-shadow .12s,background .12s}.agent-profile-generate-btn:hover:not(:disabled){background:var(--transmit);border-color:var(--transmit);transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--ink)}.agent-profile-generate-btn:disabled{opacity:.5;cursor:not-allowed}.agent-profile-generate-options{border-top:1px dashed var(--ink-faint);padding-top:var(--sp-2)}.agent-profile-generate-options summary{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);cursor:pointer;padding:2px 0}.agent-profile-generate-options summary:hover{color:var(--ink)}.agent-profile-generate-options[open] summary{color:var(--ink);margin-bottom:var(--sp-2)}.agent-profile-generate-options label{display:flex;flex-direction:column;gap:4px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:var(--sp-2)}.agent-profile-generate-options input,.agent-profile-generate-options select{padding:5px 8px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:12px;letter-spacing:0;text-transform:none}.agent-profile-generate-model{margin:0;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);display:flex;align-items:center;gap:6px}.agent-profile-generate-model code{font-size:10px;color:var(--ink)}.agent-profile-generate-spinner{width:12px;height:12px;border-width:2px}.agent-profile-jumble-link{margin-left:auto;color:#06c;font-size:12px;text-decoration:none}.agent-profile-jumble-link:hover{text-decoration:underline}.agent-profile-avatar-row{display:flex;gap:14px;padding:14px 18px;border-bottom:1px solid #f4f4f4}.agent-profile-avatar{flex:0 0 120px;height:120px;border-radius:8px;background:#f3f4f6;overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid #e5e5e5}.agent-profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.agent-profile-avatar-empty{color:#aaa;font-size:12px}.agent-profile-avatar-spinner{display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11px;color:#666}.spinner{width:28px;height:28px;border:3px solid #d8deff;border-top-color:#3b3f9e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.agent-profile-avatar-actions{flex:1;display:flex;flex-direction:column;gap:6px;justify-content:center}.agent-profile-avatar-actions button{align-self:flex-start;padding:6px 12px;border:1px solid #3b3f9e;background:#eef2ff;color:#3b3f9e;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600}.agent-profile-avatar-actions button:disabled{opacity:.5;cursor:not-allowed}.agent-profile-avatar-actions .muted{font-size:11px;margin:0}.agent-profile-stream-status{display:flex;gap:10px;align-items:center;padding:8px 10px;background:#f6f7ff;border:1px dashed #d8deff;border-radius:4px}.agent-profile-stream-status .spinner{width:16px;height:16px;border-width:2px}.agent-profile-stream-status small{display:block;font-size:10px;color:#666;text-transform:uppercase;letter-spacing:.5px}.agent-profile-stream-status code{font-size:11px;color:#3b3f9e}.agent-profile-stream-status .muted{display:block;font-style:italic;font-size:11px}.agent-profile-stream-preview{padding:8px 10px;background:#fff;border:1px solid #e5e5e5;border-radius:4px;font-size:13px}.agent-profile-stream-about{color:#444;font-size:12px;margin-top:4px;line-height:1.4;white-space:pre-wrap}.agent-profile-stream-about .caret{display:inline-block;width:6px;color:#3b3f9e;animation:blink 1s steps(1,end) infinite}@keyframes blink{50%{opacity:0}}.relay-feed-kind{font-size:10px;padding:1px 6px;border-radius:3px;background:#eef2ff;color:#3b3f9e;margin-left:8px;text-transform:lowercase;letter-spacing:.5px}.relay-feed-item-profile{border-color:#d8deff;background:#fafbff}.relay-feed-profile{display:flex;gap:12px;align-items:center;margin-top:4px}.relay-feed-profile img{width:48px;height:48px;border-radius:6px;object-fit:cover;border:1px solid #e5e5e5}.relay-feed-profile .muted{font-size:12px}.agent-profile-generate-top{margin:10px 18px 0;background:#f6f7ff}.agent-profile-generate-row{display:flex;gap:10px;align-items:center}.agent-profile-generate-row select{flex:1;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:12px;color:#222;font-family:ui-monospace,SFMono-Regular,monospace}.agent-profile-generate-row button{white-space:nowrap}.agent-profile-generate-model{display:flex;align-items:center;gap:8px;margin:4px 0 0;font-size:12px}.agent-profile-generate-model code{font-size:11px;color:#3b3f9e}.agent-profile-generate-spinner{width:14px;height:14px;border-width:2px;flex-shrink:0}.sandbox2-chat{display:flex;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-top:2px solid var(--ink);background:var(--paper-2);align-items:center}.sandbox2-chat input{flex:1;padding:var(--sp-2) var(--sp-3);border:1.5px solid var(--ink);background:var(--card);font-family:var(--font-sans);font-size:13px;color:var(--ink);outline:none}.sandbox2-chat input:focus{background:var(--paper);box-shadow:2px 2px 0 var(--transmit)}.sandbox2-chat button{padding:var(--sp-2) var(--sp-4);border:2px solid var(--ink);background:var(--ink);color:var(--paper);font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:12px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;box-shadow:3px 3px 0 var(--transmit)}.sandbox2-chat button:hover:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px 0 var(--transmit)}.sandbox2-chat button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.sandbox2-chat-error{font-size:11px;color:var(--transmit);font-family:var(--font-mono)}.sandbox2-card-status{font-family:var(--font-mono);font-size:10px;color:var(--ok-ink);letter-spacing:.1em;text-transform:uppercase}.sandbox2-card-runtime-dot.thinking{background:var(--amber);box-shadow:0 0 0 2px var(--paper),0 0 0 3px #e8a72a66}@keyframes sandbox2-pulse-amber{0%,to{box-shadow:0 0 0 2px var(--paper),0 0 0 3px #e8a72a66}50%{box-shadow:0 0 0 2px var(--paper),0 0 0 7px #e8a72a00}}.sandbox2-card-runtime-dot.thinking{animation:sandbox2-pulse-amber .9s ease-in-out infinite}.sandbox3{display:grid;grid-template-columns:280px 1fr;gap:var(--sp-3);padding:var(--sp-3);height:100%;overflow:hidden;background:var(--paper);position:relative;transition:grid-template-columns .22s ease-out}.sandbox3:has(.agent-drawer:not(.closing)){grid-template-columns:calc(280px + var(--sp-3) + 420px + 44px) 1fr}.sandbox3-cards{width:280px;justify-self:start;position:relative;z-index:10}.sandbox3-cards{display:flex;flex-direction:column;gap:var(--sp-2);min-height:0;padding:var(--sp-3);background:var(--card);border:2px solid var(--ink);box-shadow:var(--shadow-card);overflow:hidden}.sandbox3-cards header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--sp-2);border-bottom:1.5px solid var(--ink)}.sandbox3-cards h2{margin:0;font-family:var(--font-display);font-stretch:75%;font-weight:800;font-size:18px;letter-spacing:-.02em;text-transform:lowercase;color:var(--ink)}.sandbox3-cards header button{padding:4px 12px;border:2px solid var(--ink);background:var(--ink);color:var(--paper);font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:11px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;box-shadow:2px 2px 0 var(--transmit)}.sandbox3-cards header button:hover{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--transmit)}.sandbox3-settings{border:1.5px solid var(--ink);background:var(--paper-2);margin:var(--sp-2);font-family:var(--font-mono);font-size:11px}.sandbox3-settings summary{cursor:pointer;padding:var(--sp-2);display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);list-style:none}.sandbox3-settings summary::-webkit-details-marker{display:none}.sandbox3-settings summary:before{content:"▶";font-size:9px;color:var(--ink-muted)}.sandbox3-settings[open] summary:before{content:"▼"}.sandbox3-settings-title{text-transform:uppercase;letter-spacing:.12em;font-weight:700;margin-right:auto}.sandbox3-settings-current{color:var(--ink-muted);font-size:10px;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.sandbox3-settings-body{padding:var(--sp-2);border-top:1px dashed var(--ink);display:flex;flex-direction:column;gap:var(--sp-2)}.sandbox3-settings-body label{display:flex;flex-direction:column;gap:4px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted)}.sandbox3-settings-body select{font-family:var(--font-mono);font-size:11px;padding:4px 6px;border:1px solid var(--ink);background:var(--paper);color:var(--ink);text-transform:none;letter-spacing:0}.sandbox3-settings-providers{display:flex;border:1px solid var(--ink)}.sandbox3-settings-providers button{flex:1;background:var(--paper);color:var(--ink);border:none;padding:4px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}.sandbox3-settings-providers button:disabled{color:var(--ink-faint);cursor:not-allowed}.sandbox3-settings-providers button.on{background:var(--ink);color:var(--paper)}.sandbox3-settings-hint{margin:0;font-size:10px;color:var(--ink-muted);line-height:1.4}.sandbox3-settings-hint code{font-size:10px;color:var(--ink)}.sandbox3-settings-reset{margin:0 4px;padding:1px 6px;background:var(--paper);border:1px solid var(--ink);font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;color:var(--ink)}.sandbox3-settings-reset:hover:not(:disabled){background:var(--ink);color:var(--paper)}.sandbox3-settings-reset:disabled{color:var(--ink-faint);cursor:not-allowed}.sandbox3-card-list{list-style:none;margin:0;padding:2px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--sp-2)}.sandbox3-card{display:flex;gap:var(--sp-2);background:var(--paper);border:1.5px solid var(--ink);padding:var(--sp-2);cursor:grab;-webkit-user-select:none;user-select:none;box-shadow:2px 2px 0 var(--ink);transition:transform .15s,box-shadow .15s}.sandbox3-card:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--transmit)}.sandbox3-card:active{cursor:grabbing;transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink)}.sandbox3-card.running{background:var(--ok-bg)}.sandbox3-card.thinking{animation:card-pulse 1.2s ease-in-out infinite}@keyframes card-pulse{0%,to{box-shadow:2px 2px 0 var(--ink)}50%{box-shadow:2px 2px 0 var(--amber)}}.sandbox3-card{position:relative}.sandbox3-card.selected:after{content:"";position:absolute;top:-1.5px;bottom:-1.5px;right:-1.5px;width:4px;background:var(--transmit);pointer-events:none}.sandbox3-card.selected{border-right-color:var(--transmit)}.sandbox3-card-portrait{position:relative;flex:0 0 56px;width:56px;height:56px;background:var(--paper-3);border:1.5px solid var(--ink);overflow:hidden;display:flex;align-items:center;justify-content:center}.sandbox3-card-portrait img{width:100%;height:100%;object-fit:cover;display:block}.sandbox3-card-portrait-fallback{font-family:var(--font-display);font-stretch:75%;font-weight:900;font-size:28px;color:var(--prussian)}.sandbox3-card-dot{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--lime);border:1.5px solid var(--ink)}.sandbox3-card.thinking .sandbox3-card-dot{background:var(--amber)}.sandbox3-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.sandbox3-card-name{font-family:var(--font-display);font-weight:700;font-stretch:85%;font-size:15px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sandbox3-card-status{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ok-ink)}.sandbox3-card-about{margin:0;font-size:11px;color:var(--ink-2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sandbox3-card-actions{margin-top:2px;display:flex;gap:4px}.sandbox3-card-actions button{padding:2px 8px;border:1.5px solid var(--ink);background:var(--paper);font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}.sandbox3-card-actions button:hover,.sandbox3-card-actions button.primary{background:var(--ink);color:var(--paper)}.sandbox3-card-actions button.primary:hover{background:var(--transmit);border-color:var(--transmit)}.sandbox3-card-actions button.danger{color:var(--bad-ink);border-color:var(--bad-ink)}.sandbox3-card-actions button.danger:hover{background:var(--bad-ink);color:var(--paper)}.sandbox3-card-actions .sandbox3-card-jumble{padding:2px 8px;border:1.5px solid var(--ink);background:var(--paper);font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;color:var(--ink)}.sandbox3-card-actions .sandbox3-card-jumble:hover{background:var(--ink);color:var(--paper)}.sandbox3-card-model{font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.sandbox3-stage{display:grid;grid-template-rows:auto 1fr auto auto;gap:var(--sp-2);min-height:0;background:var(--card);border:2px solid var(--ink);box-shadow:var(--shadow-card);position:relative;padding:var(--sp-3);overflow:hidden}.sandbox3-stage header{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1.5px solid var(--ink);padding-bottom:var(--sp-2)}.sandbox3-stage header h2{margin:0;font-family:var(--font-display);font-stretch:75%;font-weight:800;font-size:22px;letter-spacing:-.02em;text-transform:lowercase;color:var(--ink);display:flex;align-items:baseline;gap:var(--sp-2)}.sandbox3-map-frame{position:relative;display:flex;align-items:center;justify-content:center;min-height:0;overflow:hidden;background:repeating-linear-gradient(45deg,var(--paper-3) 0 2px,transparent 2px 6px),var(--paper-2);border:1.5px solid var(--ink);container-type:size}.sandbox3-toast{position:absolute;bottom:10px;left:50%;transform:translate(-50%);padding:6px 12px;background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:11px;letter-spacing:.05em;border:1.5px solid var(--ink);box-shadow:3px 3px 0 var(--transmit)}.sandbox3-chatlog{max-height:120px;overflow-y:auto;background:var(--paper);border:1.5px solid var(--ink);padding:var(--sp-2)}.sandbox3-chatlog ul{list-style:none;padding:0;margin:0}.sandbox3-chatlog li{padding:2px 0;font-size:12px;line-height:1.4;border-bottom:1px dotted var(--ink-faint)}.sandbox3-chatlog li:last-child{border-bottom:none}.sandbox3-chatlog strong{color:var(--transmit);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}.room-map-wrap{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0}.room-map{display:grid;width:min(100%,calc((100cqh - 36px) * 4 / 3));max-width:880px;max-height:calc(100cqh - 36px);aspect-ratio:4 / 3;gap:1px;background:var(--ink);border:2px solid var(--ink)}.room-map-caption{flex:0 0 auto;margin-top:var(--sp-2)}.room-tile{background:var(--card);display:flex;align-items:center;justify-content:center;position:relative;transition:background .1s;cursor:pointer}.room-tile:hover{background:var(--paper-2)}.room-tile.occupied{cursor:default}.room-tile.drag-over{background:var(--lime);box-shadow:inset 0 0 0 2px var(--transmit)}.room-tile-avatar{width:82%;height:82%;border-radius:50%;overflow:hidden;border:1.5px solid var(--ink);display:flex;align-items:center;justify-content:center;background:var(--paper-3);box-shadow:1px 1px 0 var(--ink)}.room-tile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.room-tile-avatar span{font-family:var(--font-display);font-weight:800;font-stretch:75%;font-size:14px;color:var(--prussian)}.room-tile-avatar.running{border-color:var(--ok-ink)}.room-tile-avatar.thinking{border-color:var(--amber);animation:card-pulse 1.2s ease-in-out infinite}.room-tile-avatar.kind-human{background:var(--transmit);color:var(--paper)}.room-tile-avatar.kind-human span{color:var(--paper)}.room-tile-avatar.kind-admin{background:var(--prussian)}.room-tile-avatar.kind-admin span{color:var(--paper)}.room-tile-badge{position:absolute;bottom:1px;right:1px;background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:8px;padding:0 3px;letter-spacing:.05em}.room-tile-hint{position:absolute;top:-28px;left:50%;transform:translate(-50%);padding:2px 8px;background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:10px;white-space:nowrap;z-index:5;box-shadow:2px 2px 0 var(--transmit)}.room-map-caption{margin:0;font-family:var(--font-mono);font-size:10px;color:var(--ink-muted);letter-spacing:.1em;text-transform:uppercase}.relay-feed-info{display:flex;gap:var(--sp-5);margin-bottom:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--card);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);flex-wrap:wrap;font-size:13px}.sidebar-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-2)}.sidebar-collapse{flex:0 0 24px;width:24px;height:24px;margin-top:2px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:14px;font-weight:700;line-height:1;cursor:pointer;padding:0;box-shadow:1px 1px 0 var(--ink)}.sidebar-collapse:hover{background:var(--ink);color:var(--paper)}.app.sidebar-collapsed .sidebar{width:0;padding:0;overflow:hidden;border-right:0;transition:width .18s ease}.app .sidebar{transition:width .18s ease}.sidebar-reopen{position:fixed;top:14px;left:0;z-index:30;width:22px;height:44px;border:1.5px solid var(--ink);border-left:0;background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:16px;font-weight:700;line-height:1;cursor:pointer;padding:0;box-shadow:2px 2px 0 var(--ink)}.sidebar-reopen:hover{background:var(--ink);color:var(--paper)}.sandbox3-card-state{margin:2px 0 0;padding:4px 6px;font-size:11px;color:var(--ink-2);line-height:1.35;background:var(--paper-3);border-left:2px solid var(--transmit);font-style:italic;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.sandbox3-card-state-label{display:inline-block;margin-right:5px;font-family:var(--font-mono);font-size:8px;letter-spacing:.15em;text-transform:uppercase;color:var(--transmit);font-style:normal;font-weight:700}.sandbox3-card-gauge{display:flex;align-items:center;gap:6px;margin-top:2px;font-family:var(--font-mono);font-size:9px;color:var(--ink-muted);letter-spacing:.05em}.sandbox3-card-gauge-bar{flex:1;height:4px;background:var(--paper-3);border:1px solid var(--ink);overflow:hidden}.sandbox3-card-gauge-fill{height:100%;background:var(--ok-ink);transition:width .3s ease}.sandbox3-card-gauge.level-amber .sandbox3-card-gauge-fill{background:var(--amber)}.sandbox3-card-gauge.level-red .sandbox3-card-gauge-fill{background:var(--transmit)}.sandbox3-card-gauge small{opacity:.6}
