@import"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;color:#e2e8f0;background:#0f0f23;min-height:100vh}.app{min-height:100vh}.home-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;background:linear-gradient(135deg,#0f0f23,#1e1e3f)}.hero{margin-bottom:4rem}.hero h1{font-size:3rem;margin-bottom:1rem;color:#fff;font-weight:700;text-shadow:0 4px 8px rgba(0,0,0,.3);display:flex;align-items:center;gap:.75rem;justify-content:center}.hero p{font-size:1.25rem;color:#94a3b8;margin-bottom:2rem}.cta-button{background:#ffb26b;color:#1a1a2e;border:none;padding:1rem 3rem;font-size:1.125rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px #ffb26b4d}.cta-button:hover{background:#ffa857;transform:translateY(-2px);box-shadow:0 6px 20px #ffb26b66}.features{display:flex;align-items:center;justify-content:center;gap:1.5rem;max-width:1200px;width:100%;flex-wrap:wrap}.feature{flex:1;min-width:250px;max-width:300px;padding:2rem;background:#1e2139;border-radius:12px;box-shadow:0 4px 16px #0003;border:1px solid #2d3748}.feature-arrow{display:flex;align-items:center;justify-content:center;color:#ffb26b;opacity:.8;flex-shrink:0}.animate-arrow{animation:arrowPulse 2s ease-in-out 3;animation-delay:1s}@keyframes arrowPulse{0%,to{transform:translate(0);opacity:.8}50%{transform:translate(5px);opacity:1}}.feature h3{margin-bottom:.5rem;color:#ffb26b;font-weight:600}.feature p{color:#94a3b8}.visualizer-page{min-height:100vh;background:#0f0f23}.page-header{background:linear-gradient(135deg,#1e2139,#2d3748);color:#fff;padding:1.5rem 2rem;border-bottom:1px solid #2d3748}.page-header h1{margin-bottom:1rem;font-weight:700;display:flex;align-items:center;gap:.5rem;justify-content:center}.header-logo{height:2rem;width:auto;filter:none}.hero .header-logo{height:3rem}.steps-indicator{display:flex;gap:2rem;justify-content:center}.step{opacity:.6;transition:opacity .3s;font-weight:500;color:#94a3b8}.step.active{opacity:1;font-weight:700;color:#ffb26b}.page-content{padding:2rem;max-width:1400px;margin:0 auto}.back-button{background:none;border:2px solid rgb(255,178,107);color:#ffb26b;padding:.5rem 1rem;border-radius:6px;cursor:pointer;margin-bottom:1rem;font-weight:500;transition:all .2s}.back-button:hover{background:#ffb26b;color:#1a1a2e}.image-upload{max-width:800px;margin:0 auto}.upload-area{border:2px dashed #4a5568;border-radius:12px;padding:3rem;text-align:center;transition:all .3s;background:#1e2139}.upload-area.drag-active{border-color:#ffb26b;background:#ffb26b1a}.upload-icon{color:#ffb26b;margin-bottom:1rem}.upload-button{background:#ffb26b;color:#1a1a2e;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;margin:1rem 0;font-weight:600;transition:all .2s}.upload-button:hover{background:#ffa857}.upload-buttons{display:flex;gap:1rem;justify-content:center;margin:1rem 0;flex-wrap:wrap}.camera-button{background:#10b981;color:#fff}.camera-button:hover{background:#059669}.file-button{background:#ffb26b;color:#1a1a2e}.file-button:hover{background:#ffa857}.upload-text{color:#e2e8f0;margin-bottom:1rem}.upload-info{color:#94a3b8;font-size:.875rem}.preview-container{position:relative}.preview-image{max-width:100%;max-height:400px;border-radius:8px}.change-image-button{position:absolute;bottom:1rem;right:1rem;background:#1e2139e6;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500}.error-message{color:#f56565;margin-top:1rem;font-weight:500}.spa-selector{width:100%}.filter-group select{padding:.5rem;border:2px solid #4a5568;border-radius:6px;font-weight:500;background:#2d3748;color:#e2e8f0}.filter-group select:focus{outline:none;border-color:#ffb26b}.spa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:2rem;max-width:1400px;margin:0 auto 2rem}.spa-card{border:2px solid #2d3748;border-radius:12px;padding:.75rem;cursor:pointer;transition:all .3s;background:#1e2139}.spa-card:hover{border-color:#ffb26b;transform:translateY(-4px);box-shadow:0 8px 24px #0000004d}.spa-card.selected{border-color:#ffb26b;background:#ffb26b1a;box-shadow:0 4px 16px #ffb26b4d}.spa-image{width:100%;height:100px;object-fit:contain;border-radius:8px;margin-bottom:.5rem;background:#f8fafc}.spa-name{margin-bottom:.5rem;font-weight:700;font-size:1rem;color:#fff}.spa-details p{color:#94a3b8;font-size:.8rem;margin-bottom:.2rem}.spa-price{font-size:1.1rem;font-weight:700;color:#ffb26b;margin-top:.5rem}.spa-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.spa-tag{background:#ffb26b33;color:#ffb26b;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.selection-panel{position:sticky;bottom:0;background:#1e2139;border-top:2px solid #2d3748;padding:1.5rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 -4px 12px #0003;flex-wrap:wrap;gap:1rem}.selected-spa-info h3{color:#fff;font-weight:700;margin-bottom:.5rem}.selected-spa-info p{color:#94a3b8;font-size:.875rem;margin-bottom:.25rem}.confirm-button{background:#ffb26b;color:#1a1a2e;border:none;padding:.75rem 2rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.confirm-button:hover{background:#ffa857}.visualizer{display:flex;gap:2rem;align-items:flex-start}.visualization-wrapper{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.visualization-container{position:relative;background:#1e2139;border-radius:12px;overflow:hidden;border:2px solid #2d3748;width:100%}.controls{width:400px;flex-shrink:0}.result-image{max-width:100%;width:auto;height:auto;display:block;image-rendering:crisp-edges;image-rendering:-webkit-optimize-contrast;margin:0 auto}.image-disclaimer{margin-top:.5rem;margin-bottom:0;color:#94a3b8;font-size:.75rem;text-align:center;font-style:italic;opacity:.8}.mobile-save-tip{display:none;margin-top:.5rem;font-size:.85rem;color:#94a3b8;font-style:italic}@media (max-width: 768px){.visualization-wrapper{width:100%;max-width:100%}.visualization-container{max-width:100%;width:100%;min-width:100%;margin:0 auto}.result-image{width:100%;max-width:100%;height:auto;display:block}.visualizer-page{padding:.5rem}.page-header{padding:1rem;text-align:center}.page-header h1{font-size:1.5rem}}.processing-overlay{position:absolute;inset:0;background:#1e2139f2;display:flex;flex-direction:column;align-items:center;justify-content:center}.spinner{width:50px;height:50px;border:4px solid #4a5568;border-top:4px solid rgb(255,178,107);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-tip{color:#ffb26b;font-size:.875rem;margin-top:1rem;font-weight:500;text-align:center;max-width:300px;line-height:1.4;transition:opacity .5s ease-in-out}.error-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1e2139;padding:2rem;border-radius:8px;box-shadow:0 4px 16px #0000004d;text-align:center;border:1px solid #2d3748}.error-overlay button{background:#ffb26b;color:#1a1a2e;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;margin-top:1rem}.controls{display:flex;flex-direction:column;gap:2rem}.adjustment-panel{background:#1e2139;padding:1.5rem;border-radius:12px;border:2px solid #2d3748}.adjustment-panel h3{margin-bottom:1rem;color:#fff;font-weight:700}.regenerate-section{margin-bottom:1.5rem;padding:1rem;background:#ffb26b1a;border-radius:8px;text-align:center;border:1px solid rgba(255,178,107,.2)}.regenerate-button{background:#ffb26b;color:#1a1a2e;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s;margin-bottom:.5rem;box-shadow:0 2px 8px #ffb26b4d}.regenerate-button:hover:not(:disabled){background:#ffa857;transform:translateY(-2px);box-shadow:0 4px 12px #ffb26b66}.regenerate-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.reset-button{background:#4a5568;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .2s;margin-bottom:.5rem;margin-top:1rem;width:100%}.reset-button:hover:not(:disabled){background:#2d3748}.reset-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.reset-info{color:#94a3b8;font-size:.875rem;margin-bottom:1rem;text-align:center}.regenerate-info{color:#94a3b8;font-size:.875rem;margin:0;font-style:italic}.quick-commands{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.quick-commands button{padding:.5rem;border:2px solid #4a5568;background:#2d3748;color:#e2e8f0;border-radius:6px;cursor:pointer;transition:all .3s;font-weight:500}.quick-commands button:hover:not(:disabled){border-color:#ffb26b;background:#ffb26b1a;color:#ffb26b}.quick-commands button:disabled{opacity:.6;cursor:not-allowed;border-color:#4a5568;background:#2d3748;color:#94a3b8}.output-panel{background:#1e2139;padding:1.5rem;border-radius:12px;border:2px solid #2d3748}.output-panel h3{margin-bottom:1rem;color:#fff;font-weight:700}.output-buttons{display:flex;gap:1rem;margin-bottom:1.5rem}.download-button{width:100%;padding:.75rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s;background:#22c55e;color:#fff}.download-button:hover:not(:disabled){background:#16a34a}.download-button:disabled{background:#4a5568;cursor:not-allowed}.spa-info{background:#2d3748;padding:1.5rem;border-radius:8px;border:2px solid #4a5568}.spa-info h4{margin-bottom:.5rem;color:#ffb26b;font-weight:700}.spa-info p{color:#94a3b8;font-size:.875rem;margin-bottom:.25rem}.image-quality-info{margin:.75rem 0;padding:.5rem;background:#3b82f61a;border-radius:.375rem;border:1px solid rgba(59,130,246,.2)}.image-dimensions{color:#60a5fa!important;font-weight:500;font-family:monospace}.quality-note{color:#34d399!important;font-size:.8rem!important;font-style:italic}.product-link{margin-top:1rem}.view-product-button{display:inline-block;background:#ffb26b;color:#1a1a2e;text-decoration:none;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:.875rem;transition:all .2s}.view-product-button:hover{background:#ffa857;transform:translateY(-1px)}.loading{color:#ffb26b;font-weight:600}.disclaimer{margin-top:35px;padding:1.5rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:8px;text-align:left}.disclaimer h4{color:#60a5fa;font-weight:600;margin-bottom:.75rem;font-size:1rem}.disclaimer p{color:#cbd5e1;font-size:.875rem;line-height:1.5;margin:0}.example-spaces{max-width:1000px;margin:3rem auto 0;padding:2.5rem;background:#1a1a3acc;border-radius:16px;border:1px solid rgb(255,178,107,.3);box-shadow:0 8px 32px #0003}.example-spaces-title{color:#fff;font-size:1.8rem;font-weight:700;text-align:center;margin-bottom:.5rem}.example-spaces-subtitle{color:#94a3b8;text-align:center;margin-bottom:2rem;font-size:1rem}.example-spaces-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;justify-items:center;max-width:1200px;margin:0 auto}.example-space-card{background:#1e2139;border:2px solid #2d3748;border-radius:16px;padding:1rem;cursor:pointer;transition:all .3s ease;text-align:center;max-width:250px;box-shadow:0 4px 12px #00000026}.example-space-card:hover{border-color:#ffb26b;transform:translateY(-4px);box-shadow:0 8px 24px #ffb26b33}.example-space-image{width:100%;height:140px;object-fit:cover;border-radius:12px;margin-bottom:.75rem}.example-space-label{color:#e2e8f0;font-weight:600;font-size:.9rem;margin:0}.time-control{display:flex;flex-direction:column;gap:1rem}.time-display{text-align:center;padding:.75rem;background:#2d3748;border-radius:6px;border:1px solid #4a5568}.time-value{color:#ffb26b;font-weight:600;font-size:.875rem}.time-slider{width:100%;height:6px;border-radius:3px;background:#4a5568;outline:none;cursor:pointer}.time-slider::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:#ffb26b;cursor:pointer;border:2px solid #1e2139}.time-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#ffb26b;cursor:pointer;border:2px solid #1e2139}.time-slider:disabled{opacity:.6;cursor:not-allowed}.time-apply-button{background:#ffb26b;color:#1a1a2e;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:.875rem;transition:all .2s}.time-apply-button:hover:not(:disabled){background:#ffa857;transform:translateY(-1px)}.time-apply-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.hero h1{font-size:2rem}.hero p{font-size:1rem}.features{flex-direction:column;gap:2rem;align-items:center}.feature-arrow{display:none}.feature{max-width:100%;width:100%}.visualizer{flex-direction:column;gap:1rem;padding:1rem}.controls{width:100%;order:2}.visualization-container{order:1}.spa-grid{grid-template-columns:1fr;gap:1rem}.filters{flex-direction:column;gap:1rem}.upload-button{padding:1rem 1.5rem;font-size:1rem;min-height:48px}.upload-buttons{flex-direction:column;gap:.75rem;align-items:center}.upload-buttons .upload-button{width:100%;max-width:280px}.example-spaces{margin:1rem auto 0;padding:1.5rem}.example-spaces-grid{grid-template-columns:1fr;gap:1rem}.example-space-card{max-width:100%}.quick-commands{grid-template-columns:1fr;gap:.75rem}.quick-commands button{padding:.875rem;font-size:.95rem;min-height:48px}.regenerate-button,.time-apply-button,.download-button{min-height:48px;padding:.875rem 1.5rem}.upload-area{padding:2rem 1rem;margin:1rem 0}.upload-icon{width:48px;height:48px}.steps-indicator{flex-direction:column;gap:.5rem;text-align:center}.step{padding:.75rem 1rem;font-size:.875rem}.selection-panel{flex-direction:column;align-items:stretch}.quick-commands{grid-template-columns:1fr}.spa-card{padding:.75rem}}
