*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f1a;height:100vh;overflow:hidden;color:#fff}.dashboard-container{display:flex;height:100vh;overflow:hidden}.sidebar{width:420px;background:linear-gradient(180deg,#1a1a2e,#16213e);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:24px 24px 0;flex-shrink:0}.logo{font-size:28px;font-weight:800;margin-bottom:24px;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;letter-spacing:-.5px}.module-nav{display:flex;gap:6px;background:#ffffff0a;padding:6px;border-radius:14px;border:1px solid rgba(255,255,255,.06)}.module-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;background:transparent;border:none;border-radius:10px;color:#6b7a99;font-size:11px;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.module-tab svg{width:22px;height:22px;transition:transform .25s ease}.module-tab:hover{color:#a0aec0;background:#ffffff0a}.module-tab:hover svg{transform:scale(1.1)}.module-tab.active{background:linear-gradient(135deg,#667eea40,#764ba240);color:#fff;box-shadow:0 4px 12px #667eea33}.module-tab.active svg{stroke:#667eea}.sidebar-scroll{flex:1;overflow-y:auto;padding:20px 24px 24px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.sidebar-scroll::-webkit-scrollbar{width:5px}.sidebar-scroll::-webkit-scrollbar-track{background:transparent}.sidebar-scroll::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff40}.module-content{animation:fadeSlideIn .3s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.module-intro{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.06)}.module-title{font-size:20px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:-.3px}.module-description{font-size:13px;color:#8b9dc3;line-height:1.5}.accordion{margin-bottom:12px;background:#ffffff08;border-radius:14px;border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:all .25s ease}.accordion:hover{border-color:#ffffff1a}.accordion.open{border-color:#667eea4d;box-shadow:0 4px 20px #667eea1a}.accordion-header{width:100%;display:flex;align-items:center;gap:12px;padding:16px 18px;background:transparent;border:none;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.accordion-header:hover{background:#ffffff08}.accordion-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;opacity:.7}.accordion-icon svg{width:18px;height:18px;stroke:currentColor;stroke-width:1.5}.accordion-title{flex:1;text-align:left}.accordion-chevron{width:18px;height:18px;color:#6b7a99;transition:transform .25s ease}.accordion.open .accordion-chevron{transform:rotate(180deg);color:#667eea}.accordion-content{max-height:0;overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}.accordion.open .accordion-content{max-height:1000px}.accordion-inner{padding:0 18px 18px}.main-content{flex:1;background:#0f0f1a;overflow:hidden;padding:24px;display:flex;flex-direction:column}.results-panel{max-width:1000px;margin:0 auto;flex:1;display:flex;flex-direction:column;overflow:hidden}.form-section{margin-bottom:20px;background:#ffffff08;border-radius:14px;padding:20px;border:1px solid rgba(255,255,255,.06)}.form-section h3{font-size:12px;font-weight:700;color:#8b9dc3;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px}.form-group{margin-bottom:18px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;color:#e2e8f0;margin-bottom:10px;font-weight:500}select,input[type=number],input[type=text]{width:100%;padding:14px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:14px;transition:all .2s ease}select:hover,input[type=number]:hover,input[type=text]:hover{border-color:#fff3;background:#ffffff14}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.number-input-wrapper{position:relative;display:flex;align-items:stretch}.number-input-wrapper input{flex:1;padding-right:40px}.number-controls{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:2px}.number-btn{background:transparent;border:none;color:#8b9dc3;font-size:8px;padding:3px 6px;cursor:pointer;line-height:1;transition:all .2s;border-radius:4px}.number-btn:hover{color:#667eea;background:#667eea26}.number-btn:active{color:#fff;transform:scale(.9)}.ambiance-options{max-height:0;overflow:hidden;opacity:0;transition:max-height .35s ease,opacity .25s ease,margin .3s ease;margin-top:0}.ambiance-options.visible{max-height:350px;opacity:1;margin-top:18px}select:focus,input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea33}select option{background:#1a1a2e;color:#fff}.radio-group{display:flex;gap:10px}.radio-option{flex:1;padding:14px 10px;background:#ffffff0a;border:2px solid rgba(255,255,255,.08);border-radius:12px;cursor:pointer;transition:all .25s ease;text-align:center}.radio-option:hover{border-color:#667eea66;background:#667eea14;transform:translateY(-2px)}.radio-option.selected{border-color:#667eea;background:#667eea26;box-shadow:0 4px 12px #667eea33}.radio-option input{display:none}.radio-option span{font-size:13px;color:#e2e8f0;font-weight:500}.dropzone{border:2px dashed rgba(255,255,255,.15);border-radius:14px;padding:32px 24px;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff05}.dropzone:hover,.dropzone.active{border-color:#667eea;background:#667eea14;transform:translateY(-2px);box-shadow:0 8px 25px #667eea26}.dropzone-icon{font-size:44px;margin-bottom:12px}.dropzone p{color:#8b9dc3;font-size:14px;line-height:1.6}.dropzone p small{opacity:.7}.mini-dropzone{padding:18px}.mini-dropzone p{font-size:12px}.uploaded-preview{border-radius:12px;overflow:hidden;position:relative;background:#0000004d}.uploaded-preview img{width:100%;max-height:200px;object-fit:contain}.mini-preview img{max-height:110px}.remove-image{position:absolute;top:10px;right:10px;background:#ef4444e6;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #ef44444d}.remove-image:hover{transform:scale(1.1);box-shadow:0 4px 12px #ef444466}.section-hint{font-size:12px;color:#8b9dc3;margin-bottom:14px;line-height:1.5}.layer-group{margin-bottom:20px;padding:14px;background:#ffffff05;border-radius:12px;border:1px solid rgba(255,255,255,.05)}.layer-group:last-child{margin-bottom:0}.layer-group-header{display:flex;align-items:center;gap:7px;margin-bottom:12px;font-size:10px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.8px}.layer-group-header svg{opacity:.7;stroke:#667eea}.slot-with-toggle{display:flex;flex-direction:column;align-items:center;min-width:0}.slot-with-toggle .garment-slot{width:100%}.shirt-open-toggle-inline{display:flex;align-items:center;gap:6px;margin-top:8px;padding:4px 8px;background:#667eea14;border-radius:6px;border:1px solid rgba(102,126,234,.15);width:100%;justify-content:center}.toggle-label-mini{font-size:9px;font-weight:600;color:#a5b4fc;text-transform:uppercase;letter-spacing:.3px}.toggle-switch-mini{position:relative;display:inline-block;width:28px;height:16px;flex-shrink:0}.toggle-switch-mini input{opacity:0;width:0;height:0}.toggle-slider-mini{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ffffff1a;transition:.3s;border-radius:16px}.toggle-slider-mini:before{position:absolute;content:"";height:12px;width:12px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch-mini input:checked+.toggle-slider-mini{background-color:#667eea}.toggle-switch-mini input:checked+.toggle-slider-mini:before{transform:translate(12px)}.toggle-switch-mini input:disabled+.toggle-slider-mini{opacity:.4;cursor:not-allowed}.toggle-disabled{opacity:.4;pointer-events:none}.garment-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.garment-slots-single{grid-template-columns:1fr;max-width:33.33%}.garment-slots-accessories{grid-template-columns:1.2fr .8fr .8fr}.garment-slot{display:flex;flex-direction:column;align-items:center;min-width:0}.garment-slot-small .slot-dropzone,.garment-slot-small .slot-preview{aspect-ratio:1;max-width:72px;max-height:72px}.garment-slot-small .slot-icon{font-size:20px}.garment-slot-small .slot-remove{width:18px;height:18px;font-size:10px;top:3px;right:3px}.slot-label{font-size:10px;font-weight:600;color:#8b9dc3;margin-bottom:6px;text-align:center;max-width:100%;line-height:1.3;min-height:26px;display:flex;align-items:flex-end;justify-content:center;word-break:break-word}.slot-dropzone{width:100%;aspect-ratio:1;border:2px dashed rgba(255,255,255,.12);border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;background:#ffffff05}.slot-dropzone:hover,.slot-dropzone.active{border-color:#667eea;background:#667eea14;transform:scale(1.03)}.slot-icon{font-size:24px;color:#fff3}.slot-preview{width:100%;aspect-ratio:1;position:relative;border-radius:10px;overflow:hidden}.slot-preview img{width:100%;height:100%;object-fit:cover;border-radius:10px}.slot-remove{position:absolute;top:4px;right:4px;background:#ef4444e6;border:none;color:#fff;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:0}.slot-preview:hover .slot-remove{opacity:1}.slot-remove:hover{transform:scale(1.1)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.05)}.toggle-row:last-of-type{border-bottom:none}.toggle-label{font-size:14px;color:#e2e8f0;font-weight:500}.toggle-switch{position:relative;cursor:pointer}.toggle-switch input{display:none}.toggle-slider{display:block;width:48px;height:26px;background:#ffffff1f;border-radius:13px;transition:background .3s;position:relative}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #00000040}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2)}.toggle-switch input:checked+.toggle-slider:after{transform:translate(22px)}.hint{display:block;font-size:11px;color:#6b7a99;margin-top:10px;font-style:italic}.generate-btn{width:100%;padding:18px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:16px;box-shadow:0 6px 20px #667eea59;letter-spacing:.3px}.generate-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #667eea73}.generate-btn:active:not(:disabled){transform:translateY(-1px)}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.error-message{background:#ef44441f;border:1px solid rgba(239,68,68,.35);border-radius:12px;padding:14px 18px;margin-bottom:16px;color:#fca5a5;font-size:13px}.ghost-result{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}.ghost-result h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:16px}.tool-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.tool-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#9ca3af;font-size:12px;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1)}.tool-option:hover{background:#ffffff14;border-color:#fff3;color:#e5e7eb;transform:translateY(-2px)}.tool-option.active{background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea80;color:#fff;box-shadow:0 4px 20px #667eea33}.tool-option svg{opacity:.7;transition:all .25s}.tool-option:hover svg,.tool-option.active svg{opacity:1;stroke:#a78bfa}.color-picker-container{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:12px}.color-picker{width:48px;height:48px;border:none;border-radius:10px;cursor:pointer;background:transparent;padding:0}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border-radius:8px;border:2px solid rgba(255,255,255,.2)}.color-value{font-family:SF Mono,Fira Code,monospace;font-size:14px;font-weight:500;color:#9ca3af;letter-spacing:.5px}.batch-preview-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:16px}.batch-preview-item{aspect-ratio:1;border-radius:8px;overflow:hidden;background:#0000004d}.batch-preview-item img{width:100%;height:100%;object-fit:cover}.clear-batch-btn{width:100%;margin-top:12px;padding:10px;background:transparent;border:1px solid rgba(239,68,68,.4);border-radius:10px;color:#fca5a5;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.clear-batch-btn:hover{background:#ef44441f}.batch-settings-summary{background:#ffffff08;border-radius:10px;padding:14px}.setting-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.setting-item:last-child{border-bottom:none}.setting-label{font-size:13px;color:#8b9dc3}.setting-value{font-size:13px;color:#e2e8f0;font-weight:500}.batch-hint{font-size:11px;color:#6b7a99;margin-top:12px;text-align:center}.batch-results{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08)}.batch-results-info{margin-top:16px;padding:12px 16px;background:#667eea26;border:1px solid rgba(102,126,234,.3);border-radius:10px;text-align:center}.batch-results-info p{font-size:13px;color:#a0aec0;margin:0}.batch-results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.batch-results-header h4{font-size:14px;font-weight:600;color:#fff;margin:0}.download-zip-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.download-zip-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.download-zip-btn:disabled{opacity:.6;cursor:not-allowed}.batch-results h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:16px}.batch-results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.batch-results-grid-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.batch-result-item{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;background:#0000004d}.batch-result-item.transparent-bg{background-image:linear-gradient(45deg,#1a1a2e 25%,transparent 25%),linear-gradient(-45deg,#1a1a2e 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a2e 75%),linear-gradient(-45deg,transparent 75%,#1a1a2e 75%);background-size:12px 12px;background-position:0 0,0 6px,6px -6px,-6px 0px;background-color:#0d0d1a}.batch-result-item img{width:100%;height:100%;object-fit:cover}.batch-info-section{margin-bottom:0}.batch-feature-info{display:flex;align-items:flex-start;gap:14px;padding:16px;background:#667eea1f;border:1px solid rgba(102,126,234,.25);border-radius:12px}.batch-feature-info svg{flex-shrink:0;color:#667eea;margin-top:2px}.batch-feature-text h4{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.batch-feature-text p{font-size:12px;color:#8b95a5;line-height:1.4}.batch-action-btn svg{flex-shrink:0;opacity:.6}.batch-action-btn.active svg{opacity:1;stroke:#667eea}.batch-action-btn span{font-size:14px;font-weight:600}.batch-action-btn small{display:block;font-size:11px;font-weight:400;opacity:.6;margin-top:2px}.batch-progress-container{margin:16px 0;padding:16px;background:#667eea1a;border-radius:10px;border:1px solid rgba(102,126,234,.2)}.batch-progress-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:10px}.batch-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.batch-progress-text{font-size:13px;color:#8b95a5;text-align:center;display:block}.batch-results-main{padding:24px;height:100%;overflow-y:auto}.batch-progress-info{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:15px;font-weight:500;color:#fff}.progress-icon{font-size:20px}.progress-bar-track{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.batch-results-header-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.08)}.batch-results-header-main h3{font-size:18px;font-weight:600;color:#fff}.download-zip-btn-main{display:flex;align-items:center;gap:10px;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .25s ease}.download-zip-btn-main:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea59}.download-zip-btn-main:disabled{opacity:.6;cursor:not-allowed;transform:none}.batch-grid-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.batch-grid-item{position:relative;aspect-ratio:3/4;border-radius:12px;overflow:hidden;background-image:linear-gradient(45deg,#2a2a3e 25%,transparent 25%),linear-gradient(-45deg,#2a2a3e 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2a3e 75%),linear-gradient(-45deg,transparent 75%,#2a2a3e 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;background-color:#1a1a2e;cursor:pointer;transition:all .25s ease}.batch-grid-item:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0006}.batch-grid-item.transparent-bg{background-image:linear-gradient(45deg,#2a2a3e 25%,transparent 25%),linear-gradient(-45deg,#2a2a3e 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2a3e 75%),linear-gradient(-45deg,transparent 75%,#2a2a3e 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;background-color:#1a1a2e}.batch-grid-item img{width:100%;height:100%;object-fit:cover}.batch-item-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease}.batch-grid-item:hover .batch-item-overlay{opacity:1}.zoom-icon{font-size:28px}.batch-item-download{position:absolute;bottom:10px;right:10px;width:36px;height:36px;border-radius:50%;background:#667eeae6;border:none;color:#fff;font-size:16px;cursor:pointer;opacity:0;transform:translateY(10px);transition:all .25s ease}.batch-grid-item:hover .batch-item-download{opacity:1;transform:translateY(0)}.batch-item-download:hover{background:#764ba2;transform:scale(1.1)}.batch-loading-placeholder{display:flex;align-items:center;justify-content:center;height:200px;color:#6b7a99;font-size:15px}.tabs-header{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid rgba(255,255,255,.08)}.tab-btn{background:transparent;border:none;padding:16px 32px;font-size:15px;font-weight:600;color:#6b7a99;cursor:pointer;position:relative;transition:all .25s ease}.tab-btn:hover{color:#a0aec0}.tab-btn.active{color:#fff}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px 2px 0 0}.section-title{font-size:18px;font-weight:600;color:#fff;margin-bottom:20px}.result-section{margin-bottom:40px;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.result-section::-webkit-scrollbar{width:5px}.result-section::-webkit-scrollbar-track{background:transparent}.result-section::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.result-container{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:28px}.result-placeholder{text-align:center;padding:80px 24px;color:#6b7a99}.result-placeholder-icon{font-size:64px;margin-bottom:20px;opacity:.35}.result-placeholder p{font-size:15px}.result-image-container{position:relative;display:inline-block}.result-image{max-width:100%;max-height:520px;border-radius:14px;box-shadow:0 25px 60px #00000073}.checkerboard-bg{background-image:linear-gradient(45deg,#e0e0e0 25%,transparent 25%),linear-gradient(-45deg,#e0e0e0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e0e0e0 75%),linear-gradient(-45deg,transparent 75%,#e0e0e0 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;background-color:#fff;border-radius:14px;padding:10px}.checkerboard-bg .result-image{display:block;box-shadow:none}.overlay-download-btn{position:absolute;top:14px;right:14px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#667eea99;border:none;border-radius:12px;color:#fff;font-size:20px;cursor:pointer;transition:all .3s ease;opacity:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.result-image-container:hover .overlay-download-btn{opacity:1}.overlay-download-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);transform:scale(1.08);box-shadow:0 6px 20px #667eea73}.image-action-buttons{position:absolute;top:14px;right:14px;display:flex;gap:8px;opacity:0;transition:opacity .3s ease}.result-image-container:hover .image-action-buttons{opacity:1}.image-action-buttons .overlay-download-btn,.image-action-buttons .overlay-edit-btn{position:static;opacity:1}.overlay-edit-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#eab30899;border:none;border-radius:12px;color:#fff;font-size:20px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.overlay-bg-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#10b98199;border:none;border-radius:12px;color:#fff;font-size:20px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.overlay-bg-btn:hover{background:linear-gradient(135deg,#10b981,#059669);transform:scale(1.08);box-shadow:0 6px 20px #10b98173}.overlay-edit-btn:hover{background:linear-gradient(135deg,#eab308,#f59e0b);transform:scale(1.08);box-shadow:0 6px 20px #eab30873}.mini-edit-btn{position:absolute;top:10px;right:56px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#eab30899;border:none;border-radius:10px;color:#fff;cursor:pointer;transition:all .3s ease;opacity:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.grid-image-container:hover .mini-edit-btn{opacity:1}.mini-edit-btn:hover{background:linear-gradient(135deg,#eab308,#f59e0b);transform:scale(1.08);box-shadow:0 4px 15px #eab30866}.mini-bg-btn{position:absolute;top:10px;right:100px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#10b98199;border:none;border-radius:10px;color:#fff;cursor:pointer;transition:all .3s ease;opacity:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.grid-image-container:hover .mini-bg-btn{opacity:1}.mini-bg-btn:hover{background:linear-gradient(135deg,#10b981,#059669);transform:scale(1.08);box-shadow:0 4px 15px #10b98166}.edit-panel{width:100%;margin-top:16px;padding:20px;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:14px;animation:slideDown .3s ease}.edit-panel.compact{margin-top:8px;padding:12px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.edit-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.edit-panel-header h4{color:#e2e8f0;font-size:14px;font-weight:600;margin:0}.edit-panel-close{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:18px;padding:4px 8px}.edit-panel-close:hover{color:#fff}.custom-prompt-textarea,.edit-instruction-textarea{width:100%;padding:14px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:14px;font-family:inherit;transition:all .2s ease;resize:vertical;min-height:80px;box-sizing:border-box}.custom-prompt-textarea:hover,.edit-instruction-textarea:hover{border-color:#fff3;background:#ffffff14}.custom-prompt-textarea:focus,.edit-instruction-textarea:focus{outline:none;border-color:#667eea80;background:#ffffff1a;box-shadow:0 0 0 3px #667eea26}.custom-prompt-textarea::placeholder,.edit-instruction-textarea::placeholder{color:#ffffff4d}.edit-instruction-textarea{margin-bottom:12px;min-height:60px}.edit-submit-btn{width:100%;padding:12px;background:linear-gradient(135deg,#eab308,#f59e0b);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.edit-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #eab30859}.edit-submit-btn:disabled{opacity:.5;cursor:not-allowed}.edit-submit-btn.compact{padding:8px 16px;width:auto;font-size:13px}.edit-panel-actions{display:flex;gap:8px}.edit-cancel-btn{padding:8px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#e2e8f0;font-size:13px;cursor:pointer;transition:all .2s ease}.edit-cancel-btn:hover{background:#ffffff1a}.bg-replace-panel{border-color:#10b9814d}.bg-replace-btn{background:linear-gradient(135deg,#10b981,#059669)!important}.bg-replace-btn:hover:not(:disabled){box-shadow:0 6px 20px #10b98159!important}.bg-module-btn{background:linear-gradient(135deg,#10b981,#059669)!important}.bg-module-btn:hover:not(:disabled){box-shadow:0 6px 20px #10b98159}.result-image-wrapper,.grid-image-wrapper,.multi-result-container{width:100%}.image-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:24px}.grid-image-container{position:relative;background:#0000004d;border-radius:14px;overflow:hidden;aspect-ratio:3/4}.grid-image{width:100%;height:100%;object-fit:cover}.mini-download-btn{position:absolute;top:10px;right:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#667eea99;border:none;border-radius:10px;cursor:pointer;font-size:16px;color:#fff;transition:all .3s ease;opacity:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.grid-image-container:hover .mini-download-btn,.batch-result-item:hover .mini-download-btn{opacity:1}.mini-download-btn:hover{background:linear-gradient(135deg,#667eea,#764ba2);transform:scale(1.08);box-shadow:0 4px 15px #667eea66}.download-all-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.download-all-btn:hover{transform:translateY(-3px);box-shadow:0 10px 25px #667eea59}.history-section{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:28px}.history-toolbar{display:flex;align-items:center;gap:18px;margin-bottom:24px;flex-wrap:wrap}.search-box{display:flex;align-items:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:0 16px;flex:1;min-width:200px;transition:all .2s}.search-box:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea26}.search-icon{width:18px;height:18px;margin-right:12px;opacity:.4;flex-shrink:0}.search-box input{flex:1;background:transparent;border:none;padding:14px 0;color:#fff;font-size:14px}.search-box input:focus{outline:none;box-shadow:none}.sort-controls{display:flex;align-items:center;gap:10px}.sort-label{font-size:13px;color:#6b7a99}.sort-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:10px 14px;color:#8b9dc3;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.sort-btn:hover{background:#ffffff14}.sort-btn.active{background:#667eea33;border-color:#667eea;color:#fff}.clear-history-btn{background:transparent;border:1px solid rgba(239,68,68,.4);color:#fca5a5;padding:10px 16px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;margin-left:auto}.clear-history-btn:hover{background:#ef44441f}.history-empty{text-align:center;padding:80px 24px;color:#6b7a99;font-size:14px}.history-table-container{flex:1;overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.history-table-container::-webkit-scrollbar{width:5px;height:5px}.history-table-container::-webkit-scrollbar-track{background:transparent}.history-table-container::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.history-table{width:100%;border-collapse:collapse}.history-table th{text-align:left;padding:16px 18px;font-size:11px;font-weight:700;color:#8b9dc3;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid rgba(255,255,255,.06)}.history-table td{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.history-table tr{transition:background .2s}.history-table tr:hover{background:#ffffff05}.table-thumbnail{width:64px;height:85px;border-radius:10px;overflow:hidden;background:#0000004d}.table-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.table-thumbnail:hover img{transform:scale(1.15)}.no-source{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#6b7a99;font-size:20px}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#0006;color:#6b7a99;border-radius:8px}.image-placeholder svg{width:24px;height:24px;opacity:.6}.image-placeholder span{font-size:8px;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.date-cell{font-size:13px;color:#a0aec0;white-space:nowrap}.actions-cell{white-space:nowrap}.action-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 14px;cursor:pointer;font-size:14px;transition:all .2s;margin-right:10px}.action-btn:last-child{margin-right:0}.action-btn.download:hover{background:#667eea33;border-color:#667eea;transform:translateY(-2px)}.action-btn.delete:hover{background:#ef444433;border-color:#ef4444;transform:translateY(-2px)}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner{width:64px;height:64px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-text{margin-top:28px;font-size:15px;color:#a0aec0;text-align:center;max-width:320px}.multi-gen-progress{display:flex;flex-direction:column;align-items:center}.loading-step-label{display:block;font-size:17px;color:#e2e8f0;font-weight:600;margin-bottom:8px}.loading-step-counter{display:block;font-size:13px;color:#8b95a5;margin-bottom:16px}.multi-progress-bar{width:280px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.multi-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .5s ease}.export-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.export-modal{background:linear-gradient(180deg,#1e1e32,#1a1a2e);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:36px;width:92%;max-width:420px;position:relative;box-shadow:0 30px 70px #0000008c;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.export-modal-close{position:absolute;top:18px;right:18px;background:transparent;border:none;color:#8b9dc3;font-size:26px;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .2s}.export-modal-close:hover{background:#ffffff14;color:#fff}.export-modal-title{font-size:20px;font-weight:700;color:#fff;margin-bottom:28px;letter-spacing:-.3px}.export-option-group{margin-bottom:24px}.export-label{display:block;font-size:12px;font-weight:700;color:#8b9dc3;margin-bottom:12px;text-transform:uppercase;letter-spacing:.8px}.export-options{display:flex;gap:10px}.export-options.vertical{flex-direction:column}.export-options.scrollable{max-height:300px;overflow-y:auto;padding-right:8px}.export-options.scrollable::-webkit-scrollbar{width:6px}.export-options.scrollable::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.export-options.scrollable::-webkit-scrollbar-thumb{background:#667eea66;border-radius:3px}.export-options.format-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.dimension-category{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.dimension-category:last-child{margin-bottom:0}.category-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:4px}.dim-info{font-size:10px;color:#94a3b8;display:block;margin-top:2px}.export-option-btn{flex:1;padding:14px 16px;background:#ffffff0a;border:2px solid rgba(255,255,255,.08);border-radius:12px;color:#e2e8f0;font-size:13px;font-weight:500;cursor:pointer;transition:all .25s ease;text-align:center}.export-option-btn:hover{border-color:#667eea66;background:#667eea14;transform:translateY(-2px)}.export-option-btn.selected{border-color:#667eea;background:#667eea26;color:#fff;box-shadow:0 4px 12px #667eea33}.export-option-btn.disabled{cursor:default;opacity:.9}.export-option-btn.format-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.format-notice{grid-column:1 / -1;font-size:11px;color:#f59e0b;font-style:italic;margin-top:4px}.transparent-notice{font-size:12px;color:#94a3b8;margin-top:8px;font-style:italic}.export-confirm-btn{width:100%;padding:18px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:14px;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:8px;box-shadow:0 6px 20px #667eea59}.export-confirm-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #667eea73}.export-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.export-confirm-btn.exporting{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;gap:10px}.export-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.history-stats{color:#8b95a5;font-size:14px}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#8b95a5}.spinner.small{width:30px;height:30px;margin-bottom:15px}.table-thumbnail.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.table-thumbnail.clickable:hover{transform:scale(1.1);box-shadow:0 4px 12px #8b5cf64d}.type-cell{white-space:nowrap}.type-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.type-badge.packshot-mannequin{background:#8b5cf633;color:#a78bfa}.type-badge.pack-ghost-3d{background:#3b82f633;color:#60a5fa}.type-badge.détourage{background:#10b98133;color:#34d399}.type-badge.recolo{background:#f59e0b33;color:#fbbf24}.type-badge.flat-lay{background:#ec489933;color:#f472b6}.type-badge.lot---packshot{background:#6366f133;color:#818cf8}.pagination{display:flex;align-items:center;justify-content:center;gap:20px;padding:20px;border-top:1px solid rgba(255,255,255,.05)}.pagination-btn{padding:8px 16px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:#a78bfa;font-size:14px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#8b5cf640}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{color:#8b95a5;font-size:14px}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1001;cursor:pointer}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;cursor:default}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px}.lightbox-close{position:absolute;top:-40px;right:0;width:36px;height:36px;background:#ffffff1a;border:none;border-radius:50%;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-close:hover{background:#fff3}@media (max-width: 1100px){.sidebar{width:380px}}@media (max-width: 900px){.dashboard-container{flex-direction:column;height:auto;overflow:auto}.sidebar{width:100%;max-height:60vh}.main-content{min-height:50vh}}
