.image-upload-container{display:flex;gap:20px;margin-bottom:20px}.image-upload-section{flex:1 1}.image-upload-section h3{color:#333;font-size:16px;font-weight:600;margin:0 0 10px}.image-upload-area{align-items:center;border:2px dashed #ccc;border-radius:8px;cursor:pointer;display:flex;height:200px;justify-content:center;overflow:hidden;position:relative;transition:all .3s ease;width:100%}.image-upload-area:hover{background-color:#f8f9fa;border-color:#007bff}.image-upload-area.drag-over{background-color:#e3f2fd;border-color:#007bff}.upload-placeholder{color:#666;text-align:center}.upload-icon{font-size:48px;margin-bottom:10px}.upload-placeholder p{margin:5px 0}.file-types{color:#999;font-size:12px}.image-preview{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.image-preview img{border-radius:4px;max-height:100%;max-width:100%;object-fit:contain}.image-overlay{align-items:center;background:#000000b3;border-radius:4px;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.image-preview:hover .image-overlay{opacity:1}.image-overlay span{color:#fff;font-weight:500}.processed-image-area{align-items:center;background-color:#f8f9fa;border:1px solid #ddd;border-radius:8px;display:flex;height:200px;justify-content:center;width:100%}.processing-indicator{color:#666;text-align:center}.spinner{margin:0 auto 10px}.placeholder{color:#999;text-align:center}.placeholder p{margin:0}.text-to-image-section{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.text-prompt-input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .3s ease;width:100%}.text-prompt-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.text-prompt-input:disabled{background-color:#f8f9fa;cursor:not-allowed}.generate-button{background-color:#007bff;border-radius:6px;font-size:14px;padding:12px 20px;transition:background-color .3s ease}.generate-button:hover:not(:disabled){background-color:#0056b3}.generate-button:disabled{background-color:#6c757d}.generated-images-grid{margin:15px 0}.generated-images-grid h4{color:#333;font-size:14px;margin:0 0 10px}.image-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr)}.generated-image{aspect-ratio:1;border:2px solid #0000;border-radius:6px;cursor:pointer;overflow:hidden;transition:all .3s ease}.generated-image:hover{border-color:#007bff;transform:scale(1.02)}.generated-image.selected{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.generated-image img{display:block;height:100%;object-fit:cover;width:100%}.upload-divider{margin:20px 0;position:relative;text-align:center}.upload-divider:before{background-color:#ddd;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.upload-divider span{background-color:#fff;color:#666;font-size:14px;font-weight:500;padding:0 15px}.model-viewer{display:flex;flex-direction:column;height:100%}.model-viewer-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.model-viewer-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.model-controls{display:flex;gap:10px}.download-button{background:#28a745;border-radius:4px;color:#fff;font-size:12px;font-weight:500;padding:6px 12px;text-decoration:none;transition:background-color .2s}.download-button:hover{background:#218838}.model-viewer-content{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;flex:1 1;min-height:400px;overflow:hidden;position:relative}.model-placeholder,.model-status{align-items:center;color:#666;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.placeholder-icon{font-size:64px;margin-bottom:15px;opacity:.5}.model-placeholder p{margin:5px 0}.placeholder-note{color:#999;font-size:12px}.model-status p{margin:5px 0}.status-note{color:#999;font-size:12px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:15px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.model-loading{color:#fff;text-align:center}.model-loading .spinner{border:4px solid #ffffff4d;border-top-color:#fff}.model-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;color:#666;font-size:12px;margin-top:10px;padding:10px}.model-info p{margin:3px 0}.model-info p:first-child{margin-top:0}.model-info p:last-child{margin-bottom:0}@media (max-width:768px){.model-viewer-content{min-height:300px}.placeholder-icon{font-size:48px}.model-info{font-size:11px}}.parameter-controls{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-bottom:20px;padding:20px}.parameter-controls h3{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.control-group{margin-bottom:15px}.control-group:last-child{margin-bottom:0}.control-group label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:5px}.slider{background:#ddd;border-radius:3px;height:6px;margin:8px 0;opacity:.7;outline:none;transition:opacity .2s;width:100%}.slider:hover{opacity:1}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#007bff;border-radius:50%;cursor:pointer;height:18px;width:18px}.slider::-moz-range-thumb{background:#007bff;border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.slider:disabled{cursor:not-allowed;opacity:.4}.slider:disabled::-webkit-slider-thumb{cursor:not-allowed}.value{background:#e9ecef;border-radius:3px;color:#666;float:right;font-size:12px;min-width:30px;padding:2px 6px;text-align:center}.checkbox-row{gap:15px}.checkbox-label,.checkbox-row{align-items:center;display:flex}.checkbox-label{gap:8px;margin-bottom:0!important;min-width:120px}.checkbox-label input[type=checkbox]{margin:0}.face-count-input,.seed-input{flex:1 1}.face-count-input label,.seed-input label{font-size:12px;margin-bottom:0!important}.number-input{border:1px solid #ccc;border-radius:4px;font-size:12px;margin-top:3px;padding:4px 8px;width:100%}.number-input:disabled{background-color:#e9ecef;cursor:not-allowed}.number-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.App{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh}.App-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #0000001a;color:#fff;padding:20px;text-align:center}.App-header h1{font-size:28px;font-weight:700;margin:0 0 10px}.App-header p{font-size:16px;margin:0 0 15px;opacity:.9}.App-links{display:flex;gap:20px;justify-content:center}.App-links a{border:1px solid #ffffff4d;border-radius:20px;color:#fff;font-size:14px;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .3s ease}.App-links a:hover{background:#ffffff1a;border-color:#ffffff80}.App-main{margin:0 auto;max-width:1400px;padding:30px 20px}.App-container{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;min-height:600px}.App-left-panel,.App-right-panel{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:20px}.App-right-panel{display:flex;flex-direction:column}.generate-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:15px;padding:12px 24px;transition:all .3s ease;width:100%}.generate-button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.generate-button:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.seed-display{background:#e8f5e8;border:1px solid #d4edda;border-radius:4px;color:#155724;font-size:14px;padding:10px;text-align:center}.error-message{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;margin-top:20px;padding:15px}.App-info,.error-message{border-radius:8px;text-align:center}.App-info{background:#fffc;margin-top:30px;padding:20px}.App-info p{color:#555;font-size:14px;margin:8px 0}@media (max-width:768px){.App-container{gap:20px;grid-template-columns:1fr}.App-main{padding:20px 15px}.App-header h1{font-size:24px}.App-header p{font-size:14px}.App-links{align-items:center;flex-direction:column;gap:10px}}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;margin:0}
/*# sourceMappingURL=main.869a7ec8.css.map*/