*{margin:0;padding:0;box-sizing:border-box}.app{display:flex;flex-direction:column;height:100vh;background-color:#f0f0f0}.header{background-color:#2c3e50;color:#fff;padding:1rem;display:flex;justify-content:space-between;align-items:center}.header button{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.header button:hover{background-color:#2980b9}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:250px;background-color:#fff;padding:1rem;border-right:1px solid #ddd;display:flex;flex-direction:column;box-shadow:2px 0 5px #0000001a}.add-block-btn{padding:.5rem;margin-bottom:1rem;background-color:#2ecc71;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.add-block-btn:hover{background-color:#27ae60}.tree-view{flex:1;overflow-y:auto}.block-item{margin-bottom:.5rem;border:1px solid #ddd;border-radius:4px}.block-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background-color:#f8f9fa;cursor:pointer;border-radius:4px 4px 0 0}.block-header:hover{background-color:#e9ecef}.block-actions button{margin-left:.5rem;padding:.25rem .5rem;background-color:#6c757d;color:#fff;border:none;border-radius:2px;cursor:pointer;font-size:.8rem}.block-actions button:hover{background-color:#5a6268}.block-children{padding:.5rem .5rem .5rem 1rem;background-color:#fff}.child-item{padding:.25rem;margin:.25rem 0;background-color:#f8f9fa;border-radius:2px;font-size:.9rem}.canvas{flex:1;position:relative;background-color:#fff;width:1000px;height:800px;margin:1rem;border:1px solid #ddd;overflow:hidden;box-shadow:0 0 10px #0000001a}.block{border:2px solid #3498db;background-color:#3498db1a;cursor:move;border-radius:4px}.block.selected{border-color:#2ecc71;box-shadow:0 0 0 2px #2ecc714d}.child-element{cursor:move;background-color:#fff;border:1px solid #ddd;border-radius:2px;-webkit-user-select:none;user-select:none}.child-element.text{padding:.5rem;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa}.resize-handle{position:absolute;right:0;bottom:0;width:10px;height:10px;background-color:#666;cursor:se-resize;border-radius:0 0 2px}.json-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.json-content{background-color:#fff;padding:2rem;border-radius:8px;max-width:80%;max-height:80%;width:600px;display:flex;flex-direction:column;gap:1rem}.json-content h2{color:#2c3e50;margin-bottom:1rem}.json-scroll{overflow:auto;max-height:400px;background-color:#f8f9fa;padding:1rem;border-radius:4px;border:1px solid #ddd}.json-content pre{white-space:pre-wrap;font-family:monospace;font-size:.9rem;color:#2c3e50}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
