:root{font-family: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}}#root{max-width:100%;margin:0;padding:0;text-align:center;width:100%}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.App{text-align:center;min-height:100vh;display:flex;flex-direction:column;background-color:#fff;padding:0;width:100%}.container{display:flex;flex-direction:row;align-items:flex-start;gap:24px;width:100%;margin:0;padding:0 24px;box-sizing:border-box;justify-content:center}.source-area{flex:1;max-width:400px;min-width:320px;padding:24px;background-color:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin-right:24px;box-sizing:border-box}.draggable-circle{--hitbox-radius: 28px;--hint-radius: 49px;--node-color: #4caf50;width:calc(var(--hint-radius) * 2);height:calc(var(--hint-radius) * 2);position:relative;cursor:grab;transition:all .2s ease}.draggable-circle:before{content:"";position:absolute;width:calc(var(--hint-radius) * 2);height:calc(var(--hint-radius) * 2);top:50%;left:50%;transform:translate(-50%,-50%);border:2px dashed var(--node-color);border-radius:50%;transition:all .2s ease}.draggable-circle:after{content:"";position:absolute;width:calc(var(--hitbox-radius) * 2);height:calc(var(--hitbox-radius) * 2);top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--node-color);border-radius:50%;transition:all .2s ease}.draggable-circle-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:600;z-index:1}.draggable-circle:hover:after{transform:translate(-50%,-50%) scale(1.05)}.draggable-circle:active{cursor:grabbing}.drop-zone{width:340px;height:645px;border:2px dashed #e0e0e0;border-radius:12px;position:relative;background-color:#fff;box-shadow:0 4px 6px #0000000d;transition:all .3s ease}.drop-zone.drag-over{border-color:var(--node-color);background-color:#4caf500d;box-shadow:0 6px 12px #00000014}.node{--hitbox-radius: 28px;--hint-radius: 49px;--node-color: #4caf50;position:absolute;width:calc(var(--hint-radius) * 2);height:calc(var(--hint-radius) * 2);transition:all .2s ease;cursor:grab}.node:before{content:"";position:absolute;width:calc(var(--hint-radius) * 2);height:calc(var(--hint-radius) * 2);top:50%;left:50%;transform:translate(-50%,-50%);border:2px dashed var(--node-color);border-radius:50%}.node:after{content:"";position:absolute;width:calc(var(--hitbox-radius) * 2);height:calc(var(--hitbox-radius) * 2);top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--node-color);border-radius:50%}.node-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:14px;font-weight:600;z-index:1}.button-row{display:flex;gap:12px;margin:24px 0}.undo-button{flex:1;padding:12px 20px;background-color:#fff2f2;border:none;border-radius:8px;cursor:pointer;font-weight:500;color:#ff6b6b;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;font-size:14px}.undo-button:hover:not(:disabled){background-color:#ffe0e0}.undo-button:disabled{opacity:.6;cursor:not-allowed}.undo-button .button-icon{width:16px;height:16px;stroke:#ff6b6b}.clear-button{flex:1;padding:12px 20px;background-color:#fff8f0;border:none;border-radius:8px;cursor:pointer;font-weight:500;color:#ff9f43;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;font-size:14px}.clear-button:hover:not(:disabled){background-color:#fff0e0}.clear-button:disabled{opacity:.6;cursor:not-allowed}.clear-button .button-icon{width:16px;height:16px;stroke:#ff9f43}h1{color:#333;margin-bottom:20px;width:100%}p{color:#666;margin-top:10px;font-size:14px}.controls{overflow:hidden;max-height:0;opacity:0;transition:max-height .3s ease,opacity .3s ease,margin-top .3s ease}.controls.expanded{max-height:500px;opacity:1;margin-top:20px}.dimension-control{display:flex;align-items:center;gap:8px;margin-bottom:12px;background-color:#f5f5f5;padding:8px 12px;border-radius:6px;box-shadow:0 1px 3px #0000001a}.dimension-control label{font-weight:600;color:#333;min-width:100px;text-align:left}.dimension-control input{width:70px;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:14px;color:#333;background-color:#fff}.dimension-control input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf5033}.dimension-control span{color:#666;font-weight:500}.dimension-control input[type=color]{width:70px;height:30px;padding:0;border:1px solid #ccc;border-radius:4px;cursor:pointer}.dimension-control input[type=color]:focus{outline:none;border-color:var(--node-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--node-color) 20%,transparent)}.node-types{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.node-type{display:flex;align-items:center;gap:20px;padding:16px;background-color:#f8f9fa;border-radius:12px;transition:all .2s ease}.node-type:hover{transform:translate(4px);background-color:#f3f4f6}.node-type-info{display:flex;flex-direction:column;align-items:flex-start;gap:12px}.node-type p{margin:0;font-weight:500;color:#1a1a1a;font-size:16px}.toggle-controls{width:100%;padding:12px;background-color:#f5f5f5;border:none;border-radius:8px;cursor:pointer;font-weight:600;color:#333;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s ease,transform .2s ease}.toggle-controls:hover{background-color:#eee;transform:translateY(-1px)}.toggle-controls svg{transition:transform .3s ease}.toggle-controls.expanded svg{transform:rotate(180deg)}.color-control{display:flex;align-items:center;gap:12px;position:relative}.color-control input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:42px;height:42px;padding:0;border:none;border-radius:50%;cursor:pointer;background:none;position:relative}.color-control input[type=color]::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:50%}.color-control input[type=color]::-webkit-color-swatch{border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0000001a,0 0 0 1px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.color-control input[type=color]::-moz-color-swatch{border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0000001a,0 0 0 1px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.color-control input[type=color]:hover::-webkit-color-swatch{transform:scale(1.05);box-shadow:0 4px 8px #00000026,0 0 0 1px #0000001a}.color-control input[type=color]:hover::-moz-color-swatch{transform:scale(1.05);box-shadow:0 4px 8px #00000026,0 0 0 1px #0000001a}.color-control input[type=color]:focus{outline:none}.color-control input[type=color]:focus::-webkit-color-swatch{box-shadow:0 4px 8px #00000026,0 0 0 3px #0000001a}.color-control input[type=color]:focus::-moz-color-swatch{box-shadow:0 4px 8px #00000026,0 0 0 3px #0000001a}.preview-json-button{width:100%;padding:12px 20px;background-color:#e3f2fd;color:#1976d2;border:none;border-radius:8px;font-weight:500;font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;margin-top:12px}.preview-json-button:hover{background-color:#bbdefb;transform:translateY(-1px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:800px;width:90%;max-height:80vh;overflow-y:auto;position:relative;text-align:left}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.modal-close:hover{color:#333}.json-preview{background-color:#f5f5f5;padding:16px;border-radius:8px;font-family:Courier New,Courier,monospace;white-space:pre;overflow-x:auto;font-size:14px;line-height:1.5;color:#333;text-align:left;width:100%;box-sizing:border-box}.button-group{display:flex;gap:10px;margin-top:10px}.export-button{padding:10px 20px;background-color:#4caf50;border:none;border-radius:8px;cursor:pointer;font-weight:500;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;font-size:14px}.export-button:hover{background-color:#43a047;transform:translateY(-1px)}.export-button:disabled{background-color:#e0e0e0;cursor:not-allowed;transform:none}.import-button{padding:10px 20px;background-color:#ff9800;border:none;border-radius:8px;cursor:pointer;font-weight:500;color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;font-size:14px}.import-button:hover{background-color:#f57c00;transform:translateY(-1px)}.import-input{display:none}.confirm-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-content{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 12px #00000026;max-width:400px;width:90%;text-align:center}.confirm-message{margin-bottom:24px;color:#1a1a1a;font-size:16px;font-weight:500}.confirm-buttons{display:flex;gap:12px;justify-content:center}.confirm-button{padding:10px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;border:none;display:flex;align-items:center;gap:8px}.confirm-button .button-icon{width:16px;height:16px}.confirm-button.cancel{background-color:#f5f5f5;color:#666}.confirm-button.cancel:hover{background-color:#eee;transform:translateY(-1px)}.confirm-button.cancel .button-icon{stroke:#666}.confirm-button.confirm{background-color:#ef5350;color:#fff}.confirm-button.confirm:hover{background-color:#e53935;transform:translateY(-1px)}.confirm-button.confirm .button-icon{stroke:#fff}.navbar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background-color:#fff;border-bottom:1px solid #eaeaea;margin-bottom:32px;width:100%;box-sizing:border-box}.navbar-title{font-size:24px;font-weight:600;color:#1a1a1a;margin:0}.navbar-buttons{display:flex;gap:12px}.button-icon{width:18px;height:18px}.export-button .button-icon,.import-button .button-icon{stroke:#fff}.preview-json-button .button-icon{stroke:#1976d2}.filename-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.filename-content{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 12px #00000026;max-width:400px;width:90%;text-align:center}.filename-message{margin-bottom:20px;color:#1a1a1a;font-size:16px;font-weight:500}.filename-input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:20px;box-sizing:border-box}.filename-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.filename-buttons{display:flex;gap:12px;justify-content:center}.filename-button{padding:10px 24px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;border:none;display:flex;align-items:center;gap:8px}.filename-button.cancel{background-color:#f5f5f5;color:#666}.filename-button.cancel:hover{background-color:#eee}.filename-button.confirm{background-color:#4caf50;color:#fff}.filename-button.confirm:hover{background-color:#43a047}.node.dragging{opacity:.7;cursor:grabbing}
