.collage-maker[data-v-9b02fe73]{padding:120px 0 80px;background:var(--bg);min-height:100vh}.tool-header[data-v-9b02fe73]{text-align:center;margin-bottom:60px}.tool-title[data-v-9b02fe73]{font-family:var(--font-serif);font-size:clamp(32px,5vw,48px);margin-bottom:16px;color:var(--txt)}.tool-desc[data-v-9b02fe73]{color:var(--muted);font-size:18px;max-width:600px;margin:0 auto}.tool-layout[data-v-9b02fe73]{display:grid;grid-template-columns:280px 1fr;gap:32px;align-items:start}.controls-panel[data-v-9b02fe73]{background:var(--surface);border:1px solid var(--border);padding:30px;position:sticky;top:100px;z-index:10}.control-group[data-v-9b02fe73]{margin-bottom:28px}.label-with-value[data-v-9b02fe73]{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.val[data-v-9b02fe73]{font-size:12px;font-weight:600;color:var(--accent)}.control-label[data-v-9b02fe73]{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);font-weight:700;margin-bottom:8px}.file-input[data-v-9b02fe73]{display:none}.upload-zone[data-v-9b02fe73]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border:2px dashed var(--border);cursor:pointer;transition:all .3s ease}.upload-zone[data-v-9b02fe73]:hover{border-color:var(--accent);background:var(--bg)}.upload-icon[data-v-9b02fe73]{font-size:24px;margin-bottom:8px;color:var(--accent)}.upload-text[data-v-9b02fe73]{font-size:13px;font-weight:600}.select-input[data-v-9b02fe73]{width:100%;padding:12px;background:var(--bg);border:1px solid var(--border);color:var(--txt);font-family:var(--font-sans);font-size:14px;outline:none}.select-input[data-v-9b02fe73]:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.custom-dims[data-v-9b02fe73]{display:flex;align-items:center;gap:8px;margin-top:10px}.dim-input[data-v-9b02fe73]{width:80px;padding:8px 10px;background:var(--bg);border:1px solid var(--border);color:var(--txt);font-family:var(--font-sans);font-size:13px;outline:none;text-align:center}.dim-input[data-v-9b02fe73]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dim-sep[data-v-9b02fe73]{color:var(--muted);font-size:14px}.dim-unit[data-v-9b02fe73]{color:var(--muted);font-size:12px}.template-btns[data-v-9b02fe73]{display:grid;grid-template-columns:1fr 1fr;gap:8px}.template-btn[data-v-9b02fe73]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s ease;flex:1;min-width:0;overflow:hidden}.template-icon[data-v-9b02fe73]{font-size:18px;line-height:1}.template-label[data-v-9b02fe73]{font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.template-btn[data-v-9b02fe73]:hover{border-color:var(--accent);color:var(--txt)}.shuffle-inline[data-v-9b02fe73]{margin-top:8px;padding:8px;font-size:11px}.template-btn.active[data-v-9b02fe73]{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--bg))}.range-input[data-v-9b02fe73]{width:100%;accent-color:var(--accent);cursor:pointer}.color-presets[data-v-9b02fe73]{display:flex;gap:10px;align-items:center}.color-btn[data-v-9b02fe73]{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);cursor:pointer;padding:0;background:none;transition:all .2s ease}.color-btn[data-v-9b02fe73]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.color-btn.active[data-v-9b02fe73]{outline:2px solid var(--accent);outline-offset:2px;transform:scale(1.1)}.color-picker[data-v-9b02fe73]{width:30px;height:30px;padding:0;border:none;background:none;cursor:pointer}.format-toggle[data-v-9b02fe73]{display:flex;border:1px solid var(--border);overflow:hidden}.format-btn[data-v-9b02fe73]{flex:1;padding:10px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--bg);border:none;color:var(--muted);cursor:pointer;transition:all .2s ease}.format-btn.active[data-v-9b02fe73]{background:var(--accent);color:var(--bg)}.format-hint[data-v-9b02fe73]{font-size:11px;color:var(--muted);margin-top:6px;font-style:italic}.progress-bar[data-v-9b02fe73]{height:4px;background:var(--border);margin-bottom:12px;overflow:hidden}.progress-fill[data-v-9b02fe73]{height:100%;background:var(--accent);transition:width .3s ease}.actions-group[data-v-9b02fe73]{margin-top:40px;padding-top:20px;border-top:1px solid var(--border)}.btn-block[data-v-9b02fe73]{width:100%;margin-bottom:12px;padding:14px;font-size:13px;text-transform:uppercase;letter-spacing:.1em;font-weight:700}.btn-block[data-v-9b02fe73]:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-block[data-v-9b02fe73]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.pan-hint[data-v-9b02fe73]{margin-top:16px;font-size:11px;color:var(--muted);text-align:center;font-style:italic}.palette-toggle-row[data-v-9b02fe73]{width:100%;display:flex;justify-content:center;margin-top:16px}.palette-toggle-btn[data-v-9b02fe73]{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:all .2s ease}.palette-toggle-btn[data-v-9b02fe73]:hover{border-color:var(--accent);color:var(--txt)}.palette-toggle-btn svg.rotated[data-v-9b02fe73]{transform:rotate(180deg)}.palette-toggle-btn svg[data-v-9b02fe73]{transition:transform .2s ease}.palette-section[data-v-9b02fe73]{margin-top:12px;width:100%}.palette-section-inner[data-v-9b02fe73]{background:var(--surface);border:1px solid var(--border);padding:32px}.palette-section-header[data-v-9b02fe73]{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.palette-section-title[data-v-9b02fe73]{font-family:var(--font-serif);font-size:22px;color:var(--txt);margin:0}.palette-close[data-v-9b02fe73]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s ease}.palette-close[data-v-9b02fe73]:hover{border-color:var(--accent);color:var(--txt)}.palette-section-body[data-v-9b02fe73]{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}.palette-presets-col[data-v-9b02fe73]{display:flex;flex-direction:column;gap:8px}.preset-grid[data-v-9b02fe73]{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:400px;overflow-y:auto}.preset-card[data-v-9b02fe73]{padding:8px;background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:all .2s ease;text-align:left}.preset-card[data-v-9b02fe73]:hover{border-color:var(--accent)}.preset-swatches[data-v-9b02fe73]{display:flex;height:28px;border-radius:2px;overflow:hidden;margin-bottom:6px}.preset-swatch[data-v-9b02fe73]{flex:1}.preset-name[data-v-9b02fe73]{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.palette-collage-toggle[data-v-9b02fe73]{display:flex;flex-direction:column;gap:8px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border)}.toggle-row[data-v-9b02fe73]{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--txt);cursor:pointer}.toggle-row input[type=checkbox][data-v-9b02fe73]{accent-color:var(--accent);width:16px;height:16px}.position-btns[data-v-9b02fe73]{display:flex;gap:4px}.position-btns button[data-v-9b02fe73]{flex:1;padding:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;background:var(--bg);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s ease}.position-btns button.active[data-v-9b02fe73]{background:var(--accent);border-color:var(--accent);color:var(--bg)}.collage-export-wrap[data-v-9b02fe73]{width:100%;box-shadow:0 30px 60px #00000026;overflow:hidden}.text-tile[data-v-9b02fe73]{position:relative;width:100%;padding:20px 24px}.text-tile-editor[data-v-9b02fe73]{outline:none;min-height:1.2em;line-height:1.4;font-family:var(--font-serif);word-break:break-word}.text-tile-editor[data-v-9b02fe73]:empty:before{content:attr(data-placeholder);opacity:.35;pointer-events:none}.text-tile-toolbar[data-v-9b02fe73]{position:absolute;top:4px;right:4px;display:flex;align-items:center;gap:2px;background:#0009;backdrop-filter:blur(8px);padding:3px 6px;border-radius:4px;opacity:0;transition:opacity .2s ease}.text-tile:hover .text-tile-toolbar[data-v-9b02fe73],.text-tile:focus-within .text-tile-toolbar[data-v-9b02fe73]{opacity:1}.tile-tool-btn[data-v-9b02fe73]{background:transparent;border:none;color:#fff;padding:2px 6px;font-size:10px;font-weight:700;cursor:pointer;border-radius:2px;display:flex;align-items:center}.tile-tool-btn[data-v-9b02fe73]:hover{background:#ffffff26}.tile-tool-btn.active[data-v-9b02fe73]{background:#ffffff40}.tile-font-btn[data-v-9b02fe73]{font-size:9px;letter-spacing:.02em}.tile-size[data-v-9b02fe73]{color:#fff9;font-size:9px;font-weight:700;min-width:18px;text-align:center}.tile-sep[data-v-9b02fe73]{width:1px;height:12px;background:#fff3;margin:0 4px}.tile-toggle[data-v-9b02fe73]{margin-top:8px}.collage-palette-strip[data-v-9b02fe73]{display:flex;width:100%}.collage-palette-swatch[data-v-9b02fe73]{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 4px;min-height:36px}.collage-palette-hex[data-v-9b02fe73]{font-family:var(--font-sans);font-size:10px;font-weight:700;letter-spacing:.08em;text-shadow:0 1px 3px rgba(0,0,0,.2)}.canvas-area[data-v-9b02fe73]{background:var(--surface);border:1px solid var(--border);padding:24px;display:flex;flex-direction:column;align-items:stretch;overflow:hidden;position:relative;transition:border-color .2s ease,background .2s ease}.canvas-area.drag-over[data-v-9b02fe73]{border-color:var(--accent);border-style:dashed;background:color-mix(in srgb,var(--accent) 5%,var(--surface))}.canvas-container[data-v-9b02fe73]{width:100%;height:auto;transition:all .3s ease}.collage-canvas[data-v-9b02fe73]{display:grid;width:100%;overflow:hidden;flex:1;min-height:0}.canvas-container.is-exporting[data-v-9b02fe73]{max-width:none;position:absolute;left:-9999px;top:0}.collage-item[data-v-9b02fe73]{position:relative;width:100%;height:100%;cursor:grab;overflow:hidden;-webkit-touch-callout:none}.collage-item img[data-v-9b02fe73]{-webkit-touch-callout:none;-webkit-user-select:none}.collage-item[data-v-9b02fe73]:active{cursor:grabbing}.collage-item.no-drag[data-v-9b02fe73],.collage-item.no-drag[data-v-9b02fe73]:active{cursor:default}.collage-img[data-v-9b02fe73]{width:100%;height:100%;object-fit:cover;display:block;user-select:none;-webkit-user-drag:none}.remove-btn[data-v-9b02fe73]{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;justify-content:center;align-items:center;opacity:0;transition:all .2s;font-size:18px;z-index:5}.collage-item:hover .remove-btn[data-v-9b02fe73]{opacity:1}.select-btn[data-v-9b02fe73]{position:absolute;top:10px;left:10px;width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;justify-content:center;align-items:center;opacity:0;transition:all .2s;z-index:5}.select-btn.is-selected[data-v-9b02fe73]{color:var(--accent)}.collage-item:hover .select-btn[data-v-9b02fe73]{opacity:1}.thumb-strip[data-v-9b02fe73]{margin-top:12px;width:100%;max-height:250px;overflow-y:auto}.thumb-strip-header[data-v-9b02fe73]{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.thumb-strip-label[data-v-9b02fe73]{font-size:11px;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);font-weight:700}.thumb-strip-actions[data-v-9b02fe73]{display:flex;gap:6px}.thumb-action[data-v-9b02fe73]{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:all .2s ease;border-radius:4px}.thumb-action[data-v-9b02fe73]:hover{border-color:var(--accent);color:var(--txt)}.thumb-strip-grid[data-v-9b02fe73]{display:flex;flex-wrap:wrap;gap:6px}.thumb-item[data-v-9b02fe73]{position:relative;width:56px;height:56px;border:2px solid transparent;padding:0;background:none;cursor:pointer;overflow:hidden;transition:all .2s ease;border-radius:4px}.thumb-item[data-v-9b02fe73]:hover{border-color:var(--accent)}.thumb-item.deselected[data-v-9b02fe73]{opacity:.35}.thumb-item.deselected[data-v-9b02fe73]:hover{opacity:.7}.thumb-img[data-v-9b02fe73]{width:100%;height:100%;object-fit:cover;display:block}.thumb-check[data-v-9b02fe73]{position:absolute;top:3px;left:3px;display:flex;line-height:1}.span-menu-wrapper[data-v-9b02fe73]{position:absolute;bottom:10px;left:10px;z-index:5}.span-btn[data-v-9b02fe73]{width:28px;height:28px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;display:flex;justify-content:center;align-items:center;opacity:0;transition:all .2s}.collage-item:hover .span-btn[data-v-9b02fe73]{opacity:1}.remove-btn[data-v-9b02fe73]:focus-visible,.select-btn[data-v-9b02fe73]:focus-visible,.span-btn[data-v-9b02fe73]:focus-visible{opacity:1;outline:2px solid #fff;outline-offset:2px}.span-popover[data-v-9b02fe73]{position:absolute;bottom:36px;left:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:6px;background:#000000d9;backdrop-filter:blur(8px);border-radius:8px;white-space:nowrap}.span-popover button[data-v-9b02fe73]{padding:6px 10px;font-size:11px;font-weight:600;color:#fff;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;transition:all .15s ease}.span-popover button[data-v-9b02fe73]:hover{background:#ffffff26}.span-popover button.active[data-v-9b02fe73]{background:var(--accent);border-color:var(--accent);color:#fff}.empty-canvas-preview[data-v-9b02fe73]{width:100%;cursor:pointer;transition:all .3s ease;position:relative;box-shadow:inset 0 0 0 2px var(--border)}.empty-canvas-preview[data-v-9b02fe73]:hover{box-shadow:inset 0 0 0 2px var(--accent)}.empty-canvas-inner[data-v-9b02fe73]{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;color:var(--muted)}.empty-ratio-label[data-v-9b02fe73]{margin-top:16px;font-family:var(--font-sans);font-size:13px;letter-spacing:.1em;text-transform:uppercase;opacity:.5}.empty-icon[data-v-9b02fe73]{margin-bottom:24px;opacity:.4;color:var(--muted)}.empty-text[data-v-9b02fe73]{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--txt)}.empty-subtext[data-v-9b02fe73]{font-size:14px}.btn-outline[data-v-9b02fe73]{background:transparent;border:1px solid var(--border);color:var(--txt)}.btn-outline[data-v-9b02fe73]:hover{background:var(--border)}.btn-accent[data-v-9b02fe73]{background:var(--accent);border:1px solid var(--accent);color:#fff}.btn-accent[data-v-9b02fe73]:hover{opacity:.9}.collage-item.crop-active[data-v-9b02fe73]{cursor:crosshair}.collage-item.crop-active img[data-v-9b02fe73]{pointer-events:auto;cursor:crosshair}@media (max-width: 1024px){.tool-layout[data-v-9b02fe73]{grid-template-columns:1fr}.controls-panel[data-v-9b02fe73]{position:static;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px 24px;align-items:start}.controls-panel .control-group[data-v-9b02fe73]{margin-bottom:0}.actions-group[data-v-9b02fe73]{margin-top:0;padding-top:0;border-top:none;grid-column:1 / -1}.pan-hint[data-v-9b02fe73]{grid-column:1 / -1;margin-top:0}.canvas-area[data-v-9b02fe73]{padding:20px}.palette-section-body[data-v-9b02fe73]{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.collage-maker[data-v-9b02fe73]{padding:90px 0 60px}.tool-header[data-v-9b02fe73]{margin-bottom:24px}.controls-panel[data-v-9b02fe73]{padding:16px;grid-template-columns:1fr 1fr;gap:12px 16px}.canvas-area[data-v-9b02fe73]{padding:8px}.canvas-area .empty-canvas-inner[data-v-9b02fe73]{padding:16px}.empty-text[data-v-9b02fe73]{font-size:15px}.empty-icon svg[data-v-9b02fe73]{width:48px;height:48px}.thumb-strip[data-v-9b02fe73]{max-height:150px}.thumb-item[data-v-9b02fe73]{width:44px;height:44px}.palette-section-inner[data-v-9b02fe73]{padding:20px}.palette-section-body[data-v-9b02fe73]{grid-template-columns:1fr}.preset-grid[data-v-9b02fe73]{grid-template-columns:repeat(2,1fr)}.collage-item .remove-btn[data-v-9b02fe73],.collage-item .span-btn[data-v-9b02fe73],.collage-item .select-btn[data-v-9b02fe73]{opacity:.8}.collage-item .remove-btn[data-v-9b02fe73],.collage-item .span-btn[data-v-9b02fe73],.collage-item .select-btn[data-v-9b02fe73]{width:24px;height:24px;font-size:14px}.remove-btn[data-v-9b02fe73]{top:4px;right:4px}.select-btn[data-v-9b02fe73]{top:4px;left:4px}.span-menu-wrapper[data-v-9b02fe73]{bottom:4px;left:4px}.position-btns button[data-v-9b02fe73]{padding:8px}}@media (max-width: 480px){.controls-panel[data-v-9b02fe73]{grid-template-columns:1fr;padding:12px}.collage-maker[data-v-9b02fe73]{padding:80px 0 40px}.canvas-area[data-v-9b02fe73]{padding:4px;min-height:250px}.tool-desc[data-v-9b02fe73]{font-size:15px}.span-popover[data-v-9b02fe73]{position:fixed;inset:auto 0 0;grid-template-columns:repeat(4,1fr);padding:16px;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -10px 30px #0000001a;border-radius:12px 12px 0 0;z-index:100}.span-popover button[data-v-9b02fe73]{color:var(--txt);border-color:var(--border);padding:12px;font-size:13px}}.mobile-canvas-actions[data-v-9b02fe73],.mobile-drag-hint[data-v-9b02fe73]{display:none}@media (max-width: 768px){.mobile-canvas-actions[data-v-9b02fe73]{display:flex;gap:8px;padding:8px 0}.mobile-action-btn[data-v-9b02fe73]{flex:1;padding:12px;border:1px solid var(--border);background:var(--bg);color:var(--txt);font-size:12px;text-transform:uppercase;font-weight:600;letter-spacing:.1em;cursor:pointer;transition:all .2s}.mobile-action-btn[data-v-9b02fe73]:active{opacity:.7}.mobile-action-btn.primary[data-v-9b02fe73]{background:var(--txt);color:var(--bg)}.mobile-drag-hint[data-v-9b02fe73]{display:block;text-align:center;font-size:12px;font-style:italic;color:var(--muted);margin:0;padding:4px 0}.span-popover[data-v-9b02fe73]{bottom:auto;top:36px;left:0;z-index:50}}
