html{font:100%/1.3 system-ui,san-serif}body{margin:0}header{display:flex;padding:10px;background:#ddd}header h1{margin:0;padding-right:.5em;font-size:1.5em;font-weight:300}header h1 a{text-decoration:none;color:#555}header h1 a:hover{text-decoration:underline;color:#000}nav{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1px}nav a{padding:.3em .8em;border-radius:1em;color:#673ab8;text-decoration:none;white-space:nowrap}nav a:hover{background-color:#ffffff80;color:#56319c;box-shadow:inset 0 0 0 1px #673ab8;z-index:1}nav a.current{background:#673ab8;color:#fff}main{padding:10px}output{padding:.3em;min-width:1.5em;display:inline-block;text-align:center}.info{position:relative;padding:.5em .5em .5em 2em;max-width:600px;background:#e6ebfc;border-radius:5px;box-shadow:inset 0 0 0 .5px #b0bee2;color:#3955a1}.info:before{content:"\2139";position:absolute;display:inline-block;text-align:center;line-height:1em;width:1.2em;height:1.2em;left:.4em;top:50%;margin-top:-.6em;background:#3955a1;border-radius:.6em;color:#fff}.card{display:inline-block;padding:.5em 1em;background:#eee;box-shadow:inset 0 0 0 .5px #ccc;border-radius:5px}.card+.card{margin-left:10px}button{padding:.3em 1em;border-radius:1em;border:none;background:#673ab8;color:#f4eeff;cursor:pointer}button:hover{background:#9359ff;color:#fff}table{margin-top:1em;border-collapse:collapse}th,td{border:1px solid #aaa;padding:.3em}.nesting{position:relative;margin:10px;padding:10px;max-width:22em;border:1px solid #ddd;background:#f4f2f0}.nesting .notes{color:#345;margin-top:20px;border-top:4px double #ccc}.nesting h4{margin:1em 0 0}.nesting ul{margin:0;padding:.25em 1em}.nesting li>ul{padding-top:0;padding-bottom:0;font-size:90%}.nesting ul>li{padding:.25em 0}.nesting code{font:100%/1.3 Source Code Pro,monaco,menlo;color:#0a8138}.nesting output{display:inline-block;vertical-align:middle;margin:0 .25em;min-width:2.5em;height:1.3em;border-radius:.3em;text-align:center;background:rgba(255,255,255,.7);box-shadow:0 0 0 .5px #0000001a,inset 0 2px 5px #0000001a}.nesting .render-count{position:absolute;right:0;top:0;padding:0 .3em;font-size:70%}.nesting .object-editor{position:relative;margin:20px 0 0;padding:10px 5px 5px;border:1px solid #abc;background:#fff;border-radius:5px}.nesting .clock{position:fixed;right:0;top:3.2em;width:6em;padding:1.1em 1em .8em;text-align:center;background:burlywood;color:#556b2f}.nesting table{table-layout:fixed}.nesting table th{text-align:left}.nesting table th:first-child,.nesting table td:first-child{width:7em;text-align:right;font-weight:700}.nesting table th:nth-child(2),.nesting table td:nth-child(2){width:4em;padding-left:.5em}.nesting table td:nth-child(3){width:10em}.devtools-demo-container{display:flex;gap:20px;height:100vh;padding:20px}.app-section{flex:1;overflow-y:auto}.devtools-section{flex:1;min-width:600px;background:white;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.devtools-panel{height:100%;width:100%}.new-todo{display:flex;align-items:center;gap:8px;margin-bottom:8px}.todo-item{display:flex;align-items:center;gap:8px;margin-bottom:4px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.4;color:#333;background:#f5f5f5;overflow:hidden}#app{height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid #e0e0e0;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.header-title{display:flex;align-items:center;gap:12px}.header-title h1{font-size:16px;font-weight:700;color:#5e35b1}.connection-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#444}.divider{width:100%;height:2px;background:#e0e0e0;margin:8px 0}.status-indicator{width:8px;height:8px;border-radius:50%;background:#f44336;transition:background-color .2s}.status-indicator.connected{background:#4caf50}.status-indicator.connecting{background:#ff9800;animation:pulse 2s infinite}.status-indicator.warning{background:#ff9800}.status-indicator.disconnected{background:#f44336}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-controls{display:flex;gap:8px}.btn{border:1px solid #ccc;background:#fff;color:#333;padding:4px 12px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.btn:hover{background:#f0f0f0}.btn.btn-primary{background:#2196f3;border-color:#2196f3;color:#fff}.btn.btn-primary:hover{background:#1976d2}.btn.btn-secondary{background:#f5f5f5}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.active{background:#673ab7;border-color:#673ab7;color:#fff}.btn.active:hover{background:#5e35b1;border-color:#5e35b1}.settings-panel{position:absolute;top:49px;right:12px;left:auto;width:320px;background:white;border:1px solid #d0d0d0;border-radius:8px;box-shadow:0 4px 16px #00000026;z-index:1000;max-height:400px;overflow-y:auto}.settings-content{padding:16px}.settings-content h3{margin-bottom:16px;font-size:14px;font-weight:600}.setting-group{margin-bottom:12px}.setting-group label{display:block;margin-bottom:4px;font-weight:500}.setting-group input[type=checkbox]{margin-right:8px}.setting-group input[type=number],.setting-group textarea{width:100%;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:12px}.setting-group textarea{height:60px;resize:vertical;font-family:monospace}.settings-actions{margin-top:16px;display:flex;gap:8px;justify-content:flex-end}.tabs{background:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;padding:0 8px}.tab{padding:10px 20px;border:1px solid transparent;border-bottom:none;background:none;cursor:pointer;font-size:13px;font-weight:500;color:#555;transition:all .2s;margin-top:4px;border-radius:6px 6px 0 0}.tab:hover{color:#333;background:#f0f0f0}.tab.active{color:#673ab7;background:#f5f0ff;border-color:#d0c0e8;border-bottom:2px solid #fff;margin-bottom:-1px;font-weight:600}.main-content{flex:1;overflow:hidden;position:relative;display:flex;flex-direction:column}.tab-content{flex:1;overflow:hidden}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;text-align:center}.empty-state-content h2{font-size:18px;margin-bottom:8px;color:#666}.empty-state-content p{color:#999;margin-bottom:16px}.updates-container{height:100%;display:flex;flex-direction:column}.updates-header{background:#fff;border-bottom:1px solid #e0e0e0;padding:8px 12px;flex-shrink:0}.updates-stats{display:flex;gap:16px;font-size:12px;color:#666}.updates-list{flex:1;overflow-y:auto;padding:8px}.update-item{background:white;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:8px;padding:8px;font-size:12px}.update-item.effect{border-left:4px solid #ff9800}.component-name-header{margin-right:8px}.component-list{list-style:none;display:flex;margin:0;font-family:monospace;background:#f8f9fa;padding:4px 6px;border-radius:3px}.update-item.rerender{border-left:4px solid #9c27b0;background-color:#fafafa}.update-item.value{border-left:4px solid #2196f3}.update-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.update-count{display:inline-block;padding:0 6px;background:#e0e0e0;border-radius:12px;margin:0 2px}.signal-name{font-weight:600;color:#5e35b1}.component-name{font-weight:500;color:#1565c0;font-style:italic}.update-time{color:#757575;font-size:11px}.update-depth{color:#555;font-size:11px}.value-change{margin:4px 0;font-family:monospace;background:#f8f9fa;padding:4px 6px;border-radius:3px}.value-prev,.value-new{display:inline-block;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:top}.value-prev{color:#d32f2f}.value-new{color:#388e3c}.value-arrow{margin:0 8px;color:#666}.updates-list::-webkit-scrollbar{width:8px}.updates-list::-webkit-scrollbar-track{background:#f5f5f5}.updates-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.updates-list::-webkit-scrollbar-thumb:hover{background:#999}.graph-container{height:100%;display:flex;flex-direction:column}.graph-content{flex:1;position:relative;background:linear-gradient(90deg,#e5e7eb 1px,transparent 1px),linear-gradient(180deg,#e5e7eb 1px,transparent 1px),#f8fafc;background-size:40px 40px;overflow:hidden;user-select:none}.graph-svg{width:100%;height:100%;min-height:500px}.graph-controls{position:absolute;top:16px;left:16px;display:flex;gap:8px;z-index:10}.graph-reset-button,.graph-export-button{background:rgba(255,255,255,.95);backdrop-filter:blur(4px);border:1px solid #e2e8f0;border-radius:6px;color:#334155;padding:8px 14px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 2px 6px #00000014;transition:all .15s ease}.graph-reset-button:hover,.graph-export-button:hover{background:#fff;border-color:#cbd5e1;box-shadow:0 4px 8px #0000001f;transform:translateY(-1px)}.graph-reset-button:active,.graph-export-button:active{background:#eeeeee;transform:translateY(1px)}.graph-export-container{position:relative}.graph-export-menu{position:absolute;top:100%;left:0;margin-top:4px;background:white;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 8px #00000026;overflow:hidden;min-width:180px}.graph-export-menu-item{display:block;width:100%;background:white;border:none;padding:10px 12px;font-size:12px;text-align:left;cursor:pointer;transition:background .2s;white-space:nowrap}.graph-export-menu-item:hover{background:#f5f5f5}.graph-export-menu-item:active{background:#eeeeee}.graph-export-menu-item:not(:last-child){border-bottom:1px solid #e0e0e0}.graph-zoom-indicator{background:rgba(255,255,255,.9);backdrop-filter:blur(4px);border:1px solid #e0e0e0;border-radius:4px;color:#64748b;padding:6px 10px;font-size:11px;font-weight:600;font-family:monospace;box-shadow:0 2px 4px #0000001a;min-width:48px;text-align:center}.graph-node{cursor:pointer;transition:transform .15s ease,filter .15s ease;stroke:#fff;stroke-width:2.5;filter:drop-shadow(0 3px 6px rgba(0,0,0,.15))}.graph-node-group.hovered .graph-node{filter:brightness(1.15) drop-shadow(0 4px 12px rgba(0,0,0,.25));stroke-width:3}.graph-node.signal{fill:#2196f3}.graph-node.computed{fill:#ff9800}.graph-node.effect{fill:#4caf50}.graph-node.component{fill:#9c27b0}.graph-link{stroke:#94a3b8;stroke-width:2;fill:none;transition:stroke .2s,stroke-width .2s}.graph-link.highlighted{stroke:#673ab7;stroke-width:3}.graph-text{fill:#fff;text-anchor:middle;dominant-baseline:central;font-size:12px;font-weight:600;pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:.2px}.graph-tooltip{position:absolute;background:#1e293b;color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;box-shadow:0 8px 24px #00000040;z-index:1000;pointer-events:none;transform:translateY(-50%);max-width:280px;animation:tooltipFadeIn .15s ease-out}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(-4px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.tooltip-header{margin-bottom:6px}.tooltip-type{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tooltip-type.signal{background:#2196f3}.tooltip-type.computed{background:#ff9800}.tooltip-type.effect{background:#4caf50}.tooltip-type.component{background:#9c27b0}.tooltip-name{font-size:14px;font-weight:600;margin-bottom:4px;word-break:break-word}.tooltip-id{color:#94a3b8;font-size:11px;font-family:monospace}.graph-legend{position:absolute;top:16px;right:16px;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px;font-size:12px;box-shadow:0 4px 12px #00000014}.legend-item{display:flex;align-items:center;gap:10px;margin-bottom:8px}.legend-item:last-child{margin-bottom:0}.legend-color{width:14px;height:14px;border-radius:50%;box-shadow:0 2px 4px #00000026}.component-boundary{transition:all .2s ease}.component-boundary:hover{fill:#6495ed26;stroke:#6495ed80}.component-label{user-select:none;pointer-events:none}.graph-empty{display:flex;align-items:center;justify-content:center;height:100%;text-align:center;color:#666}.graph-toast{position:absolute;top:16px;right:16px;background:#323232;color:#fff;padding:12px 16px;border-radius:4px;font-size:13px;font-weight:500;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideInFade .3s ease-out}@keyframes slideInFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.tree-node{margin-bottom:4px}.tree-node-content{display:flex;align-items:flex-start;gap:4px}.collapse-button{background:none;border:none;color:#666;cursor:pointer;font-size:12px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0;margin-top:8px;flex-shrink:0;transition:color .2s}.collapse-button:hover{color:#333;background:#f0f0f0;border-radius:2px}.collapse-spacer{width:16px;height:16px;flex-shrink:0;margin-top:8px}.update-content{flex:1;min-width:0}.tree-children{margin-left:20px;border-left:1px solid #e0e0e0;padding-left:4px;margin-top:4px}.tree-children .tree-node:last-child{margin-bottom:0}.tree-node .update-item{margin-bottom:0}@media (max-width: 600px){.header{flex-direction:column;gap:8px;align-items:stretch}.header-title,.header-controls{justify-content:center}.graph-legend{position:static;margin:16px}.tree-children{margin-left:12px}}.animation{position:absolute;left:0;top:52px;bottom:0;width:100%;background:#222;color:#888;text-rendering:optimizeSpeed;touch-action:none;overflow:hidden}.circle{position:absolute;left:0;top:0;width:8px;height:8px;margin:-5px 0 0 -5px;border:2px solid #f00;border-radius:50%;transform-origin:50% 50%;transition:all .25s ease;transition-property:width,height,margin;pointer-events:none;overflow:hidden;font-size:9px;line-height:25px;text-indent:15px;white-space:nowrap}.circle.label{overflow:visible}.circle.big{width:24px;height:24px;margin:-13px 0 0 -13px}.circle>.label{position:absolute;left:0;top:0;z-index:10}
