body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--color-bg-primary:#fff;--color-bg-secondary:#f9fafb;--color-bg-tertiary:#f5f5f5;--color-text-primary:#4b5563;--color-text-secondary:#6b7280;--color-text-accent:#6366f1;--color-border:#e5e7eb;--color-button-primary:#6366f1;--color-button-primary-hover:#4f46e5;--color-button-secondary:#10b981;--color-button-secondary-hover:#059669;--color-error:#ef4444;--color-error-bg:#fee2e2;--color-shadow:#0000000d;--color-accent-gradient:linear-gradient(90deg,#6366f1,#8cebc1 50%,#f472b6)}[data-theme=dark]{--color-bg-primary:#121212;--color-bg-secondary:#000;--color-bg-tertiary:#1e1e1e;--color-text-primary:#e0e0e0;--color-text-secondary:#a0a0a0;--color-text-accent:#a78bfa;--color-border:#333;--color-button-primary:#a78bfa;--color-button-primary-hover:#8b5cf6;--color-button-secondary:#34d399;--color-button-secondary-hover:#10b981;--color-error:#f87171;--color-error-bg:#450a0a;--color-shadow:#0000004d;--color-accent-gradient:linear-gradient(90deg,#6366f1,#8cebc1 50%,#f472b6)}.App{color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;text-align:center}.App-header{display:none}.App-main{padding:0 20px 20px}.App-main,.container{margin:0 auto;max-width:1200px}.container{background-color:var(--color-bg-primary);border-radius:12px;box-shadow:0 2px 8px var(--color-shadow);padding:24px}section{background-color:var(--color-bg-secondary);border-radius:8px;box-shadow:0 1px 3px var(--color-shadow);margin-bottom:30px;padding:20px}h2{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);font-weight:600;margin-bottom:20px;margin-top:0;padding-bottom:10px}.download-button,.generate-button{background-color:var(--color-button-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s}.download-button:hover,.generate-button:hover{background-color:var(--color-button-primary-hover);transform:translateY(-1px)}.generate-button:disabled{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:not-allowed;transform:none}.download-button{background-color:var(--color-button-secondary);margin-top:15px}.download-button:hover{background-color:var(--color-button-secondary-hover)}.error-message{background-color:var(--color-error-bg);border-left:3px solid var(--color-error);border-radius:4px;color:var(--color-error);margin-top:10px;padding:10px}.result-container{align-items:center;background-color:var(--color-bg-primary);border-radius:8px;box-shadow:0 1px 3px var(--color-shadow);display:flex;flex-direction:column;margin-top:20px;padding:20px}.collage-preview{align-items:center;border:1px solid var(--color-border);display:flex;height:auto;justify-content:center;margin:15px auto;max-width:100%;overflow:hidden;position:relative}.collage-preview img{display:block;height:auto;margin:0 auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}.preview-overlay{align-items:center;background-color:#0009;bottom:0;color:#fff;display:flex;font-size:1.2rem;font-weight:700;justify-content:center;left:0;position:absolute;right:0;top:0}.download-info{align-items:center;display:flex;flex-direction:column;margin-top:10px}.preview-note{color:var(--color-text-secondary);margin:0 0 10px;text-align:center}.download-button{min-width:250px;padding:8px 16px}.download-button:disabled{cursor:wait;opacity:.8}.setting-group{align-items:center;display:flex;margin-bottom:15px}.setting-group label{color:var(--color-text-primary);font-weight:500;margin-right:10px;text-align:left;width:150px}.setting-group input[type=range]{accent-color:var(--color-button-primary);flex:1 1;max-width:200px}.setting-group span:not(.tooltip-text){color:var(--color-text-secondary);margin-left:10px;text-align:left;width:40px}.setting-group.checkbox{flex-direction:row-reverse;justify-content:flex-end}.setting-group.checkbox input{accent-color:var(--color-button-primary);margin-right:10px}.setting-group.checkbox label{width:auto}.App-footer{background-color:var(--color-bg-secondary);border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:.9rem;margin-top:60px;padding:20px}.App-footer a{color:var(--color-text-accent);text-decoration:none}.App-footer a:hover{text-decoration:underline}.empty-cells-tip{background-color:var(--color-bg-secondary);border-left:4px solid var(--color-accent);border-radius:8px;box-shadow:0 1px 3px var(--color-shadow);color:var(--color-text-primary);margin-left:auto;margin-right:auto;margin-top:20px;max-width:100%;min-width:500px;padding:15px 20px;width:auto}.tip-icon{color:var(--color-accent);font-size:1.2em;margin-right:8px;vertical-align:middle}.tip-text{font-weight:500;margin-bottom:12px}.tip-suggestions{margin-bottom:5px;margin-top:12px;padding-inline-start:10px;text-align:left;width:100%}.tip-suggestions li{align-items:flex-start;display:flex;list-style-type:none;margin-bottom:10px;padding-left:20px;position:relative;white-space:nowrap}@media (max-width:550px){.empty-cells-tip{min-width:0}.tip-suggestions li{white-space:normal}}.tip-suggestions li:before{color:var(--color-accent);content:"—";font-weight:500;left:0;position:absolute;top:-1px}.suggestion-item{display:block}.tip-suggestions li:last-child{margin-bottom:0}[data-theme=dark] .empty-cells-tip{border-left-color:var(--color-accent);color:var(--color-text-primary)}[data-theme=dark] .empty-cells-tip,body{background-color:var(--color-bg-secondary)}body{margin:0;padding:0}.page-container{margin-bottom:40px;padding:20px}.site-header{background-color:var(--color-bg-primary);box-shadow:0 1px 3px var(--color-shadow);padding:15px 0;position:sticky;top:0;z-index:1000}.header-container{justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-container,.site-branding{align-items:center;display:flex}.header-logo{display:block;height:55px;width:auto}.site-title{font-size:1.5rem;font-weight:700;letter-spacing:-.5px;margin:0}.title-part{color:var(--color-text-accent)}.title-part-accent{color:#8cebc1}.site-navigation{align-items:center;display:flex}.nav-links{display:flex;list-style:none;margin:0;padding:0}.nav-links li{margin-left:20px}.nav-links a{border-radius:4px;color:var(--color-text-secondary);display:block;font-weight:500;padding:8px 12px;text-decoration:none;transition:all .2s}.nav-links a.active,.nav-links a:hover{background-color:#6366f11a;color:var(--color-text-accent)}.hero-section{align-items:center;background-color:var(--color-bg-primary);display:flex;flex-direction:column;margin-bottom:30px;padding:10px 20px;text-align:center}.mascot-container{margin-bottom:10px;max-width:320px}.mascot-logo{height:auto;width:100%}.hero-title{font-size:3.5rem;line-height:1.2;margin:0 0 10px}.gradient-text{-webkit-text-fill-color:#0000;background:var(--color-accent-gradient);-webkit-background-clip:text;background-clip:text;color:#0000}.hero-tagline{color:var(--color-text-primary);font-size:1.5rem;line-height:1.5;margin:0 auto;max-width:800px}.tagline-part{color:var(--color-text-secondary)}.tagline-part-accent{color:#8cebc1;font-weight:600}.step-card{background-color:var(--color-bg-primary);border-radius:8px;box-shadow:0 2px 4px var(--color-shadow);margin-bottom:20px;padding:20px}.features-section{margin-top:40px}.features-section ul{padding-left:20px}.features-section li{margin-bottom:15px}.intro-text{font-size:1.1rem;line-height:1.5;margin-bottom:30px}.feedback-form{margin:0 auto;max-width:600px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);font-size:16px;padding:10px;width:100%}.form-group textarea{resize:vertical}.submit-button{background-color:var(--color-button-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background-color .3s}.submit-button:hover{background-color:var(--color-button-primary-hover)}.success-message{background-color:#f0f9f0;border-radius:8px;margin-top:20px;padding:30px;text-align:center}.reset-button{background-color:var(--color-button-primary);border-radius:4px;color:#fff;font-size:14px;margin-top:15px;padding:8px 16px}.reset-button:hover{background-color:var(--color-button-primary-hover)}@media (max-width:768px){.header-container{flex-direction:column;padding:10px}.site-branding{margin-bottom:15px}.nav-links{justify-content:center}.nav-links li{margin:0 5px}.hero-title{font-size:2.5rem}.hero-tagline{font-size:1.2rem}}@media (max-width:480px){.nav-links{flex-wrap:wrap}.nav-links li{margin:5px}.hero-title{font-size:2rem}.hero-tagline{font-size:1rem}}.theme-toggle-button{align-items:center;background:#0000;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:transform .3s,color .3s}.theme-toggle-button:hover{transform:scale(1.1)}.theme-toggle-icon{align-items:center;background:#0000;display:flex;font-size:1.25rem;justify-content:center}.dropzone{background-color:var(--color-bg-tertiary);border:2px dashed var(--color-border);border-radius:8px;color:var(--color-text-primary);cursor:pointer;margin-bottom:20px;padding:30px 20px;text-align:center;transition:all .2s ease}.dropzone.active,.dropzone:hover{background-color:var(--color-bg-primary);border-color:var(--color-text-accent)}.dropzone.active{box-shadow:0 0 0 2px #6366f133}.dropzone p{font-size:1rem;margin:0 0 10px}.dropzone-hint{color:var(--color-text-secondary);font-size:.8em!important}.image-settings{padding:0;width:100%}.settings-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:8px}.settings-header span{color:var(--color-text-primary);font-size:13px;font-weight:500}.reset-button{align-items:center;background:none;border:none;border-radius:3px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:12px;padding:3px 6px;transition:all .2s}.reset-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.setting-row{align-items:center;display:flex;margin-bottom:10px}.setting-row.weight-row{align-items:flex-start;flex-direction:column}.setting-label{color:var(--color-text-primary);font-size:14px;margin-right:10px}.weight-row .setting-label{margin-bottom:8px}.tooltip{cursor:help;margin-left:5px}.tooltip-icon{background-color:var(--color-bg-tertiary);display:inline-block;font-size:12px;font-weight:700;height:16px;line-height:16px;text-align:center;width:16px}.tooltip-text{top:50%;transform:translateY(-50%);transition:opacity .3s;z-index:100}.tooltip-text:before{border:5px solid #0000;border-right-color:#333333f2;margin-top:-5px;right:100%;top:50%}.slider-container{flex:1 1;margin-left:10px}.weight-row .slider-container{margin-left:0;width:100%}.weight-slider{margin:0;width:100%}.slider-labels{font-size:12px;margin-top:3px}.weight-value{color:var(--color-text-primary);font-weight:700}.crop-focus-container{border:1px solid var(--color-border);border-radius:4px;margin-bottom:15px;overflow:hidden}.crop-focus-image-container{cursor:crosshair;height:200px;position:relative;width:100%}.crop-focus-image{height:100%;object-fit:contain}.crop-focus-marker{background-color:#ffffff4d;border:2px solid #ff5722;border-radius:50%;box-shadow:0 0 0 1px #0000004d;height:12px;pointer-events:none;position:absolute;transform:translate(-50%,-50%);width:12px;z-index:5}.crop-focus-instructions{background-color:var(--color-bg-tertiary);border-top:1px solid var(--color-border);color:var(--color-text-secondary);font-size:13px;font-weight:400;letter-spacing:.3px;margin-top:0;padding:6px 8px}.setting-label input[type=checkbox]{cursor:pointer;height:16px;margin:0;width:16px}@media (max-width:600px){.tooltip-text{font-size:11px;width:200px}}.crop-focus-container{border-top:1px solid #e5e5e5;margin-top:15px;padding-top:15px;transform:none}.crop-focus-grid{border:1px solid #ddd;border-radius:4px;cursor:crosshair;margin-bottom:8px;overflow:hidden;position:relative;transform:none;width:100%}.crop-focus-image{display:block;transform:none;width:100%}.grid-overlay{height:100%;left:0;pointer-events:none;top:0;width:100%}.grid-line,.grid-overlay{position:absolute;transform:none}.grid-line{background-color:#ffffff80}.grid-line.horizontal{height:1px;width:100%}.grid-line.vertical{height:100%;width:1px}.focal-point{animation:pulse 1.5s infinite;background-color:red;border:2px solid #fff;border-radius:50%;box-shadow:0 0 5px #00000080;height:10px;pointer-events:none;position:absolute;width:10px;z-index:10}@keyframes pulse{0%{box-shadow:0 0 0 0 #ff0000b3}70%{box-shadow:0 0 0 5px #f000}to{box-shadow:0 0 0 0 #f000}}.crop-focus-instructions{color:#555;font-size:12px;margin-bottom:10px;text-align:center;transform:none}[data-theme=dark] .remove-button{background:#00000080;color:#fff}[data-theme=dark] .remove-button:hover{background:#000000b3}.image-preview{margin-bottom:30px}.image-grid{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.image-card{background-color:var(--color-bg-tertiary);border-radius:8px;padding:10px;position:relative;width:200px}.image-container{border:1px solid var(--color-border);border-radius:4px;height:150px;margin-bottom:10px;overflow:hidden;position:relative;width:100%}.preview-image{height:100%;object-fit:cover;width:100%}.remove-button{align-items:center;background:#ffffffb3;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;position:absolute;right:5px;top:5px;width:24px}.remove-button:hover{background:#ffffffe6}.tooltip{display:inline-flex;margin-left:8px;position:relative}.tooltip-icon{align-items:center;background:#0000;border-radius:50%;color:var(--color-text-secondary);cursor:help;display:inline-flex;font-size:11px;height:14px;justify-content:center;transition:all .2s ease;width:14px}.tooltip:hover .tooltip-icon{color:var(--color-text-primary)}.tooltip-text{word-wrap:break-word;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#333333f2;border-radius:4px;box-shadow:0 2px 8px var(--color-shadow);color:#fff;font-size:12px;left:calc(100% + 8px);line-height:1.3;opacity:0;padding:6px 10px;position:absolute;text-align:left;top:-6px;transform:none;transition:opacity .2s;visibility:hidden;white-space:normal;width:280px;z-index:1}.tooltip-text:before{border-bottom:6px solid #0000;border-right:6px solid #333333f2;border-top:6px solid #0000;content:"";height:0;left:-6px;position:absolute;top:12px;width:0}.tooltip.visible .tooltip-text{opacity:1;visibility:visible}.collage-settings{background:var(--color-bg-tertiary);border-radius:8px;margin-bottom:20px;max-width:600px;padding:20px}.setting-group{margin-bottom:24px;position:relative}.setting-label{align-items:center;display:flex;gap:8px;margin-bottom:12px;min-height:24px}.tooltip{margin-left:10px}.slider-container{margin-top:10px;max-width:300px;width:100%}.setting-slider{margin:10px 0;width:100%}.slider-labels{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.9em;justify-content:space-between;padding:0 5px}.slider-labels .value{font-weight:700}.aspect-ratio-select{appearance:none;background-color:var(--color-bg-primary);background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M6 9l6 6 6-6"/></svg>');background-position:right 12px center;background-repeat:no-repeat;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-primary);cursor:pointer;font-size:14px;padding:8px 36px 8px 12px;width:200px}.aspect-ratio-select:hover{border-color:var(--color-text-secondary)}.aspect-ratio-select:focus{border-color:var(--color-text-accent);box-shadow:0 0 0 2px #6366f133;outline:none}.color-picker{border:1px solid var(--color-border);border-radius:4px;cursor:pointer;height:28px;padding:0;transition:border-color .2s;width:50px}.color-picker:hover{border-color:var(--color-text-secondary)}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;height:16px;margin:0;width:16px}
/*# sourceMappingURL=main.843b740b.css.map*/