.move-box[data-v-b5df23a9]{position:absolute;left:0;top:0;border:2px solid var(--accent);box-shadow:0 0 0 9999px #0ea5e905;transform-origin:center;z-index:6;cursor:grab}.move-box-control[data-v-b5df23a9],.move-box-rotate[data-v-b5df23a9]{position:absolute;padding:0;border:none}.move-box-control[data-v-b5df23a9]{width:14px;height:14px;border:2px solid #fff;border-radius:50%;background:var(--accent);box-shadow:0 4px 10px #0ea5e94d}.control-lt[data-v-b5df23a9]{left:-8px;top:-8px}.control-rt[data-v-b5df23a9]{right:-8px;top:-8px}.control-lb[data-v-b5df23a9]{left:-8px;bottom:-8px}.control-rb[data-v-b5df23a9]{right:-8px;bottom:-8px}.control-ct[data-v-b5df23a9]{left:50%;top:-8px;width:14px;height:8px;border-radius:6px;transform:translate(-50%)}.control-cb[data-v-b5df23a9]{left:50%;bottom:-8px;width:14px;height:8px;border-radius:6px;transform:translate(-50%)}.control-lc[data-v-b5df23a9]{left:-8px;top:50%;width:8px;height:14px;border-radius:6px;transform:translateY(-50%)}.control-rc[data-v-b5df23a9]{right:-8px;top:50%;width:8px;height:14px;border-radius:6px;transform:translateY(-50%)}.move-box-rotate[data-v-b5df23a9]{left:50%;bottom:-46px;width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:0 0 4px #0000004d;color:#595959;transform:translate(-50%);display:flex;align-items:center;justify-content:center}.move-box-rotate svg[data-v-b5df23a9]{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}[data-v-b3eee45d],[data-v-b3eee45d]:before,[data-v-b3eee45d]:after{box-sizing:border-box}.app[data-v-b3eee45d]{--toolbar-h: 64px;--statusbar-h: 32px;--palette-w: 56px;--props-w: 300px;display:grid;grid-template-rows:var(--toolbar-h) 1fr var(--statusbar-h);height:100vh;width:100%;background:var(--bg);overflow:hidden}.app.embedded[data-v-b3eee45d]{grid-template-rows:1fr;height:min(calc(100vh - var(--nav-height, 76px) - 48px),900px);min-height:0;max-height:calc(100vh - var(--nav-height, 76px) - 36px);border:none;border-radius:0;box-shadow:none;background:transparent}.app.embedded .main-area[data-v-b3eee45d]{grid-template-columns:minmax(0,.92fr) minmax(360px,.82fr);grid-template-rows:auto minmax(0,1fr) auto;gap:18px;padding:0;background:transparent}.app.embedded .panel-3d[data-v-b3eee45d]{grid-column:1;grid-row:1 / 4;min-height:0;border-radius:24px;overflow:hidden;box-shadow:0 24px 80px #0a0a0a14}.app.embedded .panel-3d[data-v-b3eee45d]{background:#fffcf7eb}.app.embedded .panel-header-dark[data-v-b3eee45d]{border-bottom:1px solid rgba(87,80,74,.12);background:#fffcf7f0}.app.embedded .three-bg-picker[data-v-b3eee45d]{border-color:#57504a2e;box-shadow:inset 0 0 0 2px #ffffffb8}.app.embedded .view-btn[data-v-b3eee45d]{color:var(--text-secondary)}.app.embedded .view-btn[data-v-b3eee45d]:hover{background:var(--bg-warm);color:var(--text)}.app.embedded .view-btn.active[data-v-b3eee45d]{background:var(--accent-light);color:var(--accent)}.app.embedded .tool-palette[data-v-b3eee45d]{grid-column:2;grid-row:1;width:100%;min-width:0;min-height:60px;flex-direction:row;justify-content:center;padding:8px 10px;border-radius:18px;border:1px solid rgba(87,80,74,.14);background:#fffcf7eb;box-shadow:0 16px 48px #0a0a0a0f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app.embedded .tool-sep[data-v-b3eee45d]{width:1px;height:28px;margin:0 6px;background:var(--border)}.app.embedded .tool-btn[data-v-b3eee45d]{width:42px;height:42px;color:var(--text-secondary)}.app.embedded .tool-btn[data-v-b3eee45d]:hover{background:var(--bg-warm);color:var(--text)}.app.embedded .tool-btn.active[data-v-b3eee45d]{background:var(--accent-light);color:var(--accent)}.app.embedded .tool-btn[data-v-b3eee45d]:after{display:none}.app.embedded .shape-picker-card[data-v-b3eee45d]{left:auto;right:10px;top:calc(100% + 10px);z-index:80}.app.embedded .panel-2d[data-v-b3eee45d]{grid-column:2;grid-row:2;border:1px solid var(--border);border-radius:22px;overflow:hidden;box-shadow:0 18px 54px #0a0a0a0f}.app.embedded .panel-header[data-v-b3eee45d]{height:34px;padding:0 12px}.app.embedded .canvas-area[data-v-b3eee45d]{flex:1 1 auto;min-height:0}.app.embedded .embedded-render-panel[data-v-b3eee45d]{grid-column:2;grid-row:3}.toolbar[data-v-b3eee45d]{display:flex;align-items:center;justify-content:space-between;height:var(--toolbar-h);padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);z-index:10;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.toolbar[data-v-b3eee45d]::-webkit-scrollbar{display:none}.toolbar-group[data-v-b3eee45d]{display:flex;align-items:center;gap:8px}.toolbar-sep[data-v-b3eee45d]{width:1px;height:20px;background:var(--border);margin:0 4px}.share-popover-wrap[data-v-b3eee45d]{position:relative}.share-popover[data-v-b3eee45d]{width:480px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:10px;border:1px solid var(--border);border-radius:14px;background:#fffaf5fa;box-shadow:0 20px 48px #2c1b0d2e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);z-index:40}.share-popover-floating[data-v-b3eee45d]{position:fixed;z-index:1200}.share-link-field[data-v-b3eee45d]{min-width:0;height:40px;display:flex;align-items:center;padding:0 12px;border-radius:10px;background:#fff;border:1px solid rgba(149,118,90,.18);color:var(--text);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.share-copy-btn[data-v-b3eee45d]{height:40px;padding:0 16px;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:12px;font-weight:700;cursor:pointer}.share-copy-btn[data-v-b3eee45d]:hover{background:var(--accent-hover)}.btn-icon[data-v-b3eee45d],.btn-outline[data-v-b3eee45d],.btn-accent[data-v-b3eee45d],.btn-outline-sm[data-v-b3eee45d],.zoom-dropdown[data-v-b3eee45d],.tool-btn[data-v-b3eee45d],.panel-ctrl-btn[data-v-b3eee45d],.view-btn[data-v-b3eee45d]{border:none;cursor:pointer;font:inherit}.btn-icon[data-v-b3eee45d]{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;color:var(--text-secondary);transition:background .15s,color .15s}.btn-icon[data-v-b3eee45d]:hover{background:var(--bg-warm);color:var(--text)}.btn-icon svg[data-v-b3eee45d],.btn-outline svg[data-v-b3eee45d],.btn-accent svg[data-v-b3eee45d],.zoom-dropdown svg[data-v-b3eee45d],.tool-btn svg[data-v-b3eee45d],.panel-ctrl-btn svg[data-v-b3eee45d],.status-pill svg[data-v-b3eee45d],.auth-close svg[data-v-b3eee45d]{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.project-name[data-v-b3eee45d]{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:8px}.project-name[data-v-b3eee45d]:hover{background:var(--bg-warm)}.project-name input[data-v-b3eee45d]{width:190px;border:none;outline:none;background:transparent;color:var(--text);font-size:14px;font-weight:600}.status-pill[data-v-b3eee45d]{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;background:#e8f5ee;color:var(--success);font-size:11px;font-weight:500}.zoom-dropdown[data-v-b3eee45d],.btn-outline[data-v-b3eee45d],.btn-accent[data-v-b3eee45d],.btn-outline-sm[data-v-b3eee45d]{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:8px}.zoom-dropdown[data-v-b3eee45d]{padding:5px 10px;border:1px solid var(--border);background:var(--surface);font-size:12px;font-weight:500;color:var(--text-secondary)}.btn-outline[data-v-b3eee45d],.btn-outline-sm[data-v-b3eee45d]{border:1px solid var(--border);background:var(--surface);color:var(--text)}.btn-outline[data-v-b3eee45d]{padding:7px 14px;font-size:12px;font-weight:600}.btn-outline-sm[data-v-b3eee45d]{width:100%;padding:6px 12px;font-size:11px;font-weight:600;color:var(--text-secondary)}.btn-accent[data-v-b3eee45d]{padding:7px 16px;background:var(--accent);color:#fff;font-size:12px;font-weight:600}.btn-accent[data-v-b3eee45d]:hover{background:var(--accent-hover)}.btn-accent-block[data-v-b3eee45d]{width:100%}.embedded-render-panel[data-v-b3eee45d]{display:grid;gap:12px;min-width:0;padding:16px;border:1px solid rgba(87,80,74,.14);border-radius:22px;background:#fffcf7e6;box-shadow:0 18px 54px #0a0a0a0f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.embedded-render-sizes[data-v-b3eee45d]{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.render-size-btn[data-v-b3eee45d]{min-width:0;min-height:54px;display:grid;gap:2px;place-items:center;padding:8px 6px;border:1px solid var(--border);border-radius:14px;background:#ffffffc7;color:var(--text-secondary);font:inherit;cursor:pointer;transition:border-color .16s ease,background .16s ease,color .16s ease,box-shadow .16s ease}.render-size-btn strong[data-v-b3eee45d]{color:var(--text);font-size:13px;font-weight:800;line-height:1}.render-size-btn span[data-v-b3eee45d]{font-size:10px;font-weight:700;line-height:1.1}.render-size-btn[data-v-b3eee45d]:hover,.render-size-btn.active[data-v-b3eee45d]{border-color:var(--accent);background:var(--accent-light);color:var(--accent);box-shadow:0 10px 24px #c9a96e24}.embedded-render-btn[data-v-b3eee45d]{width:100%;min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:9px;border:none;border-radius:15px;background:#1f1a16;color:#fff;font:inherit;font-size:14px;font-weight:800;cursor:pointer;transition:transform .16s ease,background .16s ease,opacity .16s ease}.embedded-render-btn[data-v-b3eee45d]:hover:not(:disabled){transform:translateY(-1px);background:var(--accent)}.embedded-render-btn[data-v-b3eee45d]:disabled{opacity:.64;cursor:not-allowed}.embedded-render-btn svg[data-v-b3eee45d]{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.embedded-render-feedback[data-v-b3eee45d]{margin:0;padding:10px 12px;border-radius:12px;font-size:12px;line-height:1.45}.embedded-render-feedback.error[data-v-b3eee45d]{background:#ef44441a;color:#b91c1c}.embedded-render-feedback.success[data-v-b3eee45d]{background:#10b9811a;color:#047857}.avatar[data-v-b3eee45d]{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-light),#E8D5C8);border:2px solid var(--border-light);color:var(--accent);font-size:12px;font-weight:700}.main-area[data-v-b3eee45d]{display:grid;grid-template-columns:var(--palette-w) 1fr 1fr;min-height:0;overflow:hidden}.tool-palette[data-v-b3eee45d]{width:64px;background:#242220;display:flex;flex-direction:column;align-items:center;position:relative;padding:12px 0;gap:4px;z-index:50}.tool-btn[data-v-b3eee45d]{position:relative;width:46px;height:46px;padding:0;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#a09a94;transition:background .15s,color .15s}.tool-btn[data-v-b3eee45d]:hover{background:#3a3735;color:#e0dbd5}.tool-btn.active[data-v-b3eee45d]{background:var(--accent);color:#fff}.tool-btn svg[data-v-b3eee45d]{width:18px;height:18px;stroke-width:2.2;flex:0 0 18px}.tool-btn[data-v-b3eee45d]:after{content:attr(data-tip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background:var(--dark);color:#e0dbd5;font-size:11px;font-weight:500;padding:4px 10px;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s}.tool-btn[data-v-b3eee45d]:hover:after{opacity:1}.shape-picker-card[data-v-b3eee45d]{position:absolute;top:132px;left:calc(100% + 12px);width:220px;padding:14px;border:1px solid rgba(69,64,60,.92);border-radius:16px;background:#211e1cf5;box-shadow:0 18px 40px #00000047;z-index:30}.shape-picker-title[data-v-b3eee45d]{margin-bottom:10px;color:#f1e9e1;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.shape-picker-grid[data-v-b3eee45d]{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.shape-picker-item[data-v-b3eee45d]{display:flex;flex-direction:column;align-items:center;gap:8px;min-height:84px;padding:10px 8px;border:1px solid #4C4742;border-radius:12px;background:#2b2825;color:#e5dcd4;font-size:11px;font-weight:600}.shape-picker-item[data-v-b3eee45d]:hover{border-color:#6c665f;background:#34302d}.shape-picker-preview[data-v-b3eee45d]{position:relative;display:inline-block;width:34px;height:34px;color:var(--accent)}.preview-rectangle[data-v-b3eee45d]{border:2px solid currentColor;border-radius:8px}.preview-circle[data-v-b3eee45d]{border:2px solid currentColor;border-radius:50%}.preview-triangle[data-v-b3eee45d]:before{content:"";position:absolute;left:50%;top:4px;width:0;height:0;border-left:16px solid transparent;border-right:16px solid transparent;border-bottom:28px solid currentColor;transform:translate(-50%)}.preview-star[data-v-b3eee45d]:before{content:"★";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:28px;line-height:1}.preview-line[data-v-b3eee45d]:before{content:"";position:absolute;left:2px;right:2px;top:50%;border-top:4px solid currentColor;transform:translateY(-50%);border-radius:999px}.tool-sep[data-v-b3eee45d]{width:28px;height:1px;background:#3a3735;margin:8px 0}.panel-2d[data-v-b3eee45d],.panel-3d[data-v-b3eee45d]{display:flex;flex-direction:column;min-height:0;min-width:0}.panel-2d[data-v-b3eee45d]{background:var(--surface);border-right:1px solid var(--border)}.panel-3d[data-v-b3eee45d]{background:var(--dark)}.panel-header[data-v-b3eee45d],.panel-header-dark[data-v-b3eee45d]{display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 14px;flex-shrink:0}.panel-header[data-v-b3eee45d]{border-bottom:1px solid var(--border-light)}.panel-header-dark[data-v-b3eee45d]{border-bottom:1px solid #2E2B28}.panel-title[data-v-b3eee45d],.panel-title-dark[data-v-b3eee45d]{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px}.panel-title[data-v-b3eee45d]{color:var(--text-muted)}.panel-title-dark[data-v-b3eee45d]{color:#7a756f}.panel-controls[data-v-b3eee45d],.view-modes[data-v-b3eee45d]{display:flex;align-items:center;gap:2px}.three-bg-tools[data-v-b3eee45d]{display:flex;align-items:center;min-width:0}.three-bg-picker[data-v-b3eee45d]{position:relative;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#ffffffbf,#fff0 48%),var(--bg-color, #ffffff);border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 0 0 2px #0000002e;cursor:pointer;overflow:hidden}.three-bg-picker input[data-v-b3eee45d]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.panel-ctrl-btn[data-v-b3eee45d]{width:26px;height:26px;border-radius:4px;color:var(--text-muted)}.panel-ctrl-btn[data-v-b3eee45d]:hover{background:var(--bg-warm);color:var(--text-secondary)}.view-btn[data-v-b3eee45d]{padding:5px 9px;border-radius:4px;background:transparent;color:#8c8780;font-size:10px;font-weight:600}.view-btn[data-v-b3eee45d]:hover{background:#2b2825;color:#d8d0c8}.view-btn.active[data-v-b3eee45d]{background:#3a3735;color:#f5f0eb}.canvas-area[data-v-b3eee45d]{position:relative;flex:1;overflow:hidden;background-color:var(--surface);background-image:radial-gradient(circle,#DDD 1px,transparent 1px);background-size:20px 20px}.element-toolbar[data-v-b3eee45d]{position:absolute;left:50%;bottom:18px;z-index:12;transform:translate(-50%);pointer-events:none;max-width:calc(100% - 32px)}.element-toolbar-pill[data-v-b3eee45d]{display:flex;align-items:center;gap:10px;width:max-content;max-width:100%;padding:10px 14px;border:1px solid rgba(87,80,74,.22);border-radius:18px;background:#fffcf7eb;box-shadow:0 18px 45px #2d231829;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);pointer-events:auto;overflow:visible}.element-toolbar-type[data-v-b3eee45d]{flex:0 0 auto;padding:6px 10px;border-radius:999px;background:#f3e7d8;color:#8e5e34;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.element-toolbar-control[data-v-b3eee45d]{position:relative;flex:0 0 auto}.element-toolbar-icon[data-v-b3eee45d]{width:36px;height:36px;padding:0;border:1px solid rgba(87,80,74,.18);border-radius:12px;background:#fff;color:#5b544d;display:inline-flex;align-items:center;justify-content:center}.element-toolbar-icon.active[data-v-b3eee45d]{border-color:var(--accent);color:var(--accent);background:#0ea5e914}.element-toolbar-icon svg[data-v-b3eee45d]{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.element-toolbar-popover[data-v-b3eee45d]{position:absolute;left:50%;bottom:calc(100% + 12px);transform:translate(-50%);min-width:168px;padding:12px;border:1px solid rgba(87,80,74,.18);border-radius:14px;background:#fffffffa;box-shadow:0 18px 40px #2d231829}.element-toolbar-popover-title[data-v-b3eee45d]{margin-bottom:10px;color:var(--text-secondary);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.element-toolbar-popover strong[data-v-b3eee45d]{display:block;margin-top:8px;color:var(--text);font-size:11px;font-weight:700}.font-option-list[data-v-b3eee45d]{display:grid;gap:8px}.font-stepper[data-v-b3eee45d]{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:stretch}.toolbar-font-stepper[data-v-b3eee45d]{flex:0 0 auto}.toolbar-color-inline[data-v-b3eee45d]{flex:0 0 auto;width:36px;height:36px;border:1px solid rgba(87,80,74,.18);border-radius:999px;background:#fff;display:inline-flex;align-items:center;justify-content:center;overflow:hidden}.toolbar-color-inline input[type=color][data-v-b3eee45d]{width:100%;height:100%;padding:0;border:none;border-radius:999px;background:transparent;cursor:pointer}.font-stepper-box[data-v-b3eee45d]{display:flex;align-items:center;min-width:0;height:38px;padding:0 8px;border:1px solid var(--border);border-radius:10px;background:#fff}.font-stepper-input[data-v-b3eee45d]{width:52px;padding:0;border:none;background:transparent;color:var(--text);font:inherit;font-size:13px;font-weight:700;text-align:center;outline:none}.font-stepper-actions[data-v-b3eee45d]{display:grid;grid-template-rows:1fr 1fr;gap:4px}.font-stepper-actions button[data-v-b3eee45d]{width:34px;height:17px;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center}.font-stepper-actions svg[data-v-b3eee45d]{width:12px;height:12px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.font-option-btn[data-v-b3eee45d]{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);font-size:12px;text-align:left}.font-option-btn.active[data-v-b3eee45d]{border-color:var(--accent);color:var(--accent);background:#0ea5e914}.element-toolbar-field[data-v-b3eee45d]{display:flex;align-items:center;gap:8px;flex:0 0 auto;min-width:0;color:var(--text-secondary);font-size:11px;font-weight:600}.element-toolbar-field.compact[data-v-b3eee45d]{padding:0 2px}.element-toolbar-field.range[data-v-b3eee45d]{min-width:150px}.element-toolbar-field strong[data-v-b3eee45d]{color:var(--text);font-size:11px;font-weight:700;min-width:34px;text-align:right}.element-toolbar-field input[type=color][data-v-b3eee45d]{width:28px;height:28px;padding:2px;border:1px solid var(--border);border-radius:8px;background:#fff}.element-toolbar-delete[data-v-b3eee45d]{flex:0 0 auto;padding:8px 12px;border:none;border-radius:12px;background:#1f1a16;color:#f8f3ed;font:inherit;font-size:11px;font-weight:700}.hidden-input[data-v-b3eee45d]{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.pattern-stage[data-v-b3eee45d]{position:absolute;left:50%;top:50%;transform-origin:center center;transition:transform .18s ease}.pattern-stage.panning[data-v-b3eee45d]{transition:none}.editor-surface[data-v-b3eee45d]{position:relative;display:flex;align-items:center;justify-content:center;background:#ffffffb3;border:1px solid rgba(148,163,184,.26);border-radius:18px;box-shadow:0 18px 48px #0f172a14;overflow:hidden}.editor-surface.hand-mode[data-v-b3eee45d]{cursor:grab}.pattern-stage.panning .editor-surface.hand-mode[data-v-b3eee45d]{cursor:grabbing}.editor-surface.hand-mode[data-v-b3eee45d] .editor-node,.editor-surface.hand-mode[data-v-b3eee45d] .move-box,.editor-surface.hand-mode[data-v-b3eee45d] .move-box-handle{cursor:inherit!important}.pattern-svg-preview[data-v-b3eee45d]{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 18px 40px rgba(15,23,42,.08))}.pattern-hit-debug-canvas[data-v-b3eee45d]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;width:100%;height:100%;object-fit:contain;opacity:0;image-rendering:pixelated;pointer-events:none;mix-blend-mode:multiply}.pattern-piece-overlay[data-v-b3eee45d]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;width:100%;height:100%;pointer-events:none;overflow:visible}.pattern-piece-hover[data-v-b3eee45d]{fill:#fff0;stroke:transparent;stroke-width:2;pointer-events:none;vector-effect:non-scaling-stroke;cursor:default;transition:fill .12s ease,stroke .12s ease,filter .12s ease}.pattern-piece-hover.active[data-v-b3eee45d]{fill:#fff0;stroke:#1e90fff2;filter:drop-shadow(0 8px 18px rgba(30,144,255,.18))}.pattern-fallback-grid[data-v-b3eee45d]{width:100%;height:100%;display:grid;grid-template-columns:auto auto auto;grid-template-rows:auto auto;gap:18px;align-items:end}.piece[data-v-b3eee45d]{position:relative;cursor:pointer;transition:filter .15s}.piece[data-v-b3eee45d]:hover{filter:brightness(.97)}.piece.selected[data-v-b3eee45d]:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2px solid #4A90D9;border-radius:6px}.piece-front .piece-shape[data-v-b3eee45d],.piece-back .piece-shape[data-v-b3eee45d]{position:relative;width:140px;height:180px;background:linear-gradient(160deg,#f0d5c0,#e8c4ae);border:2px dashed #B8A898;border-radius:4px 4px 2px 2px}.piece-front .piece-shape[data-v-b3eee45d]{clip-path:polygon(8% 0%,35% 0%,38% 3%,62% 3%,65% 0%,92% 0%,100% 8%,100% 100%,0% 100%,0% 8%)}.piece-back .piece-shape[data-v-b3eee45d]{clip-path:polygon(8% 0%,38% 0%,42% 1.5%,58% 1.5%,62% 0%,92% 0%,100% 8%,100% 100%,0% 100%,0% 8%)}.piece-sleeve .piece-shape[data-v-b3eee45d]{width:70px;height:100px;background:linear-gradient(160deg,#f0d5c0,#e8c4ae);border:2px dashed #B8A898;border-radius:3px;clip-path:polygon(0% 0%,100% 12%,100% 100%,10% 100%)}.piece-sleeve.mirrored .piece-shape[data-v-b3eee45d]{clip-path:polygon(0% 12%,100% 0%,90% 100%,0% 100%)}.piece-label[data-v-b3eee45d]{position:absolute;left:50%;bottom:-18px;transform:translate(-50%);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);white-space:nowrap}.front-print[data-v-b3eee45d]{position:absolute;top:40%;left:50%;width:50px;height:50px;--print-color: #c9a96e}.print-diamond[data-v-b3eee45d],.td-diamond[data-v-b3eee45d]{position:absolute;width:28px;height:28px;border:2.5px solid var(--print-color);transform:rotate(45deg);top:11px;left:11px;opacity:.7}.print-circle[data-v-b3eee45d],.td-circle[data-v-b3eee45d]{position:absolute;width:20px;height:20px;border:2px solid var(--print-color);border-radius:50%;top:15px;left:15px;opacity:.5}.print-line-h[data-v-b3eee45d],.print-line-v[data-v-b3eee45d]{position:absolute;background:var(--print-color);opacity:.3}.print-line-h[data-v-b3eee45d]{width:40px;height:2px;top:24px;left:5px}.print-line-v[data-v-b3eee45d]{width:2px;height:40px;top:5px;left:24px}.editor-overlay[data-v-b3eee45d]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5}.editor-overlay[data-v-b3eee45d] .editor-node,.editor-overlay[data-v-b3eee45d] .move-box{z-index:2}.editor-overlay[data-v-b3eee45d] .move-box-control,.editor-overlay[data-v-b3eee45d] .move-box-rotate{z-index:3}.region-box[data-v-b3eee45d]{position:absolute;border:2px solid #04b94a;background:#9bf1c842;z-index:5;pointer-events:none}.piece-dock[data-v-b3eee45d]{position:absolute;left:16px;right:16px;bottom:16px;display:flex;flex-wrap:wrap;gap:8px}.piece-chip[data-v-b3eee45d]{padding:7px 12px;border:1px solid var(--border);border-radius:999px;background:#ffffffeb;color:var(--text-secondary);font-size:11px;font-weight:600}.piece-chip.active[data-v-b3eee45d]{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.viewport[data-v-b3eee45d]{position:relative;flex:1;min-height:0;overflow:hidden;background:linear-gradient(180deg,#ffffff9e,#ffffff2e 42%,#fff0),var(--three-bg-color, #ffffff)}.viewport[data-v-b3eee45d]:before{content:"";position:absolute;left:-8%;right:-8%;top:-10%;height:58%;background:linear-gradient(180deg,#ffffffbd,#ffffff5c 46%,#fff0),repeating-linear-gradient(90deg,rgba(255,255,255,.18) 0 1px,transparent 1px 92px);filter:blur(18px);transform:scale(1.04);transform-origin:center top;pointer-events:none}.viewport[data-v-b3eee45d]:after{content:"";position:absolute;inset:auto 0 0;height:42%;background:linear-gradient(180deg,#fff0,#dedede29);pointer-events:none}.three-root[data-v-b3eee45d]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.three-root[data-v-b3eee45d] canvas{display:block;width:100%!important;height:100%!important}.gizmo[data-v-b3eee45d]{position:absolute;z-index:2;right:18px;top:18px;width:70px;height:70px;border:1px solid rgba(255,255,255,.08);border-radius:50%;background:#0000002e}.gizmo-inner[data-v-b3eee45d]{position:absolute;top:19px;right:19px;bottom:19px;left:19px;border:1px solid rgba(255,255,255,.18);border-radius:50%}.gizmo-label[data-v-b3eee45d]{position:absolute;color:#8c8780;font-size:9px;font-weight:700}.gizmo-n[data-v-b3eee45d]{top:6px;left:50%;transform:translate(-50%)}.gizmo-s[data-v-b3eee45d]{bottom:6px;left:50%;transform:translate(-50%)}.gizmo-e[data-v-b3eee45d]{right:8px;top:50%;transform:translateY(-50%)}.gizmo-w[data-v-b3eee45d]{left:8px;top:50%;transform:translateY(-50%)}.material-chip[data-v-b3eee45d]{position:absolute;z-index:2;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:8px;max-width:calc(100% - 32px);padding:8px 12px;border:1px solid rgba(255,255,255,.08);border-radius:999px;background:#00000047;color:#d8d0c8;font-size:11px;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.material-chip span[data-v-b3eee45d]:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-chip-thumb[data-v-b3eee45d]{flex:0 0 18px;width:18px;height:18px;border-radius:50%;background-size:cover;background-position:center}.three-status[data-v-b3eee45d]{position:absolute;z-index:2;left:16px;top:16px;max-width:calc(100% - 112px);padding:7px 10px;border-radius:999px;background:#00000052;color:#bfb8b0;font-size:11px;font-weight:600}input[type=range][data-v-b3eee45d]{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-deep);border-radius:2px;outline:none}input[type=range][data-v-b3eee45d]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid var(--surface);box-shadow:0 1px 3px #00000026}.status-bar[data-v-b3eee45d]{display:flex;align-items:center;justify-content:space-between;height:var(--statusbar-h);padding:0 16px;background:var(--bg-warm);border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}.status-right[data-v-b3eee45d]{display:flex;align-items:center;gap:14px}.status-dot[data-v-b3eee45d]{width:5px;height:5px;border-radius:50%;background:var(--success);display:inline-block;margin-right:4px}.loading-state[data-v-b3eee45d]{display:flex;align-items:center;justify-content:center;gap:12px;height:100%;padding:24px;text-align:center}.app.embedded .loading-state[data-v-b3eee45d]{min-height:100%}.spinner[data-v-b3eee45d]{width:26px;height:26px;border:3px solid rgba(14,165,233,.16);border-top-color:var(--accent);border-radius:50%;animation:spin-b3eee45d .7s linear infinite}.modal-overlay[data-v-b3eee45d],.auth-modal-overlay[data-v-b3eee45d]{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.modal-overlay[data-v-b3eee45d]{background:#0000007a;z-index:1000}.modal[data-v-b3eee45d]{width:min(680px,calc(100vw - 32px));border-radius:20px;background:var(--surface);overflow:hidden;box-shadow:0 24px 60px #0f172a2e}.modal-header[data-v-b3eee45d],.modal-body[data-v-b3eee45d]{padding:20px 24px}.modal-header[data-v-b3eee45d]{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.modal-header h2[data-v-b3eee45d]{margin:0;font-family:var(--font-display);font-size:28px;font-weight:500}.render-modal[data-v-b3eee45d]{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:18px}.render-settings[data-v-b3eee45d],.render-history[data-v-b3eee45d]{padding:18px;border:1px solid var(--border);border-radius:18px;background:var(--surface-hover)}.render-settings[data-v-b3eee45d]{display:flex;flex-direction:column;gap:14px}.render-field[data-v-b3eee45d]{display:flex;flex-direction:column;gap:8px}.render-field label[data-v-b3eee45d]{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-secondary)}.render-field select[data-v-b3eee45d]{width:100%;height:44px;padding:0 14px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-primary)}.render-preview-meta[data-v-b3eee45d]{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:#ffffffb8;font-size:13px;color:var(--text-secondary)}.render-preview-meta strong[data-v-b3eee45d]{color:var(--text-primary)}.render-note[data-v-b3eee45d],.render-empty[data-v-b3eee45d]{margin:0;color:var(--text-secondary);font-size:13px;line-height:1.6}.render-feedback[data-v-b3eee45d]{padding:12px 14px;border-radius:12px;font-size:13px}.render-feedback.error[data-v-b3eee45d]{background:#ef44441a;color:#b91c1c}.render-feedback.success[data-v-b3eee45d]{background:#10b9811a;color:#047857}.render-actions[data-v-b3eee45d]{display:flex;gap:12px;margin-top:auto}.render-history[data-v-b3eee45d]{display:flex;flex-direction:column;gap:14px}.render-history-head[data-v-b3eee45d]{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.render-history-head h4[data-v-b3eee45d]{margin:0;font-size:16px}.render-history-head span[data-v-b3eee45d]{font-size:12px;color:var(--text-secondary)}.render-history-list[data-v-b3eee45d]{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.render-history-card[data-v-b3eee45d]{display:flex;flex-direction:column;gap:10px;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:inherit;text-decoration:none}.render-history-card img[data-v-b3eee45d]{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;background:#d6d3d1}.render-history-copy[data-v-b3eee45d]{display:flex;flex-direction:column;gap:4px}.render-history-copy strong[data-v-b3eee45d]{font-size:13px}.render-history-copy span[data-v-b3eee45d]{font-size:12px;color:var(--text-secondary)}.auth-modal-overlay[data-v-b3eee45d]{z-index:1100;background:#0f172a6b;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.auth-modal[data-v-b3eee45d]{position:relative;width:min(760px,calc(100vw - 32px));border-radius:24px;overflow:hidden;background:linear-gradient(135deg,rgba(14,165,233,.08),transparent 32%),linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 30px 80px #0f172a3d}.auth-close[data-v-b3eee45d]{position:absolute;top:16px;right:16px;z-index:2;width:36px;height:36px;border:none;border-radius:50%;background:#ffffffe6;color:var(--text-secondary);cursor:pointer}.auth-modal-content[data-v-b3eee45d]{display:grid;grid-template-columns:.9fr 1.1fr;min-height:460px}.auth-copy[data-v-b3eee45d]{padding:40px 36px;background:var(--dark);color:#fff;display:flex;flex-direction:column;justify-content:center;gap:18px}.auth-brand[data-v-b3eee45d]{font-family:var(--font-display);font-size:28px;font-weight:600}.auth-copy h2[data-v-b3eee45d]{margin:0;font-family:var(--font-display);font-size:38px;font-weight:500;line-height:1.05}.auth-copy p[data-v-b3eee45d]{margin:0;color:#ffffffb8;font-size:15px;line-height:1.7}.auth-form[data-v-b3eee45d]{padding:40px 36px;display:flex;flex-direction:column;justify-content:center;gap:18px}.auth-row[data-v-b3eee45d]{display:grid;grid-template-columns:1fr 1fr;gap:14px}.auth-field[data-v-b3eee45d]{display:flex;flex-direction:column;gap:6px}.auth-field label[data-v-b3eee45d]{font-size:13px;font-weight:600;color:var(--text-secondary)}.auth-field input[data-v-b3eee45d]{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text);font:inherit}.auth-field input[data-v-b3eee45d]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0ea5e924}.auth-error[data-v-b3eee45d]{padding:12px 14px;border:1px solid #fecaca;border-radius:12px;background:#fef2f2;color:#dc2626;font-size:13px}.auth-submit[data-v-b3eee45d]{display:inline-flex;align-items:center;justify-content:center;min-height:48px;border:none;border-radius:12px;background:var(--accent);color:#fff;font:inherit;font-weight:600;cursor:pointer}.auth-switch[data-v-b3eee45d]{margin:0;text-align:center;color:var(--text-secondary);font-size:14px}.auth-switch button[data-v-b3eee45d]{border:none;background:transparent;color:var(--accent);font:inherit;font-weight:600;cursor:pointer}.auth-spinner[data-v-b3eee45d]{width:18px;height:18px}@keyframes spin-b3eee45d{to{transform:rotate(360deg)}}@media(max-width:1200px){.app.embedded .main-area[data-v-b3eee45d]{grid-template-columns:minmax(0,1fr) minmax(340px,.82fr);gap:14px}.main-area[data-v-b3eee45d]{grid-template-columns:var(--palette-w) minmax(520px,1.1fr) minmax(380px,.9fr);overflow-x:auto;overflow-y:hidden}}@media(max-width:900px){.app[data-v-b3eee45d]{grid-template-rows:auto 1fr auto;height:100vh;min-height:100vh}.app.embedded[data-v-b3eee45d]{height:min(740px,calc(100vh - var(--nav-height, 76px) - 48px));min-height:620px;max-height:none}.app.embedded .main-area[data-v-b3eee45d]{grid-template-columns:1fr;grid-template-rows:320px auto minmax(240px,1fr) auto;overflow:hidden}.app.embedded .panel-3d[data-v-b3eee45d]{grid-column:1;grid-row:1}.app.embedded .tool-palette[data-v-b3eee45d]{grid-column:1;grid-row:2}.app.embedded .panel-2d[data-v-b3eee45d]{grid-column:1;grid-row:3}.app.embedded .embedded-render-panel[data-v-b3eee45d]{grid-column:1;grid-row:4}.toolbar[data-v-b3eee45d]{height:auto;min-height:var(--toolbar-h);padding:10px 12px;gap:12px}.toolbar-group[data-v-b3eee45d]{flex:0 0 auto}.project-name input[data-v-b3eee45d]{width:156px}.main-area[data-v-b3eee45d]{grid-template-columns:var(--palette-w) minmax(480px,1fr) minmax(340px,.92fr);overflow-x:auto;overflow-y:hidden}.tool-palette[data-v-b3eee45d]{width:var(--palette-w);padding:10px 0}.shape-picker-card[data-v-b3eee45d]{left:calc(100% + 8px);width:188px}.tool-btn[data-v-b3eee45d]:after{display:none}.element-toolbar[data-v-b3eee45d]{bottom:14px}.element-toolbar-pill[data-v-b3eee45d]{max-width:100%}.panel-2d[data-v-b3eee45d],.panel-3d[data-v-b3eee45d]{grid-column:auto;grid-row:auto}.panel-2d[data-v-b3eee45d]{min-height:0;border-right:1px solid var(--border);border-bottom:none}.render-modal[data-v-b3eee45d],.render-history-list[data-v-b3eee45d]{grid-template-columns:1fr}.status-bar[data-v-b3eee45d]{flex-direction:column;align-items:flex-start;gap:4px;height:auto;padding:10px 16px}.status-right[data-v-b3eee45d]{flex-wrap:wrap;gap:8px 14px}.auth-modal-content[data-v-b3eee45d]{grid-template-columns:1fr}.auth-copy[data-v-b3eee45d],.auth-form[data-v-b3eee45d]{padding:28px 22px}.auth-copy h2[data-v-b3eee45d]{font-size:30px}.auth-row[data-v-b3eee45d]{grid-template-columns:1fr}}@media(max-width:640px){.app.embedded[data-v-b3eee45d]{height:min(680px,calc(100vh - var(--nav-height, 76px) - 40px));min-height:560px}.app.embedded .main-area[data-v-b3eee45d]{grid-template-rows:280px auto minmax(200px,1fr) auto}.app.embedded .tool-palette[data-v-b3eee45d]{overflow-x:auto;justify-content:flex-start}.app.embedded .embedded-render-panel[data-v-b3eee45d]{padding:12px}.project-name input[data-v-b3eee45d]{width:128px}.main-area[data-v-b3eee45d]{grid-template-columns:var(--palette-w) 460px 320px}.element-toolbar-pill[data-v-b3eee45d]{max-width:100%;padding:10px 12px}.shape-picker-card[data-v-b3eee45d]{width:172px;padding:12px}.pattern-stage[data-v-b3eee45d]{padding:18px}.piece-dock[data-v-b3eee45d]{left:10px;right:10px;bottom:10px}}
