*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.absolute{position:absolute}.grid{display:grid}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--clr-bg: #f5f0eb;--clr-bg-deep: #ece5dd;--clr-surface: #faf8f5;--clr-surface-hover: #f0ece6;--clr-border: #d6cec4;--clr-border-light: #e8e2da;--clr-text: #2c2520;--clr-text-secondary: #7a6e62;--clr-text-tertiary: #a89a8c;--clr-accent: #c4533a;--clr-accent-hover: #a8432d;--clr-accent-light: rgba(196, 83, 58, .08);--clr-success: #4a8c6a;--clr-error: #c4533a;--clr-error-bg: rgba(196, 83, 58, .06);--clr-warning: #96652a;--clr-warning-bg: rgba(196, 136, 58, .1);--font-display: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-body: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--header-height: 72px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--clr-bg);color:var(--clr-text);line-height:1.5;min-height:100vh}img{display:block;max-width:100%}.app{display:flex;flex-direction:column;min-height:100vh}.app--fullscreen{height:100vh}.app-header{height:var(--header-height);border-bottom:1px solid var(--clr-border-light);background:var(--clr-surface);display:flex;align-items:center;flex-shrink:0}.app-header__inner{width:100%;max-width:1800px;margin:0 auto;padding:0 32px;display:flex;align-items:baseline;gap:16px}.app-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;letter-spacing:-.03em;color:var(--clr-text)}.app-title__mosaic{background:linear-gradient(135deg,var(--clr-accent),#d97a4a);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.app-subtitle{font-size:.875rem;color:var(--clr-text-tertiary);font-weight:400}.app-wizard{flex:1;overflow-y:auto;display:flex;justify-content:center;padding:32px 24px 64px}.wizard{width:100%;max-width:520px;display:flex;flex-direction:column;gap:28px}.wizard-section{display:flex;flex-direction:column;gap:12px}.wizard-section__title{font-family:var(--font-display);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--clr-text-secondary);display:flex;align-items:center;gap:10px}.wizard-step-dot{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--clr-accent);color:#fff;font-size:.6875rem;font-weight:700;flex-shrink:0;font-style:normal}.app-generating{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;padding:40px 24px}.generating-preview{width:100%;max-width:400px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--clr-border-light);background:var(--clr-bg-deep)}.generating-preview__canvas{width:100%;height:auto;display:block;image-rendering:pixelated}.generating-progress{width:100%;max-width:400px}.upload-zone{border:2px dashed var(--clr-border);border-radius:var(--radius-md);padding:20px;cursor:pointer;transition:border-color .2s,background .2s;text-align:center;background:var(--clr-bg);position:relative;overflow:hidden}.upload-zone:hover{border-color:var(--clr-text-tertiary);background:var(--clr-surface-hover)}.upload-zone--active{border-color:var(--clr-accent);background:var(--clr-accent-light)}.upload-zone--disabled{opacity:.5;cursor:not-allowed}.upload-zone--has-preview{padding:0;border-style:solid;border-color:var(--clr-border)}.upload-zone__content{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0}.upload-zone__icon{width:36px;height:36px;color:var(--clr-text-tertiary)}.upload-zone__title{font-family:var(--font-display);font-size:.875rem;font-weight:600;color:var(--clr-text)}.upload-zone__subtitle{font-size:.75rem;color:var(--clr-text-tertiary)}.pool-uploader{display:flex;flex-direction:column;gap:10px}.pool-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.fallback-btn{font-size:.75rem;color:var(--clr-text-secondary);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:2px;padding:0;text-align:left}.fallback-btn:hover{color:var(--clr-text)}.fallback-btn:disabled{opacity:.4;cursor:not-allowed}.zip-btn{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;color:var(--clr-text-secondary);background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-sm);padding:6px 12px;cursor:pointer;transition:border-color .2s,background .2s}.zip-btn:hover:not(:disabled){border-color:var(--clr-text-tertiary);background:var(--clr-surface-hover);color:var(--clr-text)}.zip-btn:disabled{opacity:.4;cursor:not-allowed}.zip-btn--active{border-color:var(--clr-accent);color:var(--clr-accent)}.zip-btn__spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--clr-border);border-top-color:var(--clr-accent);border-radius:50%;animation:zip-spin .6s linear infinite;flex-shrink:0}@keyframes zip-spin{to{transform:rotate(360deg)}}.pool-preview{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.pool-preview__thumb{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;border-radius:4px}.pool-preview__more{display:flex;align-items:center;justify-content:center;aspect-ratio:1;background:var(--clr-bg-deep);border-radius:4px;font-size:.6875rem;font-weight:600;color:var(--clr-text-secondary)}.target-preview{position:relative;width:100%}.target-preview img{width:100%;display:block;border-radius:calc(var(--radius-md) - 2px)}.target-preview__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#2c252080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:calc(var(--radius-md) - 2px)}.target-preview:hover .target-preview__overlay{opacity:1}.target-preview__overlay span{font-size:.8125rem;font-weight:600;color:#fff}.controls{display:flex;flex-direction:column;gap:16px}.control-group{display:flex;flex-direction:column;gap:6px}.control-label{font-size:.8125rem;font-weight:500;color:var(--clr-text);display:flex;align-items:center;justify-content:space-between}.control-value{font-family:var(--font-display);font-weight:600;font-size:.8125rem;color:var(--clr-accent)}.control-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--clr-border-light);outline:none;cursor:pointer}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--clr-accent);border:3px solid var(--clr-surface);box-shadow:0 1px 4px #00000026;cursor:pointer}.control-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--clr-accent);border:3px solid var(--clr-surface);box-shadow:0 1px 4px #00000026;cursor:pointer}.control-slider:disabled{opacity:.4;cursor:not-allowed}.control-range-labels{display:flex;justify-content:space-between;font-size:.6875rem;color:var(--clr-text-tertiary)}.control-info{font-size:.8125rem;color:var(--clr-text-secondary);background:var(--clr-bg);padding:10px 14px;border-radius:var(--radius-sm)}.control-info p{font-family:var(--font-display);font-weight:500}.control-warning{font-size:.75rem;font-weight:500;color:var(--clr-warning);background:var(--clr-warning-bg);border:1px solid rgba(196,136,58,.2);border-radius:var(--radius-sm);padding:8px 12px}.btn{font-family:var(--font-display);font-weight:600;font-size:.875rem;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,opacity .15s,transform .1s;padding:12px 20px}.btn:active{transform:scale(.98)}.btn--generate{background:var(--clr-accent);color:#fff;width:100%}.btn--generate:hover:not(:disabled){background:var(--clr-accent-hover)}.btn--generate:disabled{opacity:.4;cursor:not-allowed}.btn--cancel{background:var(--clr-border-light);color:var(--clr-text);width:100%}.btn--cancel:hover{background:var(--clr-border)}.btn--cancel-sm{font-family:var(--font-display);font-weight:500;font-size:.8125rem;background:none;border:1px solid var(--clr-border);border-radius:var(--radius-sm);color:var(--clr-text-secondary);cursor:pointer;padding:8px 20px;margin-top:8px;width:100%;transition:border-color .2s,color .2s}.btn--cancel-sm:hover{border-color:var(--clr-text-tertiary);color:var(--clr-text)}.btn--small{padding:6px 14px;font-size:.75rem;background:var(--clr-surface);color:var(--clr-text-secondary);border:1px solid var(--clr-border-light)}.btn--small:hover{background:var(--clr-surface-hover);color:var(--clr-text)}.btn--download{padding:6px 14px;font-size:.75rem;background:var(--clr-accent);color:#fff}.btn--download:hover{background:var(--clr-accent-hover)}.export-dropdown{position:relative;margin-left:auto}.export-dropdown__menu{position:absolute;top:100%;right:0;margin-top:4px;background:var(--clr-surface);border:1px solid var(--clr-border-light);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001a;overflow:hidden;z-index:10;min-width:180px}.export-dropdown__menu button{display:block;width:100%;padding:10px 16px;font-family:var(--font-body);font-size:.8125rem;color:var(--clr-text);background:none;border:none;cursor:pointer;text-align:left;transition:background .15s}.export-dropdown__menu button:hover{background:var(--clr-surface-hover)}.export-dropdown__menu button+button{border-top:1px solid var(--clr-border-light)}.progress-container{padding:14px;background:var(--clr-surface);border-radius:var(--radius-sm);border:1px solid var(--clr-border-light)}.progress-header{display:flex;justify-content:space-between;margin-bottom:8px}.progress-label{font-family:var(--font-display);font-size:.8125rem;font-weight:600;color:var(--clr-text)}.progress-count{font-size:.75rem;color:var(--clr-text-tertiary);font-variant-numeric:tabular-nums}.progress-track{height:6px;background:var(--clr-border-light);border-radius:3px;overflow:hidden}.progress-fill{height:100%;width:100%;background:var(--clr-accent);border-radius:3px;transform-origin:left;transition:transform .1s linear;will-change:transform}.progress-fill--cancelled{background:var(--clr-text-tertiary)}.progress-footer{display:flex;justify-content:space-between;margin-top:4px}.progress-percent{font-size:.6875rem;color:var(--clr-text-tertiary);font-variant-numeric:tabular-nums}.progress-eta{font-size:.6875rem;color:var(--clr-text-secondary);font-variant-numeric:tabular-nums}.error-banner{background:var(--clr-error-bg);border:1px solid rgba(196,83,58,.2);border-radius:var(--radius-sm);padding:12px 14px}.error-banner__text{font-size:.8125rem;color:var(--clr-error);font-weight:500}.mosaic-viewer{flex:1;display:flex;flex-direction:column;overflow:hidden}.mosaic-viewer__toolbar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--clr-surface);border-bottom:1px solid var(--clr-border-light);flex-shrink:0}.mosaic-viewer__zoom-level{font-size:.75rem;font-variant-numeric:tabular-nums;color:var(--clr-text-tertiary);min-width:42px}.mosaic-viewer__container{flex:1;overflow:hidden;cursor:grab;position:relative;background:var(--clr-bg-deep);touch-action:none}.mosaic-viewer__container:active{cursor:grabbing}.mosaic-viewer__wrapper{position:relative;transform-origin:0 0;will-change:transform}.mosaic-viewer__canvas,.mosaic-viewer__detail{image-rendering:auto}.mosaic-viewer__warning{padding:8px 16px;background:var(--clr-warning-bg);border-bottom:1px solid rgba(196,136,58,.2);font-size:.75rem;font-weight:500;color:var(--clr-warning);flex-shrink:0}.mosaic-viewer__info{padding:6px 16px;background:var(--clr-surface);border-top:1px solid var(--clr-border-light);font-size:.6875rem;color:var(--clr-text-tertiary);font-variant-numeric:tabular-nums;text-align:right;flex-shrink:0}@media (max-width: 768px){:root{--header-height: 56px}.app-wizard{padding:20px 16px 48px}.app-header__inner{padding:0 16px}.app-subtitle{display:none}.pool-preview{grid-template-columns:repeat(7,1fr)}.mosaic-viewer__toolbar{flex-wrap:wrap;gap:6px;padding:8px 12px}}.hidden{display:none}
