: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:#7a0081;text-decoration:inherit}a:hover{color:#7a0081}body{margin:0;min-width:100vw;min-height:100vh;width:100vw;height:100vh;overflow:hidden}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}.card{padding:2em}#app{max-width:100vw;width:100vw;height:100vh;margin:0;padding:0;text-align:center}drawing-canvas,.drawing-canvas{position:relative;width:100vw;height:calc(100vh - 100px);background:#fff;border:1px solid #ccc;margin:0 auto;box-sizing:border-box;overflow:hidden}.grid-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;background-image:linear-gradient(to right,#e0e0e0 1px,transparent 1px),linear-gradient(to bottom,#e0e0e0 1px,transparent 1px);background-size:25px 25px;z-index:1;opacity:.7}.export-bar{position:fixed;left:0;right:0;bottom:0;background:#222;padding:.5rem 0;display:flex;justify-content:center;gap:1rem;z-index:100}.export-bar button{color:#fff;background:#5e5e5e;border:1px solid #444}.toolbar-bottom{position:fixed;left:0;right:0;bottom:0;background:#222;display:flex;flex-direction:row;align-items:center;justify-content:center;padding:.8rem 0;z-index:10;gap:1rem;border:none}.about-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:300px;text-align:center}.about-dialog button{margin-top:1rem;padding:.5rem 1rem;background-color:#7a0081;color:#fff;border:none;border-radius:4px;cursor:pointer}.btn{border:none;border-radius:4px;padding:.75rem 1.5rem;cursor:pointer;font-weight:500;transition:all .2s ease;font-family:inherit}.btn-primary{background-color:#7a0081;color:#fff}.btn-primary:hover{background-color:#5a006b}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-toolbar{background-color:#333;color:#fff;width:90px;margin:1rem 0;font-size:1rem;padding:.7em .5em}.btn-toolbar:hover{background-color:#7b008161}.dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;color:#333;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000}.dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.toolbar[data-v-2a18b77e]{position:absolute;bottom:0;left:0;width:100%;display:flex;justify-content:space-around;background-color:#f8f8f8;border-top:none;padding:10px}.toolbar-bottom[data-v-2a18b77e]{position:fixed;left:0;right:0;bottom:0;background:#222;display:flex;flex-direction:row;align-items:center;justify-content:center;padding:1.6rem 0;z-index:100;gap:1rem;border:none}.toolbar-bottom button[data-v-2a18b77e],.toolbar-bottom label[data-v-2a18b77e]{color:#fffffffd;background:#333;border:none;border-radius:6px;font-size:1rem;padding:.7em .5em;cursor:pointer;transition:background .2s}.toolbar-bottom button[data-v-2a18b77e]:hover,.toolbar-bottom label[data-v-2a18b77e]:hover{background:#7b008155}button.active[data-v-2a18b77e]{background-color:var(--active-bg)}.export-buttons[data-v-99df9f8b]{display:flex;gap:1rem;flex-direction:column;align-items:center}.export-status[data-v-99df9f8b]{margin-top:.5rem;padding:.5rem;border-radius:4px;font-size:.9rem}.export-status.error[data-v-99df9f8b]{background-color:#fee;color:#c33}.export-status[data-v-99df9f8b]:not(.error){background-color:#efe;color:#393}button[data-v-99df9f8b]:disabled{opacity:.6;cursor:not-allowed}.status-message[data-v-0da48135]{margin-top:1rem;padding:.5rem;border-radius:4px;font-size:.9rem;background-color:#e8f5e8;color:#2d5a2d}.status-message.error[data-v-0da48135]{background-color:#fee;color:#c33}.spinner[data-v-0da48135]{display:inline-block;margin-right:.5rem}button[data-v-0da48135]:disabled{opacity:.6;cursor:not-allowed}input[data-v-0da48135]:disabled,select[data-v-0da48135]:disabled{opacity:.6;cursor:not-allowed}.import-dialog-overlay[data-v-d87c7dcb]{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.import-dialog[data-v-d87c7dcb]{background:#fff;border-radius:8px;padding:2rem;min-width:450px;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.import-dialog h3[data-v-d87c7dcb]{margin:0 0 1.5rem;text-align:center;color:#333}.upload-section[data-v-d87c7dcb]{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;padding:1.5rem;border:2px dashed #ddd;border-radius:8px;background-color:#f9f9f9;transition:all .3s ease}.upload-section.drag-over[data-v-d87c7dcb]{border-color:#7a0081;background-color:#f0e6f7;transform:scale(1.02)}.upload-button[data-v-d87c7dcb]{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;cursor:pointer;transition:all .3s ease;color:#666}.upload-button[data-v-d87c7dcb]:hover,.upload-section.drag-over .upload-button[data-v-d87c7dcb]{color:#7a0081}.file-info[data-v-d87c7dcb]{font-size:.9rem;color:#3e3e3e;margin-top:.5rem}.current-files[data-v-d87c7dcb]{margin-bottom:1.5rem}.file-item[data-v-d87c7dcb]{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid #ddd;border-radius:8px;margin-bottom:.5rem;background-color:#f8f9fa}.file-preview[data-v-d87c7dcb]{width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:4px;overflow:hidden}.preview-thumb[data-v-d87c7dcb]{width:100%;height:100%;object-fit:cover}.dst-preview[data-v-d87c7dcb]{width:100%;height:100%;background-color:#7a0081;color:#898989;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.file-info[data-v-d87c7dcb]{flex:1}.file-info strong[data-v-d87c7dcb]{display:block;margin-bottom:.25rem}.file-info p[data-v-d87c7dcb]{margin:0;font-size:.8rem;color:#666}.remove-btn[data-v-d87c7dcb]{background-color:#dc3545;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.remove-btn[data-v-d87c7dcb]:hover{background-color:#c82333}.empty-state[data-v-d87c7dcb]{text-align:center;padding:2rem;color:#666;font-style:italic}.scale-controls[data-v-d87c7dcb]{margin-bottom:1.5rem;padding:1rem;border:1px solid #ddd;border-radius:8px;background-color:#f8f9fa}.scale-controls h4[data-v-d87c7dcb]{margin:0 0 1rem;color:#333}.scale-slider[data-v-d87c7dcb]{display:flex;flex-direction:column;gap:1rem}.slider-container[data-v-d87c7dcb]{display:flex;align-items:center;gap:1rem}.slider-container input[type=range][data-v-d87c7dcb]{flex:1}.dialog-buttons[data-v-d87c7dcb]{display:flex;justify-content:center;margin-top:1.5rem}.close-btn[data-v-d87c7dcb]{background-color:#6c757d;color:#fff;border:none;padding:.75rem 2rem;border-radius:4px;cursor:pointer;font-weight:500}.close-btn[data-v-d87c7dcb]:hover{background-color:#5a6268}.machine-control[data-v-692fa33b]{padding:1rem;border:1px solid #ddd;border-radius:8px;background:#f9f9f9;min-width:280px}.machine-status[data-v-692fa33b]{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.status-indicator[data-v-692fa33b]{width:12px;height:12px;border-radius:50%}.machine-actions[data-v-692fa33b]{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.machine-actions button[data-v-692fa33b]{padding:.5rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-primary[data-v-692fa33b]{background-color:#007bff;color:#fff}.btn-secondary[data-v-692fa33b]{background-color:#6c757d;color:#fff}.btn-success[data-v-692fa33b]{background-color:#28a745;color:#fff}.btn-danger[data-v-692fa33b]{background-color:#dc3545;color:#fff}.machine-position[data-v-692fa33b]{margin-top:1rem;padding-top:1rem;border-top:1px solid #ddd}.machine-position h4[data-v-692fa33b]{margin:0 0 .5rem;font-size:.9rem}.position-display[data-v-692fa33b]{display:flex;flex-direction:column;gap:.25rem;font-family:monospace;font-size:.8rem}.stitch-toolbar[data-v-f20c9242]{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#f0f0f0;padding:8px;border-radius:8px;box-shadow:0 2px 5px #0003;display:flex;gap:10px;z-index:10}button[data-v-f20c9242]{padding:8px 16px;border:1px solid #ccc;background-color:#fff;cursor:pointer;border-radius:4px}button.active[data-v-f20c9242]{background-color:#7a0081;color:#fff;border-color:#7a0081}button[data-v-f20c9242]:disabled{background-color:#e0e0e0;color:#999;cursor:not-allowed}#app-container{position:relative;width:100vw;height:100vh}.side-toolbar{position:fixed;top:0;left:0;height:100vh;width:150px;background:#222;display:flex;flex-direction:column;align-items:center;padding-top:2rem;z-index:10;transition:transform .3s cubic-bezier(.4,2,.6,1),opacity .3s}.side-toolbar.closed{transform:translate(-100%);opacity:.2;pointer-events:none}.toolbar-toggle{position:fixed;top:1rem;left:150px;z-index:20;background:#7a0081;color:#fff;border:none;border-radius:0 6px 6px 0;font-size:1.5rem;padding:.2em .5em;cursor:pointer;transition:background .2s}.toolbar-toggle:hover{background:#b62b8c}.side-toolbar button{margin:1rem 0;width:90px;color:#fff;background:#333;border:none;border-radius:6px;font-size:1rem;padding:.7em .5em;cursor:pointer;transition:background .2s}.side-toolbar button:hover{background:#7b008161}.side-toolbar .export-bar{margin-top:2rem}.toast-notification{position:fixed;top:1rem;right:1rem;color:#fff;padding:1rem;border-radius:5px;z-index:100;display:flex;align-items:center;box-shadow:0 2px 10px #0003}.toast-notification.error{background:#f44336}.toast-notification.success{background:#4caf50}.toast-notification.info{background:#2196f3}.toast-notification button{margin-left:1rem;background:none;border:none;color:#fff;font-weight:700;cursor:pointer;font-size:1.2rem}.machine-section{margin:1rem 0}.machine-panel{position:absolute;left:160px;top:0;background:#fff;border:1px solid #ddd;border-radius:8px;padding:1rem;min-width:300px;box-shadow:0 4px 12px #00000026;z-index:100}.drawing-canvas[data-v-3aa35aee]{width:100vw;height:calc(100vh - 100px);position:relative;overflow:hidden}.stitch-control[data-v-3aa35aee]{position:absolute;bottom:45px;right:20px;background:#fffffff2;border:1px solid #ddd;border-radius:8px;padding:1rem;box-shadow:0 2px 10px #0000001a;z-index:10;min-width:200px;pointer-events:auto}.stitch-scale label[data-v-3aa35aee]{display:block;font-weight:600;margin-bottom:.5rem;color:#333;font-size:.9rem}.scale-container[data-v-3aa35aee]{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.scale-label[data-v-3aa35aee]{font-size:.8rem;color:#666;min-width:35px;text-align:center}.scale-slider[data-v-3aa35aee]{flex:1;height:6px;background:#ddd;border-radius:3px;outline:none;cursor:pointer}.scale-slider[data-v-3aa35aee]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:#7a0081;border-radius:50%;cursor:pointer}.scale-slider[data-v-3aa35aee]::-moz-range-thumb{width:18px;height:18px;background:#7a0081;border-radius:50%;cursor:pointer;border:none}.scale-value[data-v-3aa35aee]{text-align:center;font-size:.8rem;color:#7a0081;font-weight:600;padding:.2rem .5rem;background:#f8f0f9;border-radius:4px}.background-image[data-v-3aa35aee]{position:absolute;top:0;left:0;width:100%;height:100%;background-size:contain;background-repeat:no-repeat;background-position:center center;z-index:0;pointer-events:none}svg[data-v-3aa35aee]{display:block;position:relative;z-index:1}.import-overlay[data-v-3aa35aee]{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;display:flex;align-items:center;justify-content:center;z-index:100}.import-message[data-v-3aa35aee]{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:1.2rem}
