.image-preview{width:100%;max-width:1000px;margin-top:2rem}.product-info{margin-bottom:1.5rem}.product-name{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#fffffff2}.product-meta{display:flex;gap:1.5rem;font-size:.875rem;color:#ffffffb3}.product-sku,.product-id{font-family:monospace}.product-dimensions{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;background-color:#646cff1a;border:1px solid rgba(100,108,255,.3);border-radius:6px;font-size:.875rem}.product-dimensions.missing{background-color:#ffc1071a;border-color:#ffc1074d}.dimensions-label{color:#ffffffb3;font-weight:500}.dimensions-value{color:#fffffff2;font-family:monospace}.product-dimensions.missing .dimensions-value{color:#ffc107e6;font-style:italic}.dimensions-source{color:#ffffff80;font-size:.75rem}.view-mode-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.view-mode-tab{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#ffffffb3;background-color:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s}.view-mode-tab:hover{color:#ffffffe6;border-color:#fff6}.view-mode-tab.active{color:#fff;background-color:#646cff;border-color:#646cff}.image-container{background-color:#ffffff0d;border-radius:12px;padding:1rem;overflow:hidden}.comparison-view{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.image-panel{display:flex;flex-direction:column;gap:.5rem}.image-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#fff9}.image-panel img,.single-view img{width:100%;height:auto;border-radius:8px;background-color:#ffffff1a}.single-view{display:flex;justify-content:center}.single-view img{max-width:600px}.image-error{display:flex;align-items:center;justify-content:center;min-height:200px;background-color:#ff4d4f1a;border:1px dashed rgba(255,77,79,.3);border-radius:8px;color:#ff4d4f;font-size:.875rem}.download-section{margin-top:1.5rem;display:flex;justify-content:center}.download-button{padding:.875rem 2rem;font-size:1rem;font-weight:500;color:#fff;background-color:#52c41a;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s,opacity .2s}.download-button:hover:not(:disabled){background-color:#389e0d}.download-button:disabled{opacity:.6;cursor:not-allowed}.download-loading{display:flex;align-items:center;gap:.5rem}.download-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}@media(max-width:768px){.comparison-view{grid-template-columns:1fr}.product-meta{flex-direction:column;gap:.5rem}.view-mode-tabs{flex-wrap:wrap}}.background-selector{padding:1rem;background:#f8f9fa;border-radius:8px}.background-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.background-selector-header h3{margin:0;font-size:1.1rem;color:#333}.category-filter{display:flex;gap:.5rem}.filter-btn{padding:.4rem .8rem;border:1px solid #ddd;background:#fff;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s ease}.filter-btn:hover{border-color:#007bff;color:#007bff}.filter-btn.active{background:#007bff;color:#fff;border-color:#007bff}.background-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.background-item{border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s ease;background:#fff}.background-item:hover{border-color:#007bff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.background-item.selected{border-color:#28a745}.background-item.standard{border-color:#ffc107}.background-item.standard.selected{border-color:#28a745}.background-thumbnail{position:relative;aspect-ratio:16/9;overflow:hidden}.background-thumbnail img{width:100%;height:100%;object-fit:cover}.standard-badge{position:absolute;top:.5rem;left:.5rem;background:#ffc107;color:#333;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600}.selected-badge{position:absolute;top:.5rem;right:.5rem;background:#28a745;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem}.background-info{padding:.5rem;display:flex;flex-direction:column;gap:.2rem}.background-name{font-weight:500;font-size:.9rem;color:#333}.background-category{font-size:.75rem;color:#666;text-transform:capitalize}.background-version{font-size:.7rem;color:#999;font-family:monospace}.custom-upload-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #ddd}.upload-btn{display:inline-block;padding:.6rem 1.2rem;background:#6c757d;color:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s ease}.upload-btn:hover{background:#5a6268}.upload-btn input[type=file]{display:none}.selected-background-info{margin-top:1rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #ddd}.selected-background-info h4{margin:0 0 .5rem;font-size:.95rem;color:#333}.selected-details p{margin:.3rem 0;font-size:.85rem;color:#555}.standard-note{margin-top:.5rem!important;padding:.5rem;background:#fff3cd;border-radius:4px;color:#856404!important;font-size:.8rem!important}.lighting-controls{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.lighting-controls.disabled{opacity:.6;pointer-events:none}.lighting-controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #eee}.lighting-controls-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#333}.tab-buttons{display:flex;gap:8px}.tab-btn{padding:6px 16px;border:1px solid #ddd;border-radius:20px;background:#fff;color:#666;font-size:.85rem;cursor:pointer;transition:all .2s ease}.tab-btn:hover:not(:disabled){border-color:#007bff;color:#007bff}.tab-btn.active{background:#007bff;border-color:#007bff;color:#fff}.tab-btn:disabled{cursor:not-allowed;opacity:.5}.controls-content{min-height:200px}.basic-controls,.shadow-controls{display:flex;flex-direction:column;gap:20px}.slider-control{display:flex;flex-direction:column;gap:8px}.slider-header{display:flex;justify-content:space-between;align-items:center}.slider-header label{font-size:.9rem;font-weight:500;color:#444}.slider-value{font-size:.85rem;color:#666;min-width:60px;text-align:right}.slider-track-container{position:relative}.slider-input{width:100%;height:6px;border-radius:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;outline:none}.slider-input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #007bff;box-shadow:0 2px 4px #00000026;cursor:pointer;transition:transform .15s ease}.slider-input::-webkit-slider-thumb:hover{transform:scale(1.1)}.slider-input::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid #007bff;box-shadow:0 2px 4px #00000026;cursor:pointer}.slider-control.temperature .slider-input::-webkit-slider-thumb{border-color:#666}.shadow-direction-control{display:flex;flex-direction:column;gap:12px}.shadow-direction-control>label{font-size:.9rem;font-weight:500;color:#444}.direction-pad{display:flex;justify-content:center;margin-bottom:8px}.shadow-direction-pad{position:relative;width:120px;height:120px;background:#f5f5f5;border:2px solid #ddd;border-radius:8px;cursor:crosshair;overflow:hidden}.shadow-direction-pad.disabled{cursor:not-allowed;opacity:.5}.pad-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.grid-line{position:absolute;background:#ddd}.grid-line.horizontal{left:0;right:0;top:50%;height:1px;transform:translateY(-50%)}.grid-line.vertical{top:0;bottom:0;left:50%;width:1px;transform:translate(-50%)}.direction-indicator{position:absolute;transform:translate(-50%,-50%);transition:left .1s ease,top .1s ease}.indicator-dot{width:16px;height:16px;background:#007bff;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003}.pad-labels{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;font-size:.75rem;color:#999}.pad-labels span{position:absolute}.label-top{top:4px;left:50%;transform:translate(-50%)}.label-bottom{bottom:4px;left:50%;transform:translate(-50%)}.label-left{left:4px;top:50%;transform:translateY(-50%)}.label-right{right:4px;top:50%;transform:translateY(-50%)}.direction-sliders{display:flex;flex-direction:column;gap:12px}.preview-info{margin-top:20px;padding:12px;background:#f8f9fa;border-radius:8px}.preview-info h4{margin:0 0 8px;font-size:.85rem;font-weight:600;color:#666}.settings-summary{display:flex;flex-wrap:wrap;gap:12px;font-size:.8rem;color:#888}.settings-summary span{padding:4px 8px;background:#fff;border-radius:4px}.controls-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid #eee}.reset-btn,.apply-btn{padding:10px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-btn{background:#fff;border:1px solid #ddd;color:#666}.reset-btn:hover:not(:disabled){border-color:#999;color:#333}.apply-btn{background:#007bff;border:1px solid #007bff;color:#fff}.apply-btn:hover:not(:disabled){background:#0056b3;border-color:#0056b3}.reset-btn:disabled,.apply-btn:disabled{cursor:not-allowed;opacity:.5}@media(max-width:480px){.lighting-controls-header{flex-direction:column;gap:12px;align-items:flex-start}.shadow-direction-pad{width:100px;height:100px}.controls-actions{flex-direction:column}.reset-btn,.apply-btn{width:100%}}.workflow-progress{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #000000;margin-bottom:1.5rem}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.progress-header h3{margin:0;font-size:1.1rem;color:#000;font-weight:700}.progress-count{font-size:.875rem;color:#000}.progress-bar-container{height:4px;background:#e0e0e0;border-radius:2px;margin-bottom:1.5rem;overflow:hidden;border:1px solid #000000}.progress-bar-fill{height:100%;background:#000;border-radius:2px;transition:width .3s ease}.phases-container{display:flex;justify-content:space-between;align-items:flex-start}.phase-wrapper{display:flex;align-items:center;flex:1}.phase-wrapper:last-child{flex:0}.phase-step{display:flex;flex-direction:column;align-items:center;padding:.75rem;border:2px solid #000000;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;min-width:100px;text-align:center}.phase-step:hover:not(:disabled){background:#f0f0f0}.phase-step:disabled{cursor:not-allowed;opacity:.6}.phase-step.active,.phase-step.approved,.phase-step.completed,.phase-step.processing,.phase-step.rejected{border-width:3px;background:#f5f5f5}.phase-step.locked{background:#fafafa}.phase-icon{font-size:1.25rem;margin-bottom:.25rem;color:#000}.phase-step.processing .phase-icon{animation:pulse 1s infinite}.phase-number{font-size:.75rem;color:#000;margin-bottom:.25rem}.phase-label{font-weight:600;font-size:.875rem;color:#000;margin-bottom:.25rem}.phase-description{font-size:.75rem;color:#000;line-height:1.3;font-style:italic}.phase-connector{flex:1;height:2px;background:#000;margin:-2rem .5rem 0}.phase-connector.completed{background:#000}@media(max-width:768px){.phases-container{flex-direction:column;gap:.5rem}.phase-wrapper{flex-direction:column;width:100%}.phase-step{width:100%;flex-direction:row;justify-content:flex-start;gap:1rem;text-align:left}.phase-connector{width:2px;height:1rem;margin:0;margin-left:2.5rem}}.phase-approval{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #000000;margin-bottom:1.5rem}.phase-approval-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #000000}.phase-approval-header h3{margin:0;font-size:1.25rem;color:#000;font-weight:700}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#fff;color:#000;border:1px solid #000000}.compare-mode-selector{display:flex;gap:.5rem;margin-bottom:1rem}.compare-mode-selector button{padding:.5rem 1rem;border:1px solid #000000;border-radius:4px;background:#fff;cursor:pointer;font-size:.875rem;color:#000;transition:all .2s ease}.compare-mode-selector button:hover{background:#f0f0f0}.compare-mode-selector button.active{background:#000;color:#fff}.comparison-container{margin-bottom:1.5rem;border-radius:8px;overflow:hidden;background:#f5f5f5;border:1px solid #000000}.side-by-side-view{display:grid;grid-template-columns:1fr 1fr;gap:1rem;padding:1rem}.compare-panel{position:relative;border-radius:4px;overflow:hidden;background:#fff;border:1px solid #000000}.compare-panel img{width:100%;height:auto;display:block}.compare-label{position:absolute;top:.5rem;left:.5rem;padding:.25rem .5rem;background:#fff;color:#000;font-size:.75rem;border-radius:4px;border:1px solid #000000;font-weight:500}.slider-view{position:relative;cursor:ew-resize;-webkit-user-select:none;user-select:none}.slider-before,.slider-after{position:relative}.slider-before img,.slider-after img{width:100%;height:auto;display:block}.slider-after{position:absolute;top:0;left:0;right:0;bottom:0}.slider-handle{position:absolute;top:0;bottom:0;width:4px;transform:translate(-50%);z-index:10}.handle-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#000;transform:translate(-50%)}.handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:32px;height:32px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid #000000;font-size:1rem;color:#000}.toggle-view{position:relative;padding:1rem}.toggle-view img{width:100%;height:auto;display:block;border-radius:4px;border:1px solid #000000}.toggle-btn{position:absolute;bottom:1.5rem;right:1.5rem;padding:.5rem 1rem;background:#fff;color:#000;border:2px solid #000000;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .2s ease}.approval-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1rem;border-top:1px solid #000000}.approve-btn,.reject-btn,.reprocess-btn{padding:.75rem 1.5rem;border:2px solid #000000;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#fff;color:#000}.approve-btn:hover:not(:disabled),.reject-btn:hover:not(:disabled),.reprocess-btn:hover:not(:disabled){background:#f0f0f0}.approve-btn:disabled,.reject-btn:disabled,.reprocess-btn:disabled{opacity:.4;cursor:not-allowed}.approved-message{color:#000;font-weight:600;display:flex;align-items:center;gap:.5rem}@media(max-width:768px){.side-by-side-view{grid-template-columns:1fr}.approval-actions{flex-direction:column}.approve-btn,.reject-btn,.reprocess-btn{width:100%}}.product-lane{display:flex;flex-direction:column;background:#fff;border:2px solid #000000;border-radius:8px;padding:20px;width:350px;min-width:280px;min-height:600px;flex-shrink:0}.processing-lanes.three-products .product-lane{width:320px;padding:16px}.lane-header{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e0e0e0}.lane-header h4{margin:0;font-size:15px;font-weight:600;color:#000}.lane-sku{font-size:11px;color:#000;background:#f5f5f5;padding:2px 6px;border-radius:3px;border:1px solid #000000}.lane-dims{font-size:11px;color:#000}.lane-steps{display:flex;gap:4px;margin-bottom:12px;overflow-x:auto;padding-bottom:4px}.lane-step{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:44px}.step-num{width:22px;height:22px;border-radius:50%;background:#e0e0e0;color:#000;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.lane-step.done .step-num{background:#000;color:#fff}.lane-step.active .step-num{background:#fff;color:#000;border:2px solid #000000}.step-name{font-size:9px;color:#666;text-align:center}.lane-step.active .step-name{color:#000;font-weight:500}.lane-step.done .step-name{color:#000}.lane-canvas{background:#f5f5f5;border:1px solid #000000;border-radius:6px;min-height:300px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;position:relative;overflow:hidden}.lane-image{max-width:100%;max-height:280px;object-fit:contain}.lane-preview{max-width:90%;max-height:260px;object-fit:contain;opacity:.8}.lane-placeholder{color:#000;font-size:13px;display:flex;flex-direction:column;align-items:center;gap:8px}.lane-loading{display:flex;flex-direction:column;align-items:center;gap:10px;color:#000}.spinner{width:28px;height:28px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.lane-controls{flex:1;display:flex;flex-direction:column}.step-content{flex:1;margin-bottom:12px}.step-instruction{font-size:13px;color:#000;margin:0 0 10px}.step-hint{font-size:11px;color:#000;margin:4px 0 0}.auto-position-display{margin:12px 0}.position-badge{display:inline-block;padding:10px 20px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:14px;font-weight:600}.auto-selected-image{margin:8px 0;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.selected-label{display:inline-block;padding:8px 16px;background:#f5f5f5;color:#000;border:2px solid #000000;border-radius:6px;font-size:13px;font-weight:500}.angle-tag{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:#fff;color:#000;border:2px solid #000000;border-radius:6px;font-size:12px;font-weight:600}.angle-tag.confidence-high{background:#f5f5f5}.angle-tag.confidence-medium{background:#fff}.angle-tag.confidence-low{background:#fff;border-style:dashed}.confidence-indicator{font-size:10px;font-weight:400;opacity:.8}.image-alternatives{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}.image-alt-option{display:flex;flex-direction:column;align-items:center;width:60px;border:2px solid #000000;border-radius:4px;overflow:hidden;cursor:pointer;transition:all .15s;background:#fff}.image-alt-option:hover{opacity:.8}.image-alt-option img{width:56px;height:50px;object-fit:contain}.image-alt-option .alt-label{font-size:8px;color:#000;text-align:center;padding:2px 4px;background:#f5f5f5;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:150px;overflow-y:auto}.image-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;border:2px solid #000000;border-radius:6px;cursor:pointer;transition:all .15s}.image-option:hover{opacity:.8}.image-option.selected{background:#f5f5f5}.image-option img{width:50px;height:50px;object-fit:contain;border-radius:3px}.image-option span{font-size:9px;color:#000;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.lane-step.error .step-num{background:#fff;color:#000;border:2px dashed #000000}.lane-step.error .step-name{color:#000}.lane-step.processing-step .step-num{border:2px solid currentColor}.lane-step.processing-step.done .step-num,.lane-step.processing-step.active .step-num{border-color:#000}.approve-btn{width:100%;padding:10px;background:#fff;color:#000;border:2px solid #000000;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;margin-top:auto}.approve-btn:hover:not(:disabled){background:#f0f0f0}.approve-btn:disabled{opacity:.5;cursor:not-allowed}.retry-btn{width:100%;padding:10px;background:#fff;color:#000;border:2px solid #000000;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s;margin-top:auto}.retry-btn:hover:not(:disabled){background:#f0f0f0}.retry-btn:disabled{opacity:.5;cursor:not-allowed}.lane-error{background:#fff;border:2px solid #000000;border-radius:4px;padding:10px;margin-bottom:10px;display:flex;align-items:flex-start;gap:8px}.lane-error .error-icon{flex-shrink:0}.lane-error .error-message{font-size:12px;color:#000;word-break:break-word}.complete-badge{background:#f5f5f5;color:#000;padding:12px;border-radius:6px;text-align:center;font-weight:500;border:1px solid #000000}.all-images-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;margin:8px 0;padding-right:4px}.image-row{display:flex;align-items:center;gap:10px;padding:6px 8px;background:#fff;border:2px solid #000000;border-radius:6px;cursor:pointer;transition:all .15s}.image-row:hover,.image-row.selected{background:#f5f5f5}.row-thumbnail{width:50px;height:40px;object-fit:contain;border-radius:4px;background:#fff;flex-shrink:0}.row-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.row-label{font-size:11px;font-weight:500;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.row-angle{font-size:10px;display:inline-flex;align-items:center;gap:4px;color:#000}.row-angle.confidence-high,.row-angle.confidence-medium{color:#000}.row-angle.confidence-low{color:#000;font-style:italic}.row-angle .conf{font-size:9px;opacity:.7}.selected-check{font-size:16px;color:#000;font-weight:700;flex-shrink:0}@media(max-width:1200px){.product-lane{width:320px}.processing-lanes.three-products .product-lane{width:280px;padding:14px}}@media(max-width:900px){.product-lane{width:100%;min-width:280px}.processing-lanes.three-products .product-lane{width:100%}}.dimension-input{background:#fff;border-radius:8px;padding:16px;border:1px solid #000000}.dimension-input.fallback-mode{border:2px dashed #000000}.fallback-notice{display:flex;align-items:flex-start;gap:8px;padding:12px;background:#f5f5f5;border:1px solid #000000;border-radius:6px;margin-bottom:16px;font-size:13px;color:#000}.notice-icon{font-size:16px;flex-shrink:0}.dimension-product-context{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f5f5f5;border-radius:6px;margin-bottom:16px;font-size:13px}.context-label{color:#000}.context-value{font-weight:500;color:#000}.dimension-form{display:flex;flex-direction:column;gap:16px}.dimension-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.dimension-field{display:flex;flex-direction:column;gap:4px}.dimension-field.has-error .dimension-input-field{border-width:2px}.dimension-label{display:flex;align-items:baseline;gap:4px;font-size:13px;font-weight:500;color:#000}.dimension-unit{font-size:11px;font-weight:400;color:#000}.dimension-input-field{padding:10px 12px;border:1px solid #000000;border-radius:6px;font-size:14px;color:#000;background:#fff;transition:border-color .2s}.dimension-input-field:focus{outline:none;border-width:2px}.dimension-input-field:disabled{background:#f5f5f5;color:#666;cursor:not-allowed}.dimension-input-field::placeholder{color:#999}.dimension-input-field::-webkit-outer-spin-button,.dimension-input-field::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dimension-input-field[type=number]{-moz-appearance:textfield}.dimension-error{font-size:11px;color:#000;margin-top:2px}.dimension-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:8px;border-top:1px solid #e0e0e0}.dimension-cancel-btn,.dimension-submit-btn{padding:10px 20px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.dimension-cancel-btn{background:#fff;color:#000;border:1px solid #000000}.dimension-cancel-btn:hover:not(:disabled){background:#f0f0f0}.dimension-submit-btn{background:#fff;color:#000;border:2px solid #000000}.dimension-submit-btn:hover:not(:disabled){background:#f0f0f0}.dimension-cancel-btn:disabled,.dimension-submit-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.dimension-fields{grid-template-columns:1fr}.dimension-actions{flex-direction:column}.dimension-cancel-btn,.dimension-submit-btn{width:100%;justify-content:center}}.pre-composition-preview{background:#fff;border-radius:12px;padding:24px;border:1px solid #000000}.pre-composition-preview.three-product{border-width:2px}.preview-header{text-align:center;margin-bottom:24px}.preview-header h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#000}.preview-subtitle{margin:0;font-size:14px;color:#000;line-height:1.5}.depth-layering-info{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;padding:8px 16px;background:#f5f5f5;border:1px solid #000000;border-radius:6px;font-size:13px;color:#000}.depth-layering-info .info-icon{font-size:14px}.preview-products-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:24px}.preview-products-grid.three-products{grid-template-columns:repeat(3,1fr)}@media(max-width:900px){.preview-products-grid.three-products{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.preview-products-grid.three-products{grid-template-columns:1fr}}.preview-product-item{background:#f5f5f5;border:2px solid #000000;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:12px;position:relative}.preview-product-item.accent{border-color:#000;border-width:3px;box-shadow:0 4px 12px #00000026}.preview-product-item.primary{border-color:#666}.role-badge{position:absolute;top:-10px;left:16px;padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;display:flex;align-items:center;gap:6px}.role-badge.accent{background:#000;color:#fff}.role-badge.primary{background:#666;color:#fff}.role-badge .depth-indicator{font-size:10px;opacity:.8;font-weight:400}.preview-product-info{padding-bottom:12px;border-bottom:1px solid #e0e0e0}.preview-product-name{margin:0 0 4px;font-size:16px;font-weight:600;color:#000;line-height:1.3}.preview-product-sku{font-size:12px;color:#000;font-family:Monaco,Menlo,monospace}.preview-dimensions{display:flex;gap:12px;flex-wrap:wrap}.dim-item{display:flex;align-items:baseline;gap:3px;background:#fff;padding:4px 8px;border-radius:4px;border:1px solid #000000}.dim-value{font-size:13px;font-weight:600;color:#000}.preview-image-container{width:100%;min-height:180px;display:flex;align-items:center;justify-content:center;border-radius:8px;overflow:hidden;transition:height .3s ease}.transparent-bg-indicator{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-image:linear-gradient(45deg,#e8e8e8 25%,transparent 25%),linear-gradient(-45deg,#e8e8e8 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e8e8e8 75%),linear-gradient(-45deg,transparent 75%,#e8e8e8 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;background-color:#f5f5f5;border:1px solid #000000;border-radius:8px}.preview-product-image{max-width:100%;max-height:100%;object-fit:contain}.no-image-placeholder{color:#000;font-size:13px;text-align:center;padding:20px}.scale-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;background:#f5f5f5;border-radius:6px;border:1px solid #000000;flex-wrap:wrap}.scale-indicator.with-boost{background:#e8e8e8;border-width:2px}.scale-label{font-size:12px;color:#000}.scale-value{font-size:14px;font-weight:600;color:#000}.depth-boost-badge{font-size:10px;padding:2px 6px;background:#000;color:#fff;border-radius:4px;font-weight:500}.z-index-indicator{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px;background:#fff;border-radius:4px;border:1px solid #cccccc}.z-label{font-size:11px;color:#666}.z-value{font-size:12px;font-weight:600;color:#000}.preview-status{text-align:center}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:500}.status-badge.status-complete{background:#f5f5f5;color:#000;border:1px solid #000000}.reprocess-button{width:100%;padding:10px 16px;background:#fff;border:1px solid #000000;border-radius:8px;font-size:14px;cursor:pointer;transition:all .15s ease;color:#000}.reprocess-button:hover{background:#f0f0f0}.preview-actions-bar{display:flex;justify-content:center;gap:16px;padding-top:20px;border-top:1px solid #e0e0e0;flex-wrap:wrap}.cancel-button{padding:12px 28px;background:#fff;border:1px solid #000000;border-radius:8px;font-size:15px;cursor:pointer;transition:all .15s ease;color:#000}.approve-button{padding:12px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.approve-button:hover:not(:disabled){background:#f0f0f0}.approve-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.preview-products-grid{grid-template-columns:1fr}.preview-actions-bar{flex-direction:column}.cancel-button,.approve-button{width:100%}}.depth-preview-section{margin:24px 0;padding:16px;background:#f9f9f9;border:1px solid #000000;border-radius:8px}.depth-preview-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#000;text-align:center}.depth-preview-container{display:flex;flex-direction:column;gap:8px}.depth-layer{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:6px}.depth-layer.back-layer{background:#e8e8e8;border:1px solid #999999}.depth-layer.front-layer{background:#fff;border:2px solid #000000;box-shadow:0 2px 8px #0000001a}.layer-label{font-size:11px;font-weight:600;color:#666;min-width:180px}.front-layer .layer-label{color:#000}.layer-products{display:flex;flex-wrap:wrap;gap:8px}.layer-product-name{font-size:12px;padding:4px 8px;background:#fff;border:1px solid #cccccc;border-radius:4px;color:#000}.front-layer .layer-product-name{background:#000;color:#fff;border-color:#000}@media(max-width:640px){.depth-preview-container{gap:12px}.depth-layer{flex-direction:column;align-items:flex-start;gap:8px}.layer-label{min-width:auto}}.placement-validation{padding:20px;background:#fff;border-radius:8px;margin:16px 0;border:1px solid #000000}.validation-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px;color:#000}.validation-loading .spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin 1s linear infinite}.validation-error{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;background:#fff;border:2px solid #000000;border-radius:8px}.validation-error .error-icon{font-size:32px}.validation-error .error-message{color:#000;font-weight:500}.validation-error .error-actions{display:flex;gap:12px;margin-top:8px}.validation-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;background:#f5f5f5;border:2px solid #000000;border-radius:8px}.validation-success .success-icon{font-size:48px;color:#000}.validation-success h3,.validation-success p{margin:0;color:#000}.validation-corrected{display:flex;flex-direction:column;gap:16px}.correction-header{display:flex;flex-direction:column;align-items:center;gap:8px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.correction-header .correction-icon{font-size:36px}.correction-header h3,.correction-header p{margin:0;color:#000}.violations-section{background:#fff;border:2px solid #000000;border-radius:6px;padding:12px 16px}.violations-section h4{margin:0 0 8px;color:#000;font-size:14px}.violations-list{list-style:none;margin:0;padding:0}.violation-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;font-size:13px;color:#000}.violation-item .violation-icon{flex-shrink:0}.corrections-section{background:#f5f5f5;border:1px solid #000000;border-radius:6px;padding:12px 16px}.corrections-section h4{margin:0 0 8px;color:#000;font-size:14px}.corrections-list{list-style:none;margin:0;padding:0}.correction-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;font-size:13px;border-bottom:1px solid #e0e0e0}.correction-item:last-child{border-bottom:none}.correction-item .correction-icon{flex-shrink:0}.correction-item .correction-product{font-weight:500;color:#000;min-width:100px}.correction-item .correction-reason{color:#000}.report-section{margin-top:8px}.toggle-report-btn{background:none;border:none;color:#000;cursor:pointer;font-size:13px;padding:4px 0;text-decoration:underline}.toggle-report-btn:hover{opacity:.8}.validation-report{background:#f5f5f5;border:1px solid #000000;border-radius:4px;padding:12px;font-family:monospace;font-size:12px;white-space:pre-wrap;overflow-x:auto;margin-top:8px;color:#000}.final-status{background:#f5f5f5;border:1px solid #000000;border-radius:6px;padding:12px 16px}.final-status h4{margin:0 0 8px;color:#000;font-size:14px}.validation-checks{list-style:none;margin:0;padding:0}.validation-checks li{padding:4px 0;font-size:13px;color:#000}.validation-actions{display:flex;justify-content:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0;flex-wrap:wrap}.proceed-btn{background:#fff;color:#000;border:2px solid #000000;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.adjust-btn{background:#fff;color:#000;border:1px solid #000000;padding:10px 24px;border-radius:6px;font-size:14px;cursor:pointer;transition:background .2s}.adjust-btn:hover{background:#f0f0f0}.retry-btn{background:#fff;color:#000;border:2px solid #000000;padding:8px 16px;border-radius:4px;font-size:13px;cursor:pointer}.composition-workflow{background:#fff;border-radius:8px;padding:20px;margin:16px 0;border:1px solid #000000}.workflow-header{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.workflow-header h2{margin:0;font-size:18px;color:#000;font-weight:600}.workflow-header p{margin:0;color:#000;font-size:13px;flex:1}.cancel-btn{padding:6px 14px;background:#fff;border:1px solid #000000;border-radius:5px;cursor:pointer;font-size:13px;color:#000}.cancel-btn:hover{background:#f0f0f0}.background-selector-bar{display:flex;align-items:center;gap:12px;padding:12px;background:#f5f5f5;border-radius:8px;margin-bottom:16px;border:1px solid #e0e0e0}.bg-label{font-size:13px;font-weight:500;color:#000}.bg-options{display:flex;gap:8px;flex-wrap:wrap}.bg-thumb{width:60px;height:40px;border:2px solid #000000;border-radius:4px;overflow:hidden;cursor:pointer;transition:all .15s}.bg-thumb:hover{opacity:.8}.bg-thumb.selected{border-width:3px;box-shadow:0 0 0 2px #0000001a}.bg-thumb img{width:100%;height:100%;object-fit:cover}.bg-upload-btn{width:60px;height:40px;border:2px dashed #666;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;background:#f5f5f5;font-size:20px;color:#666}.bg-upload-btn:hover{border-color:#333;background:#e8e8e8;color:#333}.bg-upload-btn input[type=file]{display:none}.bg-upload-btn:has(input:disabled){opacity:.5;cursor:not-allowed}.processing-lanes{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-bottom:24px;padding:16px;background:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.processing-lanes.three-products{gap:16px;padding:12px}.composition-section{background:#f5f5f5;border-radius:8px;padding:20px;text-align:center;border:1px solid #e0e0e0}.composition-section h3{margin:0 0 16px;color:#000}.generate-btn{padding:12px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background .15s}.generate-btn:hover:not(:disabled){background:#f0f0f0}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.composition-actions-initial{display:flex;flex-direction:column;align-items:center;gap:12px}.reprocess-btn{padding:8px 16px;background:#fff3e0;border:1px solid #ffb74d;border-radius:6px;color:#e65100;font-size:13px;cursor:pointer;transition:all .15s}.reprocess-btn:hover{background:#ffe0b2;border-color:#ffa726}.compositing-status{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;color:#000}.compositing-status .spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.composition-error{background:#fff;border:2px solid #000000;border-radius:6px;padding:12px;display:flex;align-items:center;justify-content:center;gap:12px;color:#000}.composition-error button{background:#fff;border:1px solid #000000;padding:6px 12px;border-radius:4px;cursor:pointer}.composition-error button:hover{background:#f0f0f0}.final-result{display:flex;flex-direction:column;align-items:center;gap:16px}.final-result img{max-width:100%;max-height:400px;border-radius:8px;border:1px solid #000000}.regenerate-btn{padding:8px 20px;background:#fff;border:1px solid #000000;border-radius:6px;cursor:pointer;font-size:14px;color:#000}.regenerate-btn:hover{background:#f0f0f0}.composition-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.lighting-btn,.enhancement-btn{padding:10px 24px;background:#fff;color:#000;border:2px solid #000000;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.lighting-btn:hover,.enhancement-btn:hover{background:#f0f0f0}.lighting-status{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f5f5f5;border-radius:6px;color:#000;font-size:13px;border:1px solid #e0e0e0}.lighting-status .spinner{width:16px;height:16px;border:2px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.lighting-applied{padding:8px 16px;background:#f5f5f5;color:#000;border-radius:6px;font-size:13px;font-weight:500;border:1px solid #000000}.product-selection-phase{background:#fff;border-radius:8px;padding:20px;margin-bottom:16px}.phase-title{margin:0 0 16px;font-size:16px;color:#000;font-weight:600}.products-display{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:20px}.product-card{background:#f5f5f5;border:2px solid #000000;border-radius:10px;padding:16px}.product-card.missing-dimensions{border-style:dashed}.product-info-header{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.product-name{margin:0 0 4px;font-size:15px;font-weight:600;color:#000;line-height:1.3}.product-sku{font-size:12px;color:#000;font-family:monospace}.product-dimensions{margin-bottom:12px}.dimensions-display{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.dimension-item{display:flex;align-items:baseline;gap:4px;background:#fff;padding:6px 10px;border-radius:6px;border:1px solid #000000}.dim-label{font-size:11px;font-weight:600;color:#000}.dim-value{font-size:14px;font-weight:600;color:#000}.dim-unit{font-size:10px;color:#000}.dimensions-missing{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff;border:1px solid #000000;border-radius:6px;color:#000;font-size:13px}.missing-icon{font-size:16px}.missing-text{font-weight:500}.product-image-preview{width:100%;height:180px;background:#fff;border:1px solid #000000;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.preview-image{max-width:100%;max-height:100%;object-fit:contain}.no-image-placeholder{color:#000;font-size:13px}.image-gallery{border-top:1px solid #e0e0e0;padding-top:12px}.gallery-label{display:block;font-size:12px;color:#000;margin-bottom:8px}.gallery-thumbnails{display:flex;gap:8px;flex-wrap:wrap}.gallery-thumb{width:48px;height:48px;border:2px solid #000000;border-radius:6px;overflow:hidden;cursor:pointer;transition:all .15s}.gallery-thumb:hover{opacity:.8}.gallery-thumb.selected{border-width:3px}.gallery-thumb img{width:100%;height:100%;object-fit:cover}.dimension-warning{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:#fff;border:2px solid #000000;border-radius:8px;margin-bottom:16px}.warning-icon{font-size:18px;flex-shrink:0}.warning-text{font-size:13px;color:#000;line-height:1.4}.selection-actions{display:flex;justify-content:center;padding-top:8px}.start-processing-btn{padding:14px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.start-processing-btn:hover:not(:disabled){background:#f0f0f0}.start-processing-btn:disabled{opacity:.5;cursor:not-allowed}.edit-dimensions-btn{background:transparent;border:none;padding:4px 8px;cursor:pointer;font-size:14px;opacity:.6;transition:opacity .2s}.edit-dimensions-btn:hover{opacity:1}.enter-dimensions-btn{padding:6px 12px;background:#fff;color:#000;border:1px solid #000000;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s;margin-left:auto}.enter-dimensions-btn:hover{background:#f0f0f0}.product-dimensions .dimension-input{margin:0;padding:12px;background:#fff;border:1px solid #000000;border-radius:6px}.product-dimensions .dimension-fields{grid-template-columns:1fr;gap:8px}.product-dimensions .dimension-field{flex-direction:row;align-items:center;gap:8px}.product-dimensions .dimension-label{min-width:60px}.product-dimensions .dimension-input-field{flex:1;padding:8px 10px}.product-dimensions .dimension-actions{padding-top:12px;margin-top:8px}.auto-advance-indicator{display:flex;align-items:center;justify-content:center;gap:12px;padding:20px;background:#f5f5f5;border-radius:8px;color:#000;font-weight:500;border:1px solid #000000}.auto-advance-indicator .spinner{width:20px;height:20px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.preview-phase{background:#fff;border-radius:8px;padding:20px}.preview-phase h3{margin:0 0 8px;font-size:18px;color:#000}.preview-description{margin:0 0 16px;color:#000;font-size:14px}.preview-products{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin:20px 0}.preview-product-card{background:#f5f5f5;border:2px solid #000000;border-radius:10px;padding:16px}.preview-product-header{margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e0e0e0}.preview-product-header h4{margin:0 0 4px;font-size:15px;font-weight:600;color:#000}.preview-sku{font-size:12px;color:#000;font-family:monospace}.preview-product-image{width:100%;height:200px;background:#fff;border:1px solid #000000;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.preview-product-image img{max-width:100%;max-height:100%;object-fit:contain}.preview-product-image .no-image{color:#000;font-size:13px}.preview-product-status{margin-bottom:12px;text-align:center}.status-complete{display:inline-block;padding:6px 12px;background:#f5f5f5;color:#000;border-radius:4px;font-size:13px;font-weight:500;border:1px solid #000000}.reprocess-btn{width:100%;padding:10px;background:#fff;border:1px solid #000000;border-radius:6px;font-size:13px;cursor:pointer;transition:all .15s;color:#000}.reprocess-btn:hover{background:#f0f0f0}.preview-actions{display:flex;justify-content:center;gap:16px;margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0;flex-wrap:wrap}.back-to-processing-btn{padding:12px 24px;background:#fff;border:1px solid #000000;border-radius:8px;font-size:14px;cursor:pointer;transition:all .15s;color:#000}.back-to-processing-btn:hover{background:#f0f0f0}.approve-combine-btn{padding:12px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.approve-combine-btn:hover:not(:disabled){background:#f0f0f0}.approve-combine-btn:disabled{opacity:.5;cursor:not-allowed}.composition-phase{background:#fff;border-radius:8px;padding:20px}.composition-phase h3{margin:0 0 16px;font-size:18px;color:#000;text-align:center}.composition-nav{display:flex;justify-content:center;margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0}.back-to-preview-btn{padding:10px 20px;background:#fff;border:1px solid #000000;border-radius:6px;font-size:14px;cursor:pointer;transition:all .15s;color:#000}.back-to-preview-btn:hover{background:#f0f0f0}.preview-warning{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#fff;border:2px solid #000000;border-radius:8px;margin-top:16px;color:#000;font-size:14px}.preview-warning .warning-icon{font-size:16px}.validation-phase{background:#fff;border-radius:8px;padding:20px}.validation-phase h3{margin:0 0 8px;font-size:18px;color:#000;text-align:center}.validation-phase .phase-description{margin:0 0 16px;color:#000;font-size:14px;text-align:center}.enhancement-phase{background:#fff;border-radius:8px;padding:20px}.enhancement-phase h3{margin:0 0 8px;font-size:18px;color:#000;text-align:center}.enhancement-phase .phase-description{margin:0 0 20px;color:#000;font-size:14px;text-align:center}.enhancement-prompt{display:flex;flex-direction:column;align-items:center;gap:20px}.enhancement-preview{max-width:600px;width:100%;position:relative}.enhancement-preview img{width:100%;border-radius:8px;border:1px solid #000000}.enhancement-preview img.processing{opacity:.6}.processing-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#ffffffe6;border-radius:8px;color:#000;font-weight:500}.spinner.large{width:40px;height:40px;border:4px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.enhancement-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.apply-enhancement-btn{padding:14px 28px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.apply-enhancement-btn:hover{background:#f0f0f0}.skip-enhancement-btn{padding:14px 28px;background:#fff;color:#000;border:1px solid #000000;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.skip-enhancement-btn:hover{background:#f0f0f0}.enhancement-loading{display:flex;flex-direction:column;align-items:center}.enhancement-error-section{display:flex;flex-direction:column;align-items:center;gap:16px}.error-message{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#fff;border:2px solid #000000;border-radius:8px;max-width:500px}.error-icon{font-size:20px;flex-shrink:0}.error-text{color:#000;font-size:14px;line-height:1.4}.error-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.retry-btn{padding:12px 24px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.retry-btn:hover{background:#f0f0f0}.proceed-btn{padding:12px 24px;background:#fff;color:#000;border:1px solid #000000;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.proceed-btn:hover{background:#f0f0f0}.enhancement-comparison{display:flex;flex-direction:column;align-items:center;gap:20px}.comparison-header{text-align:center}.comparison-header h4{margin:0 0 8px;font-size:16px;color:#000}.comparison-header p{margin:0;color:#000;font-size:14px}.comparison-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;width:100%;max-width:900px}.comparison-image{position:relative;border:2px solid #000000;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s}.comparison-image:hover{opacity:.9}.comparison-image.selected{border-width:3px}.comparison-image .image-label{position:absolute;top:12px;left:12px;padding:6px 12px;background:#000;color:#fff;border-radius:4px;font-size:13px;font-weight:600;z-index:1}.comparison-image img{width:100%;display:block}.selected-indicator{position:absolute;bottom:12px;right:12px;padding:8px 14px;background:#000;color:#fff;border-radius:6px;font-size:13px;font-weight:600}.comparison-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:8px}.confirm-selection-btn{padding:14px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.confirm-selection-btn:hover{background:#f0f0f0}.retry-enhancement-btn{padding:14px 24px;background:#fff;color:#000;border:1px solid #000000;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.retry-enhancement-btn:hover{background:#f0f0f0}.enhancement-nav{display:flex;justify-content:center;margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0}.back-to-composition-btn{padding:10px 20px;background:#fff;border:1px solid #000000;border-radius:6px;font-size:14px;cursor:pointer;transition:all .15s;color:#000}.back-to-composition-btn:hover{background:#f0f0f0}.primary{background:#fff!important;color:#000!important;border:2px solid #000000!important}.primary:hover{background:#f0f0f0!important}.secondary{background:#fff!important;color:#000!important;border:1px solid #000000!important}.secondary:hover{background:#f0f0f0!important}.export-phase{background:#fff;border-radius:8px;padding:20px}.export-phase h3{margin:0 0 8px;font-size:18px;color:#000;text-align:center}.export-phase .phase-description{margin:0 0 20px;color:#000;font-size:14px;text-align:center}.export-preview{display:flex;justify-content:center;margin-bottom:24px}.export-preview img{max-width:100%;max-height:400px;border-radius:8px;border:1px solid #000000}.export-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.download-btn{display:flex;align-items:center;gap:8px;padding:14px 32px;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.download-btn:disabled{opacity:.5;cursor:not-allowed}.download-btn .spinner.small{width:16px;height:16px;border:2px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.back-btn{padding:14px 24px;background:#fff;color:#000;border:1px solid #000000;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.back-btn:hover{background:#f0f0f0}.export-success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px;background:#f5f5f5;border:2px solid #000000;border-radius:12px;margin-bottom:20px}.success-icon{width:60px;height:60px;background:#000;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700}.success-message{text-align:center}.success-message h4{margin:0 0 12px;font-size:18px;color:#000}.success-message .filename{margin:0 0 8px;font-size:14px;color:#000}.success-message .filename .label{color:#000;margin-right:8px}.success-message .filename code{background:#fff;padding:4px 8px;border-radius:4px;font-family:monospace;font-size:13px;color:#000;border:1px solid #000000}.success-message .sku-info{margin:0;font-size:13px;color:#000}.success-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.manifest-btn,.download-again-btn{padding:10px 20px;background:#fff;color:#000;border:1px solid #000000;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.manifest-btn:hover,.download-again-btn:hover{background:#f0f0f0}.complete-btn{padding:12px 28px;background:#fff;color:#000;border:2px solid #000000;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.complete-btn:hover{background:#f0f0f0}.export-nav{display:flex;justify-content:center;margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0}.back-to-enhancement-btn{padding:10px 20px;background:#fff;border:1px solid #000000;border-radius:6px;font-size:14px;cursor:pointer;transition:all .15s;color:#000}.back-to-enhancement-btn:hover{background:#f0f0f0}@media(max-width:768px){.composition-workflow{padding:12px}.products-display,.comparison-images,.preview-products{grid-template-columns:1fr}}.background-phase-section{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;border:1px solid #e0e0e0}.background-phase-section h3{margin:0 0 4px;font-size:16px;color:#000;font-weight:600}.background-phase-section h4{margin:0 0 12px;font-size:14px;color:#000;font-weight:600}.background-phase-section>p{margin:0 0 16px;color:#000;font-size:13px}.workflow-container{max-width:1200px;margin:0 auto;padding:1.5rem}.mode-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-radius:8px;margin-bottom:1rem;font-weight:500;font-size:.95rem;transition:all .3s ease}.mode-indicator.single-mode{background:#f5f5f5;border:1px solid #e0e0e0;color:#333}.mode-indicator.composition-mode{background:#000;border:2px solid #000000;color:#fff}.mode-icon{font-size:1.25rem}.mode-text{flex:1}.phase-locked-message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#fff;border:2px solid #000000;border-radius:8px;margin-bottom:1.5rem;color:#000;font-weight:500}.lock-icon{font-size:1.25rem}.workflow-content{background:#fff;border-radius:8px;padding:1.5rem;border:1px solid #000000}.phase-content{margin-bottom:1.5rem}.phase-content h2{margin:0 0 1rem;font-size:1.5rem;color:#000;font-weight:700}.phase-content p{color:#000;margin-bottom:1rem}.processing-indicator{display:flex;flex-direction:column;align-items:center;padding:3rem;text-align:center}.processing-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.processing-indicator p{color:#000;font-size:1rem}.empty-state{text-align:center;padding:3rem;color:#000}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;color:#000;font-weight:600}.empty-state p{margin:0}@media(max-width:768px){.workflow-container,.workflow-content{padding:1rem}}.composition-cta{margin-top:2rem;padding:1.5rem;background:#fff;border-radius:8px;text-align:center;border:1px solid #000000}.composition-cta p{margin-bottom:1rem;color:#000}.composition-cta .dimensions-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:1rem;color:#000}.composition-cta .dimensions-loading .spinner{width:20px;height:20px;border:2px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.composition-cta .dimensions-warning{display:flex;align-items:flex-start;gap:10px;padding:1rem;text-align:left;color:#000}.composition-cta .dimensions-warning .warning-icon{font-size:18px;flex-shrink:0}.mode-indicator.three-product-mode{background:#000;border:2px solid #000000;color:#fff}.mode-indicator.three-product-mode .mode-icon{font-size:1.5rem}.cta-button{padding:.75rem 1.5rem;background:#fff;color:#000;border:2px solid #000000;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.cta-button:hover{background:#f0f0f0}.auto-process-section{margin-top:1.5rem;padding:1rem;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0;display:flex;justify-content:center}.auto-process-background-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auto-process-background-selector-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:800px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.auto-process-background-selector-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e0e0e0}.auto-process-background-selector-modal .modal-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1a1a1a}.auto-process-background-selector-modal .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;padding:4px 8px;border-radius:4px;transition:background-color .2s}.auto-process-background-selector-modal .close-button:hover{background:#f0f0f0}.system-layout-composer{display:grid;grid-template-columns:280px 1fr 300px;gap:16px;height:calc(100vh - 120px);min-height:600px;padding:16px;background:#f5f5f5}.product-selection-panel{background:#fff;border-radius:8px;padding:16px;overflow-y:auto;box-shadow:0 2px 4px #0000001a}.product-selection-panel h3{margin:0 0 8px;font-size:16px;color:#333}.selection-hint{font-size:12px;color:#666;margin-bottom:16px}.product-list{display:flex;flex-direction:column;gap:8px}.product-item{display:flex;align-items:center;gap:12px;padding:8px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;transition:all .2s ease}.product-item:hover{border-color:#2196f3;background:#f0f7ff}.product-item.in-layout{border-color:#4caf50;background:#f0fff0}.product-thumbnail{width:48px;height:48px;object-fit:contain;border-radius:4px;background:#fff}.product-item .product-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.product-item .product-name{font-size:13px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-item .product-sku{font-size:11px;color:#666}.add-remove-btn{width:28px;height:28px;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s ease}.add-remove-btn.add{background:#2196f3;color:#fff}.add-remove-btn.add:hover{background:#1976d2}.add-remove-btn.remove{background:#f44336;color:#fff}.add-remove-btn.remove:hover{background:#d32f2f}.composition-mode-indicator{margin-top:16px;padding:12px;border-radius:6px;font-size:13px;text-align:center;background:#fff3e0;color:#e65100}.composition-mode-indicator.enabled{background:#e8f5e9;color:#2e7d32}.canvas-area{display:flex;flex-direction:column;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.canvas-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f8f8;border-bottom:1px solid #e0e0e0}.grid-controls{display:flex;align-items:center;gap:16px}.grid-controls label{display:flex;align-items:center;gap:6px;font-size:13px;color:#555;cursor:pointer}.grid-controls select{padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px}.layer-controls{display:flex;gap:8px}.layer-controls button{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;cursor:pointer;transition:all .2s ease}.layer-controls button:hover:not(:disabled){background:#f0f0f0;border-color:#bbb}.layer-controls button:disabled{opacity:.5;cursor:not-allowed}.layout-canvas{position:relative;flex:1;margin:16px;background:#fff;border:2px dashed #ddd;border-radius:4px;overflow:hidden;cursor:crosshair;transform-origin:top left;transform:scale(.5)}.grid-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.layout-product{position:absolute;cursor:move;-webkit-user-select:none;user-select:none;border:2px solid transparent;transition:border-color .2s ease}.layout-product:hover{border-color:#2196f3}.layout-product.selected{border-color:#2196f3;box-shadow:0 0 0 2px #2196f34d}.layout-product img{width:100%;height:100%;object-fit:contain;pointer-events:none}.selection-handles{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.selection-handles .handle{position:absolute;width:10px;height:10px;background:#2196f3;border:2px solid white;border-radius:2px;pointer-events:auto;cursor:nwse-resize}.selection-handles .handle.nw{top:-5px;left:-5px;cursor:nwse-resize}.selection-handles .handle.ne{top:-5px;right:-5px;cursor:nesw-resize}.selection-handles .handle.sw{bottom:-5px;left:-5px;cursor:nesw-resize}.selection-handles .handle.se{bottom:-5px;right:-5px;cursor:nwse-resize}.properties-panel{background:#fff;border-radius:8px;padding:16px;overflow-y:auto;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:20px}.template-section h3,.product-properties h3{margin:0 0 12px;font-size:14px;color:#333;text-transform:uppercase;letter-spacing:.5px}.template-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.template-item{padding:8px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;text-align:center}.template-item:hover{border-color:#2196f3}.template-item.selected{border-color:#2196f3;background:#f0f7ff}.template-preview{width:100%;height:60px;object-fit:contain;margin-bottom:4px}.template-name{font-size:11px;color:#555}.product-properties{border-top:1px solid #e0e0e0;padding-top:16px}.property-group{margin-bottom:16px}.property-group label{display:block;font-size:12px;color:#666;margin-bottom:6px}.position-inputs{display:flex;align-items:center;gap:8px}.position-inputs input{width:70px;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:13px}.position-inputs span{color:#999}.property-group input[type=range]{width:100%;margin-bottom:8px}.scale-presets{display:flex;flex-wrap:wrap;gap:4px}.preset-btn{padding:4px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:11px;cursor:pointer;transition:all .2s ease}.preset-btn:hover{background:#f0f0f0}.preset-btn.active{background:#2196f3;color:#fff;border-color:#2196f3}.dimensions-display{font-size:13px;color:#333;font-family:monospace}.actions-section{margin-top:auto;display:flex;flex-direction:column;gap:8px}.render-btn,.export-btn{padding:12px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.render-btn{background:#4caf50;color:#fff}.render-btn:hover:not(:disabled){background:#43a047}.export-btn{background:#2196f3;color:#fff}.export-btn:hover:not(:disabled){background:#1976d2}.render-btn:disabled,.export-btn:disabled{background:#ccc;cursor:not-allowed}@media(max-width:1200px){.system-layout-composer{grid-template-columns:240px 1fr 260px}}@media(max-width:900px){.system-layout-composer{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.product-selection-panel{max-height:200px}.properties-panel{max-height:300px}}.template-selector{display:flex;flex-direction:column;gap:12px}.template-filters{display:flex;flex-direction:column;gap:8px}.category-tab{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;font-size:12px;cursor:pointer;transition:all .2s ease}.category-tab:hover{background:#f5f5f5;border-color:#bbb}.category-tab.active{background:#2196f3;color:#fff;border-color:#2196f3}.suitable-filter{display:flex;align-items:center;gap:6px;font-size:12px;color:#666;cursor:pointer}.suitable-filter input{cursor:pointer}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.template-card{position:relative;padding:8px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease}.template-card:hover{border-color:#2196f3;box-shadow:0 2px 8px #2196f333}.template-card.selected{border-color:#2196f3;background:#f0f7ff}.template-preview{width:100%;aspect-ratio:16 / 9;background:#f5f5f5;border-radius:4px;overflow:hidden;margin-bottom:8px}.template-preview img{width:100%;height:100%;object-fit:contain}.template-info{display:flex;flex-direction:column;gap:2px}.template-name{font-size:12px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-slots{font-size:10px;color:#888}.selected-indicator{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#2196f3;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.no-templates{grid-column:1 / -1;padding:20px;text-align:center;color:#666;font-size:13px}.show-all-btn{display:block;margin:12px auto 0;padding:8px 16px;border:1px solid #2196f3;border-radius:4px;background:#fff;color:#2196f3;font-size:12px;cursor:pointer;transition:all .2s ease}.show-all-btn:hover{background:#2196f3;color:#fff}.progress-indicator{background:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 2px 8px #0000001a;margin-bottom:8px;transition:all .2s ease}.progress-indicator--queued{border-left:4px solid #6b7280}.progress-indicator--processing{border-left:4px solid #3b82f6}.progress-indicator--complete{border-left:4px solid #10b981}.progress-indicator--failed{border-left:4px solid #ef4444}.progress-indicator__header{display:flex;align-items:center;gap:8px}.progress-indicator__icon{font-size:16px;flex-shrink:0}.progress-indicator__message{flex:1;font-size:14px;color:#374151;font-weight:500}.progress-indicator__dismiss{background:none;border:none;font-size:18px;color:#9ca3af;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s ease}.progress-indicator__dismiss:hover{color:#374151}.progress-indicator__bar-container{height:6px;background:#e5e7eb;border-radius:3px;margin-top:10px;overflow:hidden}.progress-indicator__bar{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;transition:width .3s ease}.progress-indicator--processing .progress-indicator__bar{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.progress-indicator__details{display:flex;align-items:center;gap:12px;margin-top:8px;font-size:12px}.progress-indicator__status{color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.progress-indicator__percentage{color:#3b82f6;font-weight:600}.progress-indicator__error{color:#ef4444;flex:1}.progress-queue{position:fixed;bottom:20px;right:20px;width:320px;z-index:1000}.progress-queue__hidden-count{text-align:center;font-size:12px;color:#6b7280;padding:8px;background:#f3f4f6;border-radius:6px}@media(max-width:480px){.progress-queue{left:20px;right:20px;width:auto}}.error-notification{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:0 4px 12px #ef444426;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.error-notification__header{display:flex;align-items:flex-start;gap:12px}.error-notification__icon{font-size:20px;flex-shrink:0;margin-top:2px}.error-notification__content{flex:1;min-width:0}.error-notification__code{display:inline-block;font-size:11px;font-weight:600;color:#b91c1c;background:#fee2e2;padding:2px 8px;border-radius:4px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.error-notification__message{margin:0;font-size:14px;color:#991b1b;line-height:1.5}.error-notification__close{background:none;border:none;font-size:20px;color:#dc2626;cursor:pointer;padding:0;line-height:1;opacity:.6;transition:opacity .2s ease}.error-notification__close:hover{opacity:1}.error-notification__actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #fecaca}.error-notification__action{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.error-notification__action--primary{background:#ef4444;color:#fff;border:none}.error-notification__action--primary:hover{background:#dc2626}.error-notification__action--secondary{background:transparent;color:#b91c1c;border:1px solid #fca5a5}.error-notification__action--secondary:hover{background:#fee2e2}.error-container{position:fixed;top:20px;right:20px;width:380px;z-index:1100}.error-container__hidden-count{text-align:center;font-size:12px;color:#b91c1c;padding:8px;background:#fef2f2;border-radius:6px;border:1px solid #fecaca}@media(max-width:480px){.error-container{left:16px;right:16px;width:auto}.error-notification__actions{flex-direction:column}}.auto-process-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auto-process-modal{background:var(--color-surface, #ffffff);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border, #e0e0e0)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text, #1a1a1a)}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary, #666);padding:4px 8px;border-radius:4px;transition:background-color .2s}.close-button:hover{background:var(--color-hover, #f0f0f0)}.modal-content{padding:24px;overflow-y:auto;flex:1 1 auto;min-height:0}.progress-section{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0}.progress-spinner{width:48px;height:48px;border:4px solid var(--color-border, #e0e0e0);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:spin 1s linear infinite}.current-step{font-size:1rem;color:var(--color-text, #1a1a1a);font-weight:500;text-align:center}.progress-bar{width:100%;height:8px;background:var(--color-border, #e0e0e0);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--color-primary, #3b82f6);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.875rem;color:var(--color-text-secondary, #666)}.result-section{display:flex;flex-direction:column;gap:20px}.result-image-container{display:flex;justify-content:center;background:var(--color-background, #f5f5f5);border-radius:8px;padding:16px}.result-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.steps-summary{background:var(--color-background, #f5f5f5);border-radius:8px;padding:16px}.steps-summary h3{margin:0 0 12px;font-size:.875rem;font-weight:600;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.steps-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.steps-list li{display:flex;align-items:center;gap:8px;font-size:.875rem}.step-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem}.step-completed .step-icon{background:var(--color-success, #22c55e);color:#fff}.step-failed .step-icon{background:var(--color-error, #ef4444);color:#fff}.step-processing .step-icon{background:var(--color-primary, #3b82f6);color:#fff;animation:pulse 1s ease-in-out infinite}.step-skipped .step-icon{background:var(--color-border, #e0e0e0);color:var(--color-text-secondary, #666)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.step-name{color:var(--color-text, #1a1a1a)}.fallback-badge{font-size:.75rem;color:var(--color-warning, #f59e0b);background:#f59e0b1a;padding:2px 6px;border-radius:4px}.result-actions{display:flex;gap:12px;justify-content:center}.download-button,.continue-button{padding:12px 24px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.download-button{background:var(--color-primary, #3b82f6);color:#fff;border:none}.download-button:hover{background:var(--color-primary-dark, #2563eb)}.continue-button{background:transparent;color:var(--color-primary, #3b82f6);border:1px solid var(--color-primary, #3b82f6)}.continue-button:hover{background:#3b82f61a}.error-section{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0;text-align:center}.error-icon{font-size:3rem;color:var(--color-error, #ef4444)}.error-message{color:var(--color-error, #ef4444);font-size:.875rem;max-width:400px}.error-actions{display:flex;gap:12px}.retry-button,.manual-button{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.retry-button{background:var(--color-primary, #3b82f6);color:#fff;border:none}.retry-button:hover{background:var(--color-primary-dark, #2563eb)}.manual-button{background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #e0e0e0)}.manual-button:hover{background:var(--color-hover, #f0f0f0)}.inline-system-analysis{background:#fff;border-radius:8px;padding:0}.inline-system-analysis.expanded{background:#fff}.analysis-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.analysis-header h4{margin:0;font-size:20px;font-weight:600;color:#1e40af}.analysis-header .close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#666;padding:0 4px}.analysis-header .close-btn:hover{color:#333}.analysis-prompt p{margin:0 0 12px;font-size:13px;color:#666}.analyze-btn{background:#2563eb;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.analyze-btn:hover{background:#1d4ed8}.analysis-progress{padding:8px 0}.analysis-progress .progress-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-bottom:8px}.analysis-progress .progress-fill{height:100%;background:#2563eb;transition:width .3s ease}.analysis-progress .progress-message{font-size:12px;color:#666}.analysis-progress .progress-status{display:flex;align-items:center;gap:8px}.analysis-progress .spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin 1s linear infinite}.analysis-error{display:flex;align-items:center;gap:8px;padding:8px;background:#fef2f2;border-radius:6px}.analysis-error .error-icon{font-size:14px}.analysis-error .error-text{flex:1;font-size:13px;color:#dc2626}.analysis-error .retry-btn{background:#dc2626;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px}.analysis-results .results-summary{margin-bottom:16px;padding:12px;background:#ecfdf5;border-radius:6px;border:1px solid #a7f3d0}.analysis-results .result-count{font-size:16px;font-weight:600;color:#059669}.detected-products-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:400px;overflow-y:auto}.detected-product-item{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.detected-product-item .product-header{display:flex;flex-direction:column;gap:2px}.detected-product-item .product-name{font-size:13px;font-weight:600;color:#333}.detected-product-item .product-model{font-size:12px;color:#666}.detected-product-item .product-thumbnails{display:flex;gap:6px;flex-wrap:wrap;margin:4px 0}.detected-product-item .thumbnail-item{width:72px;height:72px;border-radius:6px;overflow:hidden;border:2px solid #e5e7eb}.detected-product-item .thumbnail-item img{width:100%;height:100%;object-fit:cover}.detected-product-item .product-images{font-size:11px;color:#888}.detected-product-item .no-images-message{font-size:12px;color:#999;font-style:italic;padding:8px 0}.detected-product-item .product-confidence{display:flex;align-items:center;gap:6px;font-size:12px;margin-bottom:6px}.detected-product-item .confidence-label{color:#666}.detected-product-item .confidence-value{font-weight:600}.detected-product-item .confidence-value.high{color:#059669}.detected-product-item .confidence-value.low{color:#d97706}.detected-product-item .thumbnails-label{font-size:11px;color:#666;margin-bottom:4px;width:100%}.detected-product-item .more-images-note{font-size:11px;color:#888;font-style:italic;padding:4px}.detected-product-item .matched-images-section{margin-top:8px}.detected-product-item .match-status{font-size:12px;padding:4px 8px;border-radius:4px;margin-bottom:8px}.detected-product-item .match-status.matched{background:#d1fae5;color:#065f46}.detected-product-item .match-status.unmatched{background:#fef3c7;color:#92400e}.detected-product-item .image-count{font-size:11px;color:#666;margin-top:4px}.no-matches-message{padding:16px;text-align:center;color:#666;font-style:italic;background:#f9fafb;border-radius:6px}.results-actions{display:flex;justify-content:flex-end}.results-actions .secondary-btn{background:#e5e7eb;color:#333;border:none;padding:6px 14px;border-radius:4px;cursor:pointer;font-size:13px}.results-actions .secondary-btn:hover{background:#d1d5db}.detected-product-item .thumbnail-item{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.detected-product-item .thumbnail-item:hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026;z-index:1}.image-lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.lightbox-content{position:relative;max-width:90vw;max-height:90vh}.lightbox-content img{max-width:100%;max-height:85vh;border-radius:8px;box-shadow:0 4px 20px #0000004d}.lightbox-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:32px;cursor:pointer;padding:0 8px;line-height:1}.lightbox-close:hover{color:#ccc}.confirm-count-section{padding:8px 0}.count-result{display:flex;align-items:center;gap:12px;margin-bottom:12px}.count-label{font-size:14px;font-weight:500;color:#333}.count-input-row{display:flex;align-items:center;gap:8px}.count-adjust-btn{width:28px;height:28px;border:1px solid #d1d5db;background:#fff;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.count-adjust-btn:hover{background:#f3f4f6}.count-value{font-size:20px;font-weight:700;color:#2563eb;min-width:32px;text-align:center}.detected-descriptions{background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:10px;margin-bottom:12px}.descriptions-label{font-size:12px;color:#666;display:block;margin-bottom:6px}.detected-descriptions ul{margin:0;padding-left:18px}.detected-descriptions li{font-size:13px;color:#333;margin-bottom:4px}.confirm-actions{display:flex;justify-content:flex-end;gap:8px}.confirm-actions .secondary-btn,.results-actions .secondary-btn{background:#e5e7eb;color:#333;border:none;padding:8px 14px;border-radius:6px;cursor:pointer;font-size:13px}.confirm-actions .secondary-btn:hover,.results-actions .secondary-btn:hover{background:#d1d5db}.confirm-actions .primary-btn,.results-actions .primary-btn{background:#2563eb;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500}.confirm-actions .primary-btn:hover,.results-actions .primary-btn:hover{background:#1d4ed8}.results-actions{display:flex;justify-content:flex-end;gap:8px}.product-slots-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:20px}.product-slot-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:16px}.slot-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.slot-number{background:#2563eb;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:4px}.slot-description{font-size:14px;color:#333;font-weight:500;flex:1}.slot-images{margin-top:8px}.product-slot-item .product-thumbnails{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.product-slot-item .thumbnail-item{width:100px;height:100px;border-radius:8px;overflow:hidden;border:2px solid #e5e7eb;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.product-slot-item .thumbnail-item:hover{transform:scale(1.05);border-color:#2563eb}.product-slot-item .thumbnail-item img{width:100%;height:100%;object-fit:cover}.product-slot-item.unmatched{background:#fef3c7;border-color:#f59e0b}.product-slot-item.unmatched .slot-number{background:#f59e0b}.product-slot-item.unmatched .slot-description{color:#92400e}.background-selection-inline{margin:20px 0;padding:16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px}.background-selection-inline h5{margin:0 0 12px;font-size:14px;font-weight:600;color:#0369a1}.loading-backgrounds{font-size:13px;color:#666;padding:8px 0}.background-options-inline{display:flex;gap:10px;flex-wrap:wrap}.background-option-inline{width:80px;height:80px;border-radius:8px;overflow:hidden;border:3px solid transparent;cursor:pointer;transition:border-color .2s ease,transform .15s ease}.background-option-inline:hover{transform:scale(1.05);border-color:#93c5fd}.background-option-inline.selected{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb4d}.background-option-inline img{width:100%;height:100%;object-fit:cover}.process-all-btn{background:linear-gradient(135deg,#059669,#10b981);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;display:flex;align-items:center;gap:6px;transition:transform .15s ease,box-shadow .15s ease}.process-all-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0596694d}.process-all-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.system-images-section{padding:1rem;background:#fff;border:1px solid #000000;border-radius:8px}.system-images-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.system-images-section .section-title{margin:0;font-size:1.1rem;font-weight:700;color:#000;display:flex;align-items:center;gap:.5rem}.section-icon{font-size:1.2rem}.system-images-section .section-controls{display:flex;align-items:center;gap:1rem}.system-images-section .image-count{font-size:.85rem;color:#000;padding:.25rem .5rem;background:#fff;border:1px solid #000000;border-radius:4px;font-weight:500}.system-images-section .select-all-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#000;cursor:pointer}.system-images-section .select-all-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.system-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.system-image-item{position:relative;background:#fff;border:1px solid #000000;border-radius:8px;overflow:hidden;transition:transform .2s;cursor:pointer}.system-image-item:hover{transform:translateY(-2px)}.system-image-item.selected{border-width:2px}.system-image-item .image-checkbox{position:absolute;top:.5rem;left:.5rem;z-index:2}.system-image-item .image-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.system-image-item .image-thumbnail{position:relative;aspect-ratio:16/9;overflow:hidden;background:#f5f5f5}.system-image-item .image-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.system-image-item:hover .image-thumbnail img{transform:scale(1.05)}.selected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;display:flex;align-items:center;justify-content:center}.selected-check{width:32px;height:32px;background:#000;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700}.system-image-item .image-info{padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;border-top:1px solid #000000}.system-image-item .view-label{font-size:.85rem;font-weight:500;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.system-image-item .confidence-badge{font-size:.7rem;padding:.2rem .4rem;border-radius:4px;font-weight:500;background:#fff;color:#000;border:1px solid #000000}.metadata-toggle{padding:.4rem .75rem;border-top:1px solid #000000;cursor:pointer;text-align:center;transition:background .2s}.metadata-toggle:hover{background:#f5f5f5}.metadata-toggle .toggle-text{font-size:.7rem;color:#000;font-weight:500}.metadata-details{padding:.5rem .75rem;border-top:1px solid #000000;background:#fafafa}.metadata-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.25rem;font-size:.7rem}.metadata-row:last-child{margin-bottom:0}.metadata-label{font-weight:600;color:#000;flex-shrink:0;margin-right:.5rem}.metadata-value{color:#000;word-break:break-all;text-align:right}.metadata-url{font-family:monospace;font-size:.65rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.system-images-section .section-header{flex-direction:column;align-items:flex-start}.system-images-section .section-controls{width:100%;justify-content:space-between}.system-images-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.analyze-system-image-btn{width:100%;padding:.6rem .75rem;border:none;border-top:1px solid #000000;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.4rem}.analyze-system-image-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px)}.analyze-system-image-btn:active{transform:translateY(0)}.system-image-item.analyzing{border-color:#2563eb;border-width:2px}.analysis-complete-badge{padding:.4rem .75rem;background:#dcfce7;color:#166534;font-size:.75rem;font-weight:500;text-align:center;border-top:1px solid #000000}.full-width-analysis-container{margin-top:1.5rem;padding:1.5rem;background:#f8fafc;border:3px solid #2563eb;border-radius:12px;box-shadow:0 8px 32px #2563eb33}.analysis-image-reference{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.analysis-image-reference img{width:120px;height:80px;object-fit:cover;border-radius:6px;border:2px solid #2563eb}.analysis-image-reference span{font-size:1rem;font-weight:600;color:#1e40af}.product-group:hover,.product-group.fully-selected{border-width:2px}.product-group-header{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;gap:.75rem;transition:background .2s}.product-group-header:hover{background:#f5f5f5}.product-group-checkbox{flex-shrink:0}.product-group-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.product-group-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.product-group-name{font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-group-sku{font-size:.75rem;color:#000;font-family:monospace;font-style:italic}.product-group-dimensions{font-size:.75rem;color:#000;font-family:monospace;padding:.2rem .4rem;background:#f0f0f0;border:1px solid #cccccc;border-radius:4px;display:inline-block;margin-top:.2rem}.product-group-dimensions.missing{background:#fff8e6;border-color:#d4a800;color:#8a6d00;font-style:italic;font-family:inherit}.product-group-dimensions.scraped{background:#e8f5e9;border-color:#4caf50}.product-group-dimensions.estimated{background:#fff3e0;border-color:#ff9800}.dimension-source-badge{display:inline-block;font-size:.65rem;padding:.1rem .3rem;border-radius:3px;margin-left:.5rem;font-weight:600;font-family:inherit}.dimension-source-badge.scraped{background:#4caf50;color:#fff}.dimension-source-badge.manual{background:#ff9800;color:#fff}.product-group-dimensions.loading{background:#e3f2fd;border-color:#2196f3;color:#1565c0;display:inline-flex;align-items:center;gap:.4rem}.dimension-loading-spinner{width:12px;height:12px;border:2px solid #90caf9;border-top-color:#1565c0;border-radius:50%;animation:dimension-spin .8s linear infinite}@keyframes dimension-spin{to{transform:rotate(360deg)}}.product-group-image-count{font-size:.8rem;padding:.25rem .6rem;background:#fff;color:#000;border:1px solid #000000;border-radius:12px;font-weight:600;flex-shrink:0}.product-group-expand-icon{font-size:.7rem;color:#000;transition:transform .2s;flex-shrink:0}.product-group-expand-icon.expanded{transform:rotate(180deg)}.product-group-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:.75rem 1rem 1rem;border-top:1px solid #000000;background:#fafafa}.product-group-image-item{position:relative;background:#fff;border:1px solid #000000;border-radius:6px;overflow:hidden;transition:transform .2s}.product-group-image-item:hover{transform:translateY(-2px)}.product-group-image-item.selected{border-width:2px}.product-group-image-checkbox{position:absolute;top:.4rem;left:.4rem;z-index:2}.product-group-image-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.product-group-image-thumbnail{position:relative;aspect-ratio:1;overflow:hidden;background:#f5f5f5}.product-group-image-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.product-group-image-item:hover .product-group-image-thumbnail img{transform:scale(1.05)}.product-group-selected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;display:flex;align-items:center;justify-content:center}.product-group-selected-check{width:28px;height:28px;background:#000;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.product-group-image-info{padding:.5rem;display:flex;justify-content:space-between;align-items:center;gap:.25rem;border-top:1px solid #000000}.product-group-view-label{font-size:.75rem;font-weight:500;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-group-confidence-badge{font-size:.65rem;padding:.15rem .35rem;border-radius:4px;font-weight:500;flex-shrink:0;background:#fff;color:#000;border:1px solid #000000}.product-group-metadata-toggle{padding:.35rem .5rem;border-top:1px solid #000000;cursor:pointer;text-align:center;transition:background .2s}.product-group-metadata-toggle:hover{background:#f5f5f5}.product-group-metadata-toggle .toggle-text{font-size:.65rem;color:#000;font-weight:500}.product-group-metadata-details{padding:.4rem .5rem;border-top:1px solid #000000;background:#fafafa}.product-group-metadata-details .metadata-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.2rem;font-size:.65rem}.product-group-metadata-details .metadata-row:last-child{margin-bottom:0}.product-group-metadata-details .metadata-label{font-weight:600;color:#000;flex-shrink:0;margin-right:.4rem}.product-group-metadata-details .metadata-value{color:#000;word-break:break-all;text-align:right}.product-group-metadata-details .metadata-url{font-family:monospace;font-size:.6rem;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.product-group-header{flex-wrap:wrap}.product-group-info{order:1;width:calc(100% - 30px)}.product-group-image-count{order:2}.product-group-expand-icon{order:3}.product-group-images{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.product-group-angle-badge-container{display:flex;align-items:center;justify-content:space-between;padding:.4rem .5rem;border-top:1px solid #000000;background:#f8f8f8}.product-group-angle-badge-container.low-confidence-warning{background:#fff8e6;border-top-color:#d4a800}.product-group-angle-badge{display:flex;align-items:center;gap:.4rem;padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;cursor:default;transition:all .2s}.product-group-angle-badge.high{background:#e8f5e9;border:1px solid #4caf50;color:#2e7d32}.product-group-angle-badge.medium{background:#fff3e0;border:1px solid #ff9800;color:#e65100}.product-group-angle-badge.low{background:#ffebee;border:1px solid #f44336;color:#c62828}.product-group-angle-badge.manual{background:#e3f2fd;border:1px solid #2196f3;color:#1565c0}.product-group-angle-badge .angle-label{white-space:nowrap}.product-group-angle-badge .angle-confidence{display:flex;align-items:center;font-size:.6rem;letter-spacing:-1px}.product-group-angle-badge .confidence-indicator{opacity:.8}.product-group-angle-badge .manual-indicator{font-size:.75rem}.low-confidence-icon{font-size:.85rem;cursor:help}.metadata-value.override-value{color:#1565c0;font-weight:500}.product-group-angle-badge.clickable{cursor:pointer;transition:all .2s}.product-group-angle-badge.clickable:hover{filter:brightness(.95);transform:translateY(-1px)}.product-group-angle-badge .dropdown-arrow{font-size:.5rem;margin-left:.2rem;opacity:.6}.angle-override-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;background:#fff;border:1px solid #000000;border-radius:6px;box-shadow:0 4px 12px #00000026;margin-top:4px;overflow:hidden}.angle-override-dropdown .dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .6rem;background:#f5f5f5;border-bottom:1px solid #e0e0e0;font-size:.7rem;font-weight:600;color:#333}.angle-override-dropdown .clear-override-btn{padding:.2rem .4rem;font-size:.6rem;background:#fff;border:1px solid #ccc;border-radius:3px;color:#666;cursor:pointer;transition:all .2s}.angle-override-dropdown .clear-override-btn:hover{background:#f0f0f0;border-color:#999}.angle-override-dropdown .dropdown-options{max-height:200px;overflow-y:auto}.angle-override-dropdown .dropdown-option{display:flex;align-items:center;gap:.4rem;padding:.5rem .6rem;font-size:.7rem;cursor:pointer;transition:background .15s}.angle-override-dropdown .dropdown-option:hover{background:#f5f5f5}.angle-override-dropdown .dropdown-option.selected{background:#e3f2fd;font-weight:600}.angle-override-dropdown .dropdown-option .option-label{flex:1}.angle-override-dropdown .dropdown-option .option-check{color:#1565c0;font-weight:700}.angle-override-dropdown .dropdown-option .option-detected{font-size:.6rem;color:#888;font-style:italic}.product-group-angle-badge-container{position:relative}.angle-reasoning-tooltip{position:absolute;bottom:100%;left:0;right:0;z-index:101;background:#fff;border:1px solid #000000;border-radius:6px;box-shadow:0 4px 12px #0003;margin-bottom:8px;overflow:hidden;min-width:200px}.angle-reasoning-tooltip .tooltip-header{padding:.5rem .6rem;background:#333;color:#fff;font-size:.7rem;font-weight:600}.angle-reasoning-tooltip .tooltip-content{padding:.5rem .6rem}.angle-reasoning-tooltip .tooltip-row{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.4rem}.angle-reasoning-tooltip .tooltip-row:last-child{margin-bottom:0}.angle-reasoning-tooltip .tooltip-label{font-size:.6rem;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.angle-reasoning-tooltip .tooltip-value{font-size:.7rem;color:#333;line-height:1.3}.angle-reasoning-tooltip .tooltip-value.confidence-high{color:#2e7d32;font-weight:500}.angle-reasoning-tooltip .tooltip-value.confidence-medium{color:#e65100;font-weight:500}.angle-reasoning-tooltip .tooltip-value.confidence-low{color:#c62828;font-weight:500}.angle-reasoning-tooltip .tooltip-override-notice{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background:#e3f2fd;border-top:1px solid #90caf9;font-size:.65rem;color:#1565c0}.angle-reasoning-tooltip .tooltip-override-notice .override-icon{font-size:.75rem}.angle-reasoning-tooltip:after{content:"";position:absolute;bottom:-6px;left:20px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #ffffff}.angle-reasoning-tooltip:before{content:"";position:absolute;bottom:-8px;left:19px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:7px solid #000000}.product-group-analyze-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:100%;padding:6px 8px;margin-top:4px;border:1px solid #2563eb;border-radius:4px;background:#eff6ff;color:#2563eb;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease}.product-group-analyze-btn:hover{background:#2563eb;color:#fff}.product-group-analyze-btn.has-result{background:#dcfce7;border-color:#16a34a;color:#166534}.product-group-analyze-btn.has-result:hover{background:#bbf7d0}.product-images-section{padding:1rem;background:#fff;border:1px solid #000000;border-radius:8px}.product-images-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.product-images-section .section-title{margin:0;font-size:1.1rem;font-weight:700;color:#000;display:flex;align-items:center;gap:.5rem}.product-images-section .section-controls{display:flex;align-items:center;gap:1rem}.product-images-section .image-count{font-size:.85rem;color:#000;padding:.25rem .5rem;background:#fff;border:1px solid #000000;border-radius:4px;font-weight:500}.expand-btn{padding:.3rem .6rem;font-size:.75rem;background:#fff;border:1px solid #000000;border-radius:4px;color:#000;cursor:pointer;transition:all .2s}.expand-btn:hover{background:#f0f0f0}.product-images-section .section-description{margin:0 0 1rem;font-size:.85rem;color:#000;font-style:italic}.product-groups-list{display:flex;flex-direction:column;gap:.75rem}.product-group{background:#fff;border:1px solid #000000;border-radius:8px;overflow:hidden}.product-group:hover{box-shadow:0 0 0 1px #000}.product-group.fully-selected{border-width:2px}.group-header{display:flex;align-items:center;padding:.75rem 1rem;cursor:pointer;gap:.75rem;transition:background .2s}.group-header:hover{background:#f5f5f5}.group-checkbox{flex-shrink:0}.group-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.group-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.group-name{font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-sku{font-size:.75rem;color:#000;font-family:monospace;font-style:italic}.group-image-count{font-size:.8rem;padding:.25rem .6rem;background:#fff;color:#000;border:1px solid #000000;border-radius:12px;font-weight:600;flex-shrink:0}.expand-icon{font-size:.7rem;color:#000;transition:transform .2s;flex-shrink:0}.expand-icon.expanded{transform:rotate(180deg)}.group-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;padding:.75rem 1rem 1rem;border-top:1px solid #000000;background:#fafafa}.product-image-item{position:relative;background:#fff;border:1px solid #000000;border-radius:6px;overflow:hidden;transition:transform .2s}.product-image-item:hover{transform:translateY(-2px)}.product-image-item.selected{border-width:2px}.product-image-item .image-checkbox{position:absolute;top:.4rem;left:.4rem;z-index:2}.product-image-item .image-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.product-image-item .image-thumbnail{position:relative;aspect-ratio:1;overflow:hidden;background:#f5f5f5}.product-image-item .image-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.product-image-item:hover .image-thumbnail img{transform:scale(1.05)}.product-image-item .selected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;display:flex;align-items:center;justify-content:center}.product-image-item .selected-check{width:28px;height:28px;background:#000;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.product-image-item .image-info{padding:.5rem;display:flex;justify-content:space-between;align-items:center;gap:.25rem;border-top:1px solid #000000}.product-image-item .view-label{font-size:.75rem;font-weight:500;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-image-item .confidence-badge{font-size:.65rem;padding:.15rem .35rem;border-radius:4px;font-weight:500;flex-shrink:0;background:#fff;color:#000;border:1px solid #000000}@media(max-width:768px){.product-images-section .section-header{flex-direction:column;align-items:flex-start}.product-images-section .section-controls{width:100%;justify-content:space-between}.group-header{flex-wrap:wrap}.group-info{order:1;width:calc(100% - 30px)}.group-image-count{order:2}.expand-icon{order:3}.group-images{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.analysis-accordion{margin:8px 0 16px;border:2px solid #2563eb;border-radius:8px;background:#f8fafc;overflow:hidden}.analysis-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#eff6ff;border-bottom:1px solid #dbeafe;font-size:14px;font-weight:500;color:#1e40af}.analysis-accordion-header .accordion-close{background:none;border:none;font-size:20px;cursor:pointer;color:#64748b;padding:0 4px;line-height:1}.analysis-accordion-header .accordion-close:hover{color:#1e40af}.analysis-accordion-content{display:flex;gap:16px;padding:16px}.analysis-source-image{flex-shrink:0;width:200px}.analysis-source-image img{width:100%;height:auto;border-radius:6px;border:1px solid #e2e8f0}.analysis-accordion-content .inline-system-analysis{flex:1;border:none;background:transparent;padding:0}@media(max-width:768px){.analysis-accordion-content{flex-direction:column}.analysis-source-image{width:100%;max-width:300px}}.camera-angle-selector{padding:1rem;background:#f8f9fa;border-radius:8px}.camera-angle-selector.disabled{opacity:.6;pointer-events:none}.camera-angle-title{margin:0 0 .5rem;font-size:1.1rem;color:#333}.camera-angle-description{margin:0 0 1rem;font-size:.9rem;color:#666}.angle-presets{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.75rem;max-width:800px}.angle-preset-btn{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative}.angle-preset-btn:hover:not(:disabled){border-color:#007bff;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.angle-preset-btn:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff40}.angle-preset-btn.selected{border-color:#28a745;background:#f0fff4}.angle-preset-btn:disabled{cursor:not-allowed;opacity:.5}.angle-icon-wrapper{width:64px;height:64px;margin-bottom:.5rem;color:#333}.angle-preset-btn.selected .angle-icon-wrapper{color:#28a745}.angle-icon{width:100%;height:100%}.angle-label{font-size:.85rem;font-weight:500;color:#333;text-align:center}.angle-preset-btn.selected .angle-label{color:#28a745}.selected-indicator{position:absolute;top:.5rem;right:.5rem;width:20px;height:20px;background:#28a745;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}@media(max-width:600px){.angle-presets{grid-template-columns:repeat(2,1fr)}.angle-preset-btn{padding:.75rem}.angle-icon-wrapper{width:36px;height:36px}.angle-label{font-size:.75rem}}.multi-view-renderer{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014}.multi-view-header{text-align:center;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.multi-view-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:#1f2937}.multi-view-description{margin:0;font-size:.95rem;color:#6b7280}.multi-view-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;color:#92400e;font-size:.9rem}.warning-icon{flex-shrink:0}.multi-view-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.option-card{display:flex;flex-direction:column;padding:1.25rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;transition:border-color .2s ease}.option-card:hover{border-color:#d1d5db}.option-card--generate{border-color:#3b82f6;background:#eff6ff}.option-card--skip{border-color:#10b981;background:#ecfdf5}.option-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#1f2937}.option-description{margin:0 0 1rem;font-size:.9rem;color:#6b7280}.render-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:auto;padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,opacity .2s ease}.render-btn:hover:not(:disabled){background:#2563eb}.render-btn:disabled{opacity:.6;cursor:not-allowed}.render-btn-icon{font-size:1.1rem}.render-btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.skip-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:auto;padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,opacity .2s ease}.skip-btn:hover:not(:disabled){background:#059669}.skip-btn:disabled{opacity:.6;cursor:not-allowed}.skip-btn-icon{font-size:1.1rem}.multi-view-preview-section{margin-top:1rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.multi-view-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-text{margin:0;font-size:1rem;color:#9ca3af}.disambiguation-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.disambiguation-modal{background:#fff;border-radius:12px;padding:1.5rem;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px #0003}.disambiguation-title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#1f2937}.disambiguation-description{margin:0 0 1.5rem;font-size:.95rem;color:#6b7280}.disambiguation-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-bottom:1.5rem}.disambiguation-image-btn{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:border-color .2s ease,transform .2s ease}.disambiguation-image-btn:hover{border-color:#3b82f6;transform:translateY(-2px)}.disambiguation-image-btn:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.disambiguation-image{width:100%;height:80px;object-fit:contain;border-radius:4px;background:#fff}.disambiguation-label{margin-top:.5rem;font-size:.75rem;color:#6b7280;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.disambiguation-cancel-btn{display:block;width:100%;padding:.75rem;background:#f3f4f6;color:#4b5563;border:1px solid #d1d5db;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s ease}.disambiguation-cancel-btn:hover{background:#e5e7eb}.multi-view-main{display:flex;flex-direction:column;gap:1.5rem}.render-action{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f0f9ff;border-radius:8px;border:1px solid #bae6fd}.render-btn--primary{background:#0284c7;padding:.875rem 2rem;font-size:1.05rem}.render-btn--primary:hover:not(:disabled){background:#0369a1}.render-hint{margin:0;font-size:.85rem;color:#64748b}.render-result{display:flex;flex-direction:column;gap:1.5rem}.render-error{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;text-align:center}.render-error .error-icon{font-size:2rem}.render-error p{margin:0;color:#991b1b}.retry-btn{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.retry-btn:hover{background:#b91c1c}.best-match-section{padding:1.5rem;background:#f0fdf4;border:1px solid #86efac;border-radius:8px}.section-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:#166534}.section-description{margin:0 0 1rem;font-size:.9rem;color:#4b5563}.preview-image-container{display:flex;justify-content:center;padding:1rem;background:#fff;border-radius:8px;margin-bottom:1rem}.preview-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.result-actions{display:flex;gap:.75rem;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn--primary{background:#16a34a;color:#fff}.action-btn--primary:hover{background:#15803d}.action-btn--secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.action-btn--secondary:hover{background:#e5e7eb}.accordion-section{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.accordion-header{display:flex;align-items:center;gap:.75rem;width:100%;padding:1rem 1.25rem;background:#f9fafb;border:none;font-size:.95rem;font-weight:500;color:#374151;cursor:pointer;transition:background-color .2s;text-align:left}.accordion-header:hover{background:#f3f4f6}.accordion-header.expanded{border-bottom:1px solid #e5e7eb}.accordion-icon{font-size:.75rem;color:#6b7280}.accordion-title{flex:1}.accordion-content{padding:1rem 1.25rem;background:#fff}.accordion-description{margin:0 0 1rem;font-size:.9rem;color:#6b7280}.original-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.original-image-btn{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.original-image-btn:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.original-image-btn img{width:100%;height:70px;object-fit:contain;border-radius:4px;background:#fff}.original-image-label{margin-top:.5rem;font-size:.75rem;color:#6b7280;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.ai-section{border-color:#a5b4fc;background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.ai-generation-header-section{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff)}.ai-header-content{display:flex;align-items:center;gap:.75rem}.ai-icon{font-size:1.5rem}.ai-header-text{display:flex;flex-direction:column;gap:.125rem}.ai-title{font-size:1rem;font-weight:600;color:#3730a3}.ai-subtitle{font-size:.8rem;color:#6366f1}.ai-badge{padding:.25rem .5rem;background:#fbbf24;color:#78350f;font-size:.7rem;font-weight:600;border-radius:4px;text-transform:uppercase}.ai-badge--unavailable{background:#e5e7eb;color:#6b7280}.ai-generation-content{padding:1.25rem;background:#fff;border-top:1px solid #c7d2fe}.ai-description{margin:0 0 1rem;font-size:.9rem;color:#4b5563;line-height:1.5}.ai-generate-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #6366f14d}.ai-generate-btn:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#4338ca);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.ai-generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.ai-note{margin:.75rem 0 0;font-size:.8rem;color:#9ca3af;text-align:center}.ai-unavailable-message{margin:0;padding:1rem 1.25rem;font-size:.85rem;color:#6b7280;background:#f9fafb;border-top:1px solid #e5e7eb}.ai-generating{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;text-align:center}.ai-spinner{width:48px;height:48px;border:4px solid #e0e7ff;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.ai-generating-text{margin:0;font-size:1rem;font-weight:500;color:#3730a3}.ai-generating-subtext{margin:.5rem 0 0;font-size:.85rem;color:#6b7280}.ai-error{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;text-align:center}.ai-error .error-icon{font-size:2rem}.ai-error p{margin:0;color:#991b1b}.ai-result{display:flex;flex-direction:column;gap:1rem}.ai-result-title{margin:0;font-size:1rem;font-weight:600;color:#3730a3}.ai-result-image-container{display:flex;justify-content:center;padding:1rem;background:#f8fafc;border:2px solid #c7d2fe;border-radius:8px}.ai-result-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.ai-result-actions{display:flex;gap:.75rem;flex-wrap:wrap}@media(max-width:640px){.multi-view-renderer{padding:1rem}.multi-view-options{grid-template-columns:1fr}.disambiguation-grid{grid-template-columns:repeat(2,1fr)}.result-actions{flex-direction:column}.action-btn{width:100%;justify-content:center}.original-images-grid{grid-template-columns:repeat(2,1fr)}}.categorized-image-view{width:100%;display:flex;flex-direction:column;gap:1.5rem}.no-images-message{padding:2rem;text-align:center;color:#000;background:#fff;border:1px solid #000000;border-radius:8px;font-style:italic}.selection-summary-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border:1px solid #000000;border-radius:8px}.summary-text{font-weight:600;color:#000}.summary-breakdown{font-size:.85rem;color:#000}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.section-title{margin:0;font-size:1.1rem;font-weight:700;color:#000}.section-controls{display:flex;align-items:center;gap:1rem}.image-count{font-size:.85rem;color:#000;padding:.25rem .5rem;background:#fff;border:1px solid #000000;border-radius:4px;font-weight:500}.select-all-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#000;cursor:pointer}.select-all-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.uncategorized-section{padding:1rem;background:#fff;border:1px solid #000000;border-radius:8px}.uncategorized-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.uncategorized-image-item{position:relative;background:#fff;border:1px solid #000000;border-radius:8px;overflow:hidden;transition:transform .2s}.uncategorized-image-item:hover{transform:translateY(-2px)}.image-checkbox{position:absolute;top:.5rem;left:.5rem;z-index:2}.image-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.image-thumbnail{aspect-ratio:1;overflow:hidden;background:#f5f5f5}.image-thumbnail img{width:100%;height:100%;object-fit:cover}.image-info{padding:.5rem;display:flex;flex-direction:column;gap:.25rem;border-top:1px solid #000000}.view-label{font-size:.85rem;font-weight:500;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.confidence-badge{font-size:.7rem;padding:.15rem .4rem;border-radius:4px;width:fit-content;background:#fff;color:#000;border:1px solid #000000}.manual-categorize{padding:.5rem;border-top:1px solid #000000}.manual-categorize select{width:100%;padding:.4rem;font-size:.8rem;background:#fff;border:1px solid #000000;border-radius:4px;color:#000;cursor:pointer}.manual-categorize select:focus{outline:none}.product-assignment{display:flex;gap:.25rem;align-items:stretch}.product-assignment select{flex:1;padding:.4rem;font-size:.8rem;background:#fff;border:1px solid #000000;border-radius:4px 0 0 4px;color:#000;cursor:pointer}.product-assignment select:focus{outline:none}.cancel-assignment-btn{padding:.4rem .6rem;font-size:.8rem;background:#fff;border:1px solid #000000;border-left:none;border-radius:0 4px 4px 0;color:#000;cursor:pointer;transition:background .2s}.cancel-assignment-btn:hover{background:#f0f0f0}.section-description{margin:0 0 1rem;font-size:.85rem;color:#000;font-style:italic}.section-icon{margin-right:.5rem}@media(max-width:768px){.section-header{flex-direction:column;align-items:flex-start}.section-controls{width:100%;justify-content:space-between}.uncategorized-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.multi-view-section{padding:1rem;background:#fff;border:2px solid #000000;border-radius:8px;margin-bottom:.5rem}.multi-view-validation-warning{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff9e6;border:1px solid #000000;border-radius:8px;margin-bottom:1rem}.multi-view-validation-warning .warning-icon{font-size:1.25rem;flex-shrink:0}.multi-view-validation-warning .warning-text{font-size:.9rem;color:#000;line-height:1.4}.multi-product-composition-prompt{padding:1.5rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #000000;border-radius:12px;margin-bottom:1rem}.composition-prompt-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.composition-prompt-header .prompt-icon{font-size:1.5rem}.composition-prompt-header h4{margin:0;font-size:1.1rem;font-weight:700;color:#000}.prompt-description{margin:0 0 1rem;font-size:.95rem;color:#333;line-height:1.5}.composition-link-btn{display:inline-block;padding:.75rem 1.5rem;background:#000;color:#fff;text-decoration:none;font-weight:600;font-size:.95rem;border-radius:8px;transition:all .2s ease}.composition-link-btn:hover{background:#333;transform:translateY(-1px)}.prompt-hint{margin:1rem 0 0;font-size:.85rem;color:#666;font-style:italic}.multi-product-composition-inline{padding:1.5rem;background:#fff;border:2px solid #000000;border-radius:12px;margin-bottom:1rem}.composition-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0}.composition-header-content{display:flex;align-items:flex-start;gap:1rem}.composition-icon{font-size:2rem;line-height:1}.composition-header h3{margin:0 0 .25rem;font-size:1.25rem;font-weight:700;color:#000}.composition-subtitle{margin:0;font-size:.9rem;color:#666}.composition-content-inline{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1rem}.composition-products-inline{grid-column:1;grid-row:1}.composition-products-inline h4,.composition-backgrounds-inline h4{margin:0 0 .75rem;font-size:.9rem;font-weight:600;color:#333}.composition-product-list{display:flex;flex-direction:column;gap:.5rem}.composition-product-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px}.product-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#000;color:#fff;border-radius:50%;font-size:11px;font-weight:600;flex-shrink:0}.product-thumb-small{width:40px;height:40px;object-fit:contain;background:#fff;border-radius:4px;flex-shrink:0}.product-info-compact{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.product-name-compact{font-size:.85rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-dims-compact{font-size:.75rem;color:#666}.product-scale{font-size:.8rem;font-weight:600;color:#1976d2;padding:2px 6px;background:#e3f2fd;border-radius:4px;flex-shrink:0}.remove-product-btn{width:24px;height:24px;border:none;border-radius:50%;background:#ef5350;color:#fff;font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .2s}.remove-product-btn:hover{background:#d32f2f}.template-info-compact{margin-top:.75rem;padding:.5rem;background:#e8f5e9;border-radius:4px;display:flex;align-items:center;gap:.5rem}.template-label{font-size:.8rem;color:#666}.template-name-compact{font-size:.85rem;font-weight:500;color:#2e7d32}.composition-backgrounds-inline{grid-column:1;grid-row:2}.background-options-inline{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.background-option-inline{display:flex;flex-direction:column;align-items:center;padding:.5rem;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s}.background-option-inline:hover{border-color:#2196f3}.background-option-inline.selected{border-color:#000;background:#f5f5f5}.background-option-inline img{width:100%;height:40px;object-fit:cover;border-radius:4px;margin-bottom:4px}.background-option-inline span{font-size:.7rem;color:#666;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.clear-background-btn{margin-top:.5rem;padding:.4rem .75rem;border:1px solid #e0e0e0;border-radius:4px;background:#fff;color:#666;font-size:.75rem;cursor:pointer;transition:all .2s}.clear-background-btn:hover{background:#f5f5f5;border-color:#ccc}.loading-text{font-size:.85rem;color:#666;font-style:italic}.composition-preview-inline{grid-column:2;grid-row:1 / 3;display:flex;justify-content:center;align-items:flex-start}.composition-status-inline{margin-top:1rem;padding-top:.75rem;border-top:1px solid #e0e0e0}.composition-status-inline p{margin:0;font-size:.9rem}.status-warning{color:#f57c00}.status-info{color:#1976d2}.status-ready{color:#2e7d32;font-weight:500}@media(max-width:900px){.composition-content-inline{grid-template-columns:1fr}.composition-preview-inline{grid-column:1;grid-row:3}.background-options-inline{grid-template-columns:repeat(4,1fr)}}.composition-processing-checklist{grid-column:1 / -1;padding:1rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:1rem}.composition-processing-checklist h4{margin:0 0 1rem;font-size:.9rem;font-weight:600;color:#333}.processing-product{margin-bottom:1rem;padding:.75rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px}.processing-product:last-child{margin-bottom:0}.processing-product-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #f0f0f0}.processing-product-number{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#000;color:#fff;border-radius:50%;font-size:10px;font-weight:600}.processing-product-name{font-size:.85rem;font-weight:500;color:#333}.processing-steps{display:flex;flex-wrap:wrap;gap:.5rem}.processing-step{display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;background:#f5f5f5;color:#666}.processing-step-pending{background:#f5f5f5;color:#999}.processing-step-processing{background:#fff3e0;color:#e65100}.processing-step-processing .step-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-step-complete{background:#e8f5e9;color:#2e7d32}.processing-step-error{background:#ffebee;color:#c62828}.step-icon{font-weight:700}.step-label{white-space:nowrap}.generate-composition-btn{display:block;width:100%;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #1976d24d}.generate-composition-btn:hover:not(:disabled){background:linear-gradient(135deg,#1565c0,#0d47a1);box-shadow:0 4px 12px #1976d266;transform:translateY(-1px)}.generate-composition-btn:disabled{background:#bdbdbd;cursor:not-allowed;box-shadow:none}.generated-preview{display:flex;flex-direction:column;align-items:center;gap:1rem}.generated-preview h4{margin:0;font-size:.9rem;font-weight:600;color:#2e7d32}.generated-preview-image{max-width:100%;border-radius:8px;box-shadow:0 4px 12px #00000026}.regenerate-btn{padding:.5rem 1rem;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.regenerate-btn:hover:not(:disabled){background:#f5f5f5;border-color:#ccc}.regenerate-btn:disabled{opacity:.5;cursor:not-allowed}.generation-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ffebee;border:1px solid #ef9a9a;border-radius:6px;margin-top:1rem}.generation-error .error-icon{font-size:1.2rem}.generation-error span{flex:1;font-size:.85rem;color:#c62828}.generation-error button{padding:.4rem .75rem;background:#c62828;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s}.generation-error button:hover{background:#b71c1c}.selection-summary{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#fff;border:1px solid #000000;border-radius:10px;gap:1rem;flex-wrap:wrap}.selection-summary-content{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.selection-total{display:flex;align-items:baseline;gap:.5rem}.total-count{font-size:1.75rem;font-weight:700;color:#000}.total-label{font-size:.95rem;color:#000}.selection-breakdown{display:flex;gap:1rem;padding-left:1rem;border-left:1px solid #000000}.category-count{display:flex;flex-direction:column;align-items:center;padding:.4rem .75rem;border-radius:6px;min-width:60px;background:#fff;border:1px solid #000000}.count-value{font-size:1.1rem;font-weight:700;color:#000}.count-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:#000}.selection-actions{display:flex;gap:.75rem}.clear-button,.proceed-button{padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease}.clear-button{background:#fff;border:1px solid #000000;color:#000}.clear-button:hover:not(:disabled){background:#f0f0f0}.clear-button:disabled{opacity:.4;cursor:not-allowed}.proceed-button{background:#fff;border:2px solid #000000;color:#000}.proceed-button:hover:not(:disabled){background:#f0f0f0}.proceed-button:disabled{opacity:.4;cursor:not-allowed}.selection-actions .auto-process-button{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;background:#000;color:#fff;border:2px solid #000000;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.selection-actions .auto-process-button:hover{background:#333}@media(max-width:640px){.selection-summary{flex-direction:column;align-items:stretch}.selection-summary-content{justify-content:center}.selection-breakdown{padding-left:0;border-left:none;padding-top:.75rem;border-top:1px solid #000000;justify-content:center}.selection-actions{justify-content:center;padding-top:.75rem;border-top:1px solid #000000}}.render-preview{padding:1.5rem;background:#f8f9fa;border-radius:8px;min-height:300px;display:flex;flex-direction:column}.render-preview--loading{justify-content:center;align-items:center}.render-loading-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.render-spinner{width:48px;height:48px;border:4px solid #e9ecef;border-top-color:#007bff;border-radius:50%;animation:render-spin 1s linear infinite}@keyframes render-spin{to{transform:rotate(360deg)}}.render-loading-text{margin:0;font-size:1.1rem;font-weight:500;color:#333}.render-loading-subtext{margin:0;font-size:.9rem;color:#666}.render-preview--error{justify-content:center;align-items:center}.render-error-container{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.render-error-icon{font-size:2.5rem}.render-error-text{margin:0;font-size:1.1rem;font-weight:500;color:#dc3545}.render-error-message{margin:0;font-size:.9rem;color:#666;max-width:300px}.render-preview--completed{gap:1rem}.render-preview-title{margin:0;font-size:1.1rem;font-weight:600;color:#333}.render-preview-description{margin:0;font-size:.9rem;color:#666}.render-image-container{flex:1;display:flex;justify-content:center;align-items:center;background:#fff;border-radius:8px;padding:1rem;min-height:200px;border:1px solid #e9ecef}.render-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.render-image-error{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#666}.render-image-error-icon{font-size:2rem;opacity:.5}.render-actions{display:flex;gap:1rem;justify-content:center;margin-top:.5rem}.render-action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.render-action-btn:focus{outline:none;box-shadow:0 0 0 3px #007bff40}.render-action-btn--primary{background:#28a745;color:#fff}.render-action-btn--primary:hover:not(:disabled){background:#218838;transform:translateY(-1px)}.render-action-btn--primary:disabled{background:#94d3a2;cursor:not-allowed}.render-action-btn--secondary{background:#6c757d;color:#fff}.render-action-btn--secondary:hover{background:#5a6268;transform:translateY(-1px)}.render-action-icon{font-size:1rem}.render-preview--idle{justify-content:center;align-items:center}.render-idle-container{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.render-idle-icon{font-size:3rem;opacity:.6}.render-idle-text{margin:0;font-size:.95rem;color:#666;max-width:280px}@media(max-width:600px){.render-preview{padding:1rem;min-height:250px}.render-actions{flex-direction:column}.render-action-btn{width:100%;justify-content:center}.render-image{max-height:300px}}.match-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500}.match-indicator--good{background:#d4edda;color:#155724}.match-indicator--partial{background:#fff3cd;color:#856404}.match-indicator-icon{font-size:1rem}.render-action-btn--ai{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.render-action-btn--ai:hover{background:linear-gradient(135deg,#5a6fd6,#6a4190);transform:translateY(-1px)}.search-result-card{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .2s,box-shadow .2s}.search-result-card:hover{border-color:#ccc;box-shadow:0 2px 8px #00000014}.search-result-card-info{display:flex;align-items:center;gap:1rem}.search-result-card-thumbnail{flex-shrink:0;width:60px;height:60px;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden;background-color:#f5f5f5}.search-result-card-thumbnail img{width:100%;height:100%;object-fit:contain}.search-result-card-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.625rem;color:#999;text-transform:uppercase}.search-result-card-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.search-result-card-name{font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-card-model{font-size:.875rem;color:#333}.search-result-card-url{font-size:.75rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-card-actions{display:flex;gap:.75rem;padding-top:.5rem;border-top:1px solid #f0f0f0}.search-result-card-button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s}.scrape-button{color:#000;background-color:#fff;border:2px solid #000000}.scrape-button:hover:not(:disabled){background-color:#f0f0f0}.scrape-button:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.auto-generate-button{color:#fff;background-color:#000;border:2px solid #000000}.auto-generate-button:hover:not(:disabled){background-color:#333}.auto-generate-button:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.search-result-card-button:disabled{opacity:.5;cursor:not-allowed}.scrape-button:disabled{background-color:#f5f5f5;border-color:#ccc;color:#999}.auto-generate-button:disabled{background-color:#999;border-color:#999}.search-result-card-button.loading{opacity:.8}.button-spinner{width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:button-spin .8s linear infinite}@keyframes button-spin{to{transform:rotate(360deg)}}@media(max-width:600px){.search-result-card{padding:.75rem}.search-result-card-info{gap:.75rem}.search-result-card-thumbnail{width:50px;height:50px}.search-result-card-name{font-size:.875rem}.search-result-card-model{font-size:.75rem}.search-result-card-url{display:none}.search-result-card-actions{flex-direction:column;gap:.5rem}.search-result-card-button{padding:.5rem .75rem;font-size:.8125rem}}.search-results-container{width:100%;margin-top:1rem}.search-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#666}.search-spinner{width:20px;height:20px;border:2px solid #cccccc;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.search-error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;text-align:center}.search-error-message{color:#000;font-weight:500}.search-retry-button{padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#000;background-color:#fff;border:2px solid #000000;border-radius:6px;cursor:pointer;transition:background-color .2s}.search-retry-button:hover{background-color:#f0f0f0}.search-hint{padding:2rem;text-align:center;color:#666;font-style:italic}.search-empty{padding:2rem;text-align:center}.search-empty p:first-child{font-weight:500;color:#000}.search-empty-hint{margin-top:.5rem;color:#666;font-size:.875rem}.search-results-count{font-size:.875rem;color:#666;margin-bottom:.75rem}.search-results-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem;max-height:500px;overflow-y:auto}.search-results-list li{margin:0;padding:0}@media(max-width:600px){.search-results-list{max-height:400px}}.product-input-container{width:100%;max-width:800px}.product-input-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:2px solid #e0e0e0}.product-input-tab{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:600;color:#666;background-color:transparent;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .2s,border-color .2s}.product-input-tab:hover:not(:disabled){color:#000}.product-input-tab.active{color:#000;border-bottom-color:#000}.product-input-tab:disabled{opacity:.6;cursor:not-allowed}.product-input-tab:focus{outline:none}.product-input-tab:focus-visible{outline:2px solid #000000;outline-offset:-2px}.product-input-panels{min-height:200px}.search-panel-content,.search-input-container{display:flex;flex-direction:column;gap:.5rem}.search-input-label{font-size:.875rem;font-weight:600;color:#000}.search-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid #000000;border-radius:8px;background-color:#fff;color:#000;transition:border-color .2s}.search-input::placeholder{color:#666;font-style:italic}.search-input:focus{outline:none;box-shadow:0 0 0 1px #000}.search-input:disabled{opacity:.6;cursor:not-allowed}@media(max-width:600px){.product-input-tab{padding:.5rem .75rem;font-size:.8125rem}}.api-documentation{width:100%}.api-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.group-toggle{display:flex;align-items:center;gap:.5rem}.toggle-label{color:#000;font-size:.85rem}.toggle-btn{background:#fff;border:2px solid #000000;color:#000;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s}.toggle-btn:hover{background:#f0f0f0}.toggle-btn.active{background:#000;color:#fff}.expand-controls{display:flex;gap:.5rem}.control-btn{background:#fff;border:1px solid #000000;color:#000;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s}.control-btn:hover{background:#f0f0f0}.api-summary{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:#fff;border:1px solid #000000;border-radius:6px}.summary-item{color:#000;font-size:.85rem}.summary-item strong{color:#000}.endpoint-groups{display:flex;flex-direction:column;gap:2rem}.endpoint-group{background:#fff;border:1px solid #000000;border-radius:8px;padding:1.25rem}.group-title{color:#000;font-size:1rem;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid #000000}.endpoint-list{display:flex;flex-direction:column;gap:.75rem}.endpoint-item{background:#fff;border:1px solid #000000;border-radius:6px;overflow:hidden}.endpoint-item.expanded{border-width:2px}.endpoint-header{padding:1rem;cursor:pointer;-webkit-user-select:none;user-select:none}.endpoint-header:focus{outline:2px solid #000000;outline-offset:-2px}.endpoint-summary{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.method{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:3px;text-transform:uppercase;flex-shrink:0;border:1px solid #000000;background:#fff;color:#000}.method-get{background:#fff}.method-post{background:#f0f0f0}.method-put{background:#fff}.method-delete{background:#f0f0f0}.endpoint-path{font-size:.85rem;color:#000;flex-grow:1}.expand-icon{color:#000;font-size:.7rem;flex-shrink:0}.endpoint-description{margin:0;font-size:.85rem;color:#000;line-height:1.4}.endpoint-phase{display:inline-block;margin-top:.5rem;font-size:.75rem;color:#000;background:#f0f0f0;padding:.15rem .5rem;border-radius:3px;border:1px solid #000000}.endpoint-details{padding:1rem;border-top:1px solid #000000;background:#fff}.details-section{margin-bottom:1.25rem}.details-section h4{margin:0 0 .75rem;font-size:.85rem;color:#000;font-weight:500}.params-table{width:100%;border-collapse:collapse;font-size:.8rem}.params-table th{text-align:left;padding:.5rem;color:#000;font-weight:500;border-bottom:1px solid #000000}.params-table td{padding:.5rem;border-bottom:1px solid #e0e0e0;vertical-align:top}.param-row:last-child td{border-bottom:none}.param-name code{background:#f0f0f0;padding:.15rem .4rem;border-radius:3px;color:#000;font-size:.8rem;border:1px solid #000000}.required-badge{display:inline-block;margin-left:.5rem;font-size:.65rem;color:#000;background:#f0f0f0;padding:.1rem .35rem;border-radius:2px;text-transform:uppercase;font-weight:500;border:1px solid #000000}.param-location{color:#000}.param-type{color:#000;font-family:monospace}.param-description{color:#000;line-height:1.4}.no-params{color:#000;font-style:italic;font-size:.85rem;margin:0}.schema-section{margin-bottom:1.25rem}.schema-section h5{margin:0 0 .5rem;font-size:.8rem;color:#000;font-weight:500}.schema-code{background:#f0f0f0;border:1px solid #000000;border-radius:4px;padding:.75rem;margin:0;font-size:.75rem;color:#000;overflow-x:auto;max-height:200px;overflow-y:auto}.service-deps{margin-top:1rem}.service-deps h5{margin:0 0 .5rem;font-size:.8rem;color:#000;font-weight:500}.service-tags{display:flex;flex-wrap:wrap;gap:.5rem}.service-tag{background:#f0f0f0;color:#000;padding:.25rem .6rem;border-radius:4px;font-size:.75rem;font-family:monospace;border:1px solid #000000}.no-data{color:#000;font-style:italic;padding:2rem;text-align:center}@media(max-width:768px){.api-controls{flex-direction:column;align-items:flex-start}.params-table{display:block;overflow-x:auto}.endpoint-summary{flex-wrap:wrap}.endpoint-path{order:3;width:100%;margin-top:.5rem}}.cpv-container{width:100%}.cpv-header{margin-bottom:1.5rem}.cpv-title{margin:0 0 .5rem;font-size:1.1rem;color:#000;font-weight:600}.cpv-description{margin:0;font-size:.9rem;color:#000;line-height:1.4}.cpv-stats{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:#fff;border:1px solid #000000;border-radius:6px}.cpv-stat{font-size:.85rem;color:#000}.cpv-stat strong{color:#000;margin-right:.25rem}.cpv-steps-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.cpv-step{display:flex;gap:1rem;position:relative}.cpv-step-connector{display:flex;flex-direction:column;align-items:center;width:40px;flex-shrink:0}.cpv-step-line{width:2px;height:20px;background:#000}.cpv-step-line.first{background:transparent}.cpv-step-number{width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid #000000;color:#000;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0;z-index:1}.cpv-step-line-after{width:2px;flex-grow:1;min-height:20px;background:#000}.cpv-step:last-child .cpv-step-line-after{background:transparent}.cpv-step-content{flex-grow:1;background:#fff;border:1px solid #000000;border-radius:8px;padding:1rem;margin-bottom:1rem}.cpv-step.required .cpv-step-content{border-left:3px solid #000000}.cpv-step.optional .cpv-step-content{border-left:3px solid #888888}.cpv-step-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.cpv-method{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:3px;text-transform:uppercase;flex-shrink:0;background:#fff;border:1px solid #000000;color:#000}.cpv-endpoint{font-size:.85rem;color:#000;background:#f0f0f0;padding:.25rem .5rem;border-radius:4px;border:1px solid #000000}.cpv-status-badge{font-size:.7rem;font-weight:500;padding:.15rem .5rem;border-radius:3px;text-transform:uppercase;border:1px solid #000000;background:#fff;color:#000}.cpv-step-description{margin:0 0 .75rem;font-size:.85rem;color:#000;line-height:1.5}.cpv-dependencies{margin-bottom:.75rem;padding:.5rem .75rem;background:#f0f0f0;border-radius:4px;border-left:2px solid #000000}.cpv-dep-label{font-size:.75rem;color:#000;font-weight:500;display:block;margin-bottom:.35rem}.cpv-dep-list{display:flex;flex-direction:column;gap:.35rem}.cpv-dep-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.cpv-dep-step{color:#000;font-weight:500}.cpv-dep-endpoint{color:#000;font-size:.75rem;background:#fff;padding:.1rem .35rem;border-radius:3px;border:1px solid #000000}.cpv-dataflow{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.cpv-dataflow-section{display:flex;align-items:flex-start;gap:.5rem}.cpv-dataflow-label{font-size:.75rem;color:#000;font-weight:500;min-width:50px}.cpv-dataflow-items{display:flex;flex-wrap:wrap;gap:.35rem}.cpv-dataflow-item{font-size:.75rem;background:#f0f0f0;padding:.15rem .4rem;border-radius:3px;color:#000;border:1px solid #000000}.cpv-flows-to{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.cpv-flows-label{font-size:.75rem;color:#000}.cpv-flows-item{font-size:.75rem;color:#000;background:#f0f0f0;padding:.15rem .4rem;border-radius:3px;border:1px solid #000000}.cpv-legend{margin-top:1.5rem;padding:1rem;background:#fff;border:1px solid #000000;border-radius:6px;display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.cpv-legend-title{font-size:.8rem;color:#000;font-weight:500}.cpv-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#000}.cpv-empty{text-align:center;padding:3rem 2rem;background:#fff;border-radius:8px;border:1px dashed #000000}.cpv-empty p{margin:0 0 .5rem;color:#000}.cpv-empty strong{color:#000}.cpv-empty-hint{font-size:.85rem;color:#000;font-style:italic}.cpv-graph{margin-bottom:1.5rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #000000}.cpv-graph-title{margin:0 0 1rem;font-size:.9rem;color:#000;font-weight:500}.cpv-graph-empty{margin:0;font-size:.85rem;color:#000;font-style:italic}.cpv-graph-content{display:flex;flex-direction:column;gap:1rem}.cpv-graph-nodes{display:flex;flex-wrap:wrap;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid #000000}.cpv-graph-node{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#fff;border-radius:20px;border:1px solid #000000}.cpv-graph-node-num{width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid #000000;color:#000;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600}.cpv-graph-node-method{font-size:.7rem;color:#000;text-transform:uppercase}.cpv-graph-edges{display:flex;flex-direction:column;gap:.5rem}.cpv-graph-edge{display:flex;align-items:center;gap:.5rem;font-size:.8rem;padding:.35rem .75rem;background:#f0f0f0;border-radius:4px;border-left:2px solid #000000}.cpv-graph-edge-from,.cpv-graph-edge-to{color:#000;font-weight:500}.cpv-graph-edge-arrow{color:#000;font-weight:700}.cpv-graph-edge-data{color:#000;font-size:.75rem;font-style:italic}@media(max-width:768px){.cpv-step{flex-direction:column}.cpv-step-connector{flex-direction:row;width:100%;margin-bottom:.5rem}.cpv-step-line,.cpv-step-line-after{height:2px;width:20px}.cpv-step-header{flex-direction:column;align-items:flex-start}.cpv-stats{flex-direction:column;gap:.5rem}.cpv-legend{flex-direction:column;align-items:flex-start}.cpv-graph-nodes{justify-content:center}.cpv-graph-edge{flex-wrap:wrap}}.sdv-container{width:100%}.sdv-endpoint-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #000000}.sdv-method{font-size:.7rem;font-weight:600;padding:.25rem .6rem;border-radius:4px;text-transform:uppercase;flex-shrink:0;background:#fff;border:1px solid #000000;color:#000}.sdv-endpoint-path{font-size:.9rem;color:#000;background:#f0f0f0;padding:.25rem .6rem;border-radius:4px;border:1px solid #000000}.sdv-summary{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:#fff;border:1px solid #000000;border-radius:6px}.sdv-summary-item{font-size:.85rem;color:#000}.sdv-summary-item strong{color:#000;margin-right:.25rem}.sdv-service-group{margin-bottom:1.5rem}.sdv-service-group:last-child{margin-bottom:0}.sdv-group-title{display:flex;align-items:center;gap:.5rem;margin:0 0 .5rem;font-size:1rem;color:#000;font-weight:600}.sdv-group-icon{font-size:1rem}.sdv-group-description{margin:0 0 1rem;font-size:.85rem;color:#000;font-style:italic}.sdv-service-list{display:flex;flex-direction:column;gap:.75rem}.sdv-service-card{background:#fff;border:1px solid #000000;border-radius:8px;padding:1rem}.sdv-service-card.external{border-width:2px}.sdv-service-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.sdv-service-name{font-weight:600;color:#000;font-size:.95rem;font-family:monospace}.sdv-service-type{font-size:.7rem;font-weight:500;padding:.2rem .6rem;border-radius:4px;text-transform:uppercase;background:#fff;border:1px solid #000000;color:#000}.sdv-service-responsibility{margin:0 0 .75rem;font-size:.85rem;color:#000;line-height:1.5}.sdv-env-vars{margin-bottom:.75rem;padding:.75rem;background:#f0f0f0;border:1px solid #000000;border-radius:6px}.sdv-env-label{display:block;font-size:.75rem;color:#000;font-weight:500;margin-bottom:.5rem}.sdv-env-list{display:flex;flex-wrap:wrap;gap:.5rem}.sdv-env-var{background:#fff;color:#000;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-family:monospace;border:1px solid #000000}.sdv-file-path{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sdv-path-label{font-size:.75rem;color:#000}.sdv-path-value{font-size:.75rem;color:#000;background:#f0f0f0;padding:.2rem .5rem;border-radius:3px;word-break:break-all;border:1px solid #000000}.sdv-empty{text-align:center;padding:3rem 2rem;background:#fff;border-radius:8px;border:1px dashed #000000}.sdv-empty-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.6}.sdv-empty p{margin:0 0 .5rem;color:#000;font-size:.95rem}.sdv-empty-hint{font-size:.85rem;color:#000;font-style:italic}.sdv-no-deps{padding:2rem;background:#fff;border:1px solid #000000;border-radius:8px;text-align:center}.sdv-no-deps p{margin:0;color:#000;font-size:.9rem}@media(max-width:768px){.sdv-endpoint-header{flex-direction:column;align-items:flex-start}.sdv-summary{flex-direction:column;gap:.5rem}.sdv-service-header{flex-direction:column;align-items:flex-start}.sdv-env-vars{padding:.5rem}.sdv-file-path{flex-direction:column;align-items:flex-start}}.sdv-integration{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:6px;padding:.75rem;margin-bottom:.75rem}.sdv-integration-row{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.4rem}.sdv-integration-row:last-child{margin-bottom:0}.sdv-integration-label{font-size:.75rem;color:#666;min-width:60px}.sdv-integration-value{font-size:.8rem;color:#000}.sdv-provider{font-weight:600}.sdv-model{font-style:italic}.sdv-model-id{background:#fff;padding:.15rem .4rem;border-radius:3px;font-size:.7rem;border:1px solid #ccc;word-break:break-all}.sdv-integration-notes{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #ddd}.sdv-notes-icon{flex-shrink:0}.sdv-notes-text{font-size:.75rem;color:#444;line-height:1.4}.sdv-integration-links{display:flex;gap:.75rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #ddd}.sdv-integration-link{font-size:.75rem;color:#000;text-decoration:none;padding:.25rem .5rem;border:1px solid #000;border-radius:4px;transition:background .2s}.sdv-integration-link:hover{background:#e8e8e8}.admin-panel{min-height:100vh;background:#fff;color:#000}.admin-header{border-bottom:1px solid #000000;padding:1rem 2rem}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.admin-header h1{margin:0;font-size:1.5rem;font-weight:600;color:#000}.back-link{color:#000;text-decoration:none;font-size:.9rem;padding:.5rem 1rem;border:2px solid #000000;border-radius:8px;transition:background .2s}.back-link:hover{background:#f0f0f0}.warning-banner{background:#fff;border:2px solid #000000;color:#000;padding:.5rem 1rem;border-radius:4px;margin-top:.75rem;font-size:.85rem}.admin-nav{display:flex;gap:.5rem;padding:1rem 2rem;border-bottom:1px solid #000000;max-width:1400px;margin:0 auto}.nav-item{background:#fff;border:2px solid #000000;color:#000;padding:.6rem 1.2rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .2s}.nav-item:hover{background:#f0f0f0}.nav-item.active{background:#000;color:#fff}.admin-content{max-width:1400px;margin:0 auto;padding:2rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#000}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.admin-section{background:#fff;border:1px solid #000000;border-radius:8px;padding:1.5rem}.admin-section h2{margin:0 0 .5rem;font-size:1.3rem;color:#000}.section-description{color:#000;margin:0 0 1.5rem;font-size:.9rem;font-style:italic}.no-data{color:#000;font-style:italic;padding:1rem;text-align:center}.workflow-diagram{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;padding:1rem 0}.phase-container{display:flex;align-items:center}.phase-box{background:#fff;border:2px solid #000000;border-radius:8px;padding:1rem 1.25rem;cursor:pointer;transition:background .2s;min-width:140px;text-align:center}.phase-box:hover{background:#f0f0f0}.phase-box.selected{background:#000;color:#fff}.phase-order{display:block;font-size:.75rem;color:inherit;margin-bottom:.25rem}.phase-name{font-size:.85rem;font-weight:500;color:inherit}.phase-connector{color:#000;font-size:1.2rem;padding:0 .5rem}.phase-details{margin-top:1.5rem;padding:1.25rem;background:#fff;border:1px solid #000000;border-radius:8px}.phase-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.phase-details h3{margin:0;color:#000}.view-patterns-btn{background:#fff;border:2px solid #000000;color:#000;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s}.view-patterns-btn:hover{background:#f0f0f0}.view-services-link{background:#fff;border:1px solid #000000;color:#000;padding:.2rem .5rem;border-radius:4px;cursor:pointer;font-size:.75rem;margin-left:.5rem;transition:background .2s}.view-services-link:hover{background:#f0f0f0}.phase-details p{margin:0 0 1rem;color:#000}.phase-endpoints h4,.phase-next h4{margin:0 0 .5rem;font-size:.85rem;color:#000}.phase-endpoints ul{margin:0;padding-left:1.25rem}.phase-endpoints li{margin-bottom:.25rem}.phase-endpoints code{background:#f0f0f0;padding:.15rem .4rem;border-radius:3px;font-size:.8rem;color:#000;border:1px solid #000000}.api-section-content{display:grid;grid-template-columns:1fr;gap:1.5rem}.service-dependency-panel{background:#fff;border:1px solid #000000;border-radius:8px;padding:1rem;position:sticky;top:1rem;max-height:calc(100vh - 200px);overflow-y:auto}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #000000}.panel-header h3{margin:0;font-size:1rem;color:#000}.close-panel-btn{background:transparent;border:none;color:#000;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.selected-endpoint-services{margin-bottom:2rem;padding:1.25rem;background:#fff;border:1px solid #000000;border-radius:8px}.selected-endpoint-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.selected-endpoint-header h3{margin:0;font-size:1rem;color:#000}.clear-selection-btn{background:#fff;border:1px solid #000000;color:#000;padding:.4rem .8rem;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background .2s}.clear-selection-btn:hover{background:#f0f0f0}.phase-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.phase-btn{background:#fff;border:2px solid #000000;color:#000;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.85rem;transition:background .2s}.phase-btn:hover{background:#f0f0f0}.phase-btn.active{background:#000;color:#fff}.service-group{margin-bottom:2rem}.service-group h3{color:#000;font-size:1rem;margin:0 0 .5rem}.group-description{color:#000;font-size:.85rem;margin:0 0 1rem;font-style:italic}.service-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.service-card{background:#fff;border:1px solid #000000;border-radius:8px;padding:1rem}.service-card.external{border-width:2px}.service-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.service-name{font-weight:500;color:#000;font-size:.9rem}.service-type{font-size:.7rem;padding:.15rem .5rem;border-radius:3px;text-transform:uppercase;border:1px solid #000000;color:#000}.service-responsibility{margin:0 0 .75rem;font-size:.85rem;color:#000;line-height:1.4}.service-env{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.env-label{font-size:.75rem;color:#000}.env-var{background:#f0f0f0;color:#000;padding:.15rem .4rem;border-radius:3px;font-size:.75rem;border:1px solid #000000}.service-path{display:block;font-size:.75rem;color:#000;word-break:break-all}@media(max-width:768px){.admin-header{padding:1rem}.admin-nav{padding:1rem;overflow-x:auto}.admin-content{padding:1rem}.workflow-diagram{flex-direction:column;align-items:stretch}.phase-connector{transform:rotate(90deg);padding:.25rem 0}.service-list{grid-template-columns:1fr}}.service-integration{background:#f8f8f8;border:1px solid #e0e0e0;border-radius:6px;padding:.75rem;margin-bottom:.75rem}.integration-row{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.4rem}.integration-row:last-child{margin-bottom:0}.integration-label{font-size:.75rem;color:#666;min-width:60px}.integration-value{font-size:.8rem;color:#000}.integration-value.provider{font-weight:600}.integration-value.model{font-style:italic}.integration-value.model-id{background:#fff;padding:.15rem .4rem;border-radius:3px;font-size:.7rem;border:1px solid #ccc;word-break:break-all}.integration-notes{display:flex;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #ddd}.notes-icon{flex-shrink:0}.notes-text{font-size:.75rem;color:#444;line-height:1.4}.integration-links{display:flex;gap:.75rem;margin-top:.5rem;padding-top:.5rem;border-top:1px dashed #ddd}.integration-link{font-size:.75rem;color:#000;text-decoration:none;padding:.25rem .5rem;border:1px solid #000;border-radius:4px;transition:background .2s}.integration-link:hover{background:#e8e8e8}.two-product-composer{display:grid;grid-template-columns:320px 1fr 280px;grid-template-rows:1fr auto;gap:16px;height:calc(100vh - 120px);min-height:500px;padding:16px;background:#f5f5f5}.composer-panel{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;overflow-y:auto}.composer-panel h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.composer-panel h4{margin:16px 0 8px;font-size:13px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px}.panel-hint{font-size:13px;color:#666;margin-bottom:16px}.product-selection{grid-row:1 / 3}.selected-products{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.empty-selection{font-size:13px;color:#999;font-style:italic;padding:12px;text-align:center;background:#f9f9f9;border-radius:6px}.selected-list{display:flex;flex-direction:column;gap:8px}.selected-product-card{display:flex;align-items:center;gap:10px;padding:10px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px}.product-position{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#4caf50;color:#fff;border-radius:50%;font-size:12px;font-weight:600}.selected-thumbnail{width:48px;height:48px;object-fit:contain;background:#fff;border-radius:4px}.selected-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.selected-name{font-size:13px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-sku{font-size:11px;color:#666}.selected-angle{font-size:11px;color:#2e7d32;font-style:italic}.remove-btn{width:24px;height:24px;border:none;border-radius:50%;background:#ef5350;color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.remove-btn:hover{background:#d32f2f}.composition-status{display:flex;align-items:center;gap:8px;padding:12px;border-radius:6px;font-size:13px;font-weight:500;margin-bottom:16px}.composition-status.enabled{background:#e8f5e9;color:#2e7d32}.composition-status.disabled{background:#fff3e0;color:#e65100}.status-icon{font-size:16px}.available-products{margin-top:16px}.product-grid{display:flex;flex-direction:column;gap:8px}.available-product{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;transition:all .2s}.available-product:hover{border-color:#2196f3;background:#f0f7ff}.available-product.selected{border-color:#4caf50;background:#e8f5e9}.available-product.no-dimensions{opacity:.6}.product-thumb{width:40px;height:40px;object-fit:contain;background:#fff;border-radius:4px}.product-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.product-details .product-name{font-size:12px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-details .product-sku{font-size:11px;color:#666}.dimension-warning{font-size:10px;color:#f57c00;font-style:italic}.select-btn{width:28px;height:28px;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s}.select-btn.add{background:#2196f3;color:#fff}.select-btn.add:hover:not(:disabled){background:#1976d2}.select-btn.add:disabled{background:#ccc;cursor:not-allowed}.select-btn.remove{background:#f44336;color:#fff}.select-btn.remove:hover{background:#d32f2f}.template-info{grid-column:2;grid-row:1}.template-display{padding:12px;background:#f5f5f5;border-radius:8px}.template-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px}.template-card.active{border-color:#4caf50;background:#f1f8e9}.template-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#e8f5e9;border-radius:8px;font-size:20px}.template-details{flex:1;display:flex;flex-direction:column;gap:4px}.template-name{font-size:14px;font-weight:600;color:#333}.template-desc{font-size:12px;color:#666}.template-placeholder{padding:20px;text-align:center;background:#f9f9f9;border-radius:8px;border:2px dashed #ddd}.template-placeholder p{font-size:13px;color:#666;margin-bottom:16px}.template-preview-list{display:flex;justify-content:center;gap:16px}.template-preview-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:#fff;border-radius:6px}.preview-icon{font-size:20px}.preview-name{font-size:11px;color:#666}.angle-assignments{margin-top:16px}.angle-assignment{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:4px;margin-bottom:4px}.product-label{font-size:12px;color:#666}.angle-value{font-size:12px;font-weight:500;color:#2e7d32}.scaling-info{margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0}.scale-item{display:flex;justify-content:space-between;padding:8px 12px;background:#f5f5f5;border-radius:4px;margin-bottom:4px}.scale-product{font-size:12px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.scale-value{font-size:12px;font-weight:600;color:#1976d2}.background-selection{grid-column:3;grid-row:1}.loading-backgrounds{padding:20px;text-align:center;color:#666;font-size:13px}.selected-background{display:flex;align-items:center;gap:12px;padding:12px;background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;margin-bottom:16px}.selected-bg-thumb{width:60px;height:40px;object-fit:cover;border-radius:4px}.selected-bg-info{flex:1;display:flex;flex-direction:column;gap:4px}.bg-name{font-size:13px;font-weight:500;color:#333}.clear-bg-btn{padding:4px 8px;border:none;border-radius:4px;background:#ef5350;color:#fff;font-size:11px;cursor:pointer;align-self:flex-start}.clear-bg-btn:hover{background:#d32f2f}.background-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.background-option{display:flex;flex-direction:column;align-items:center;padding:8px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s}.background-option:hover{border-color:#2196f3}.background-option.selected{border-color:#4caf50;background:#e8f5e9}.bg-thumb{width:100%;height:50px;object-fit:cover;border-radius:4px;margin-bottom:4px}.bg-label{font-size:11px;color:#666;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.actions{grid-column:2 / 4;grid-row:2;display:flex;align-items:center;gap:12px;padding:16px 20px}.preview-btn,.export-btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.preview-btn{background:#ff9800;color:#fff}.preview-btn:hover:not(:disabled){background:#f57c00}.export-btn{background:#4caf50;color:#fff}.export-btn:hover:not(:disabled){background:#43a047}.preview-btn:disabled,.export-btn:disabled{background:#ccc;cursor:not-allowed}.action-hint{font-size:13px;color:#666;margin:0 0 0 auto}@media(max-width:1100px){.two-product-composer{grid-template-columns:280px 1fr;grid-template-rows:auto auto auto}.product-selection{grid-row:1;grid-column:1}.template-info{grid-column:2;grid-row:1}.background-selection{grid-column:1 / 3;grid-row:2}.background-grid{grid-template-columns:repeat(4,1fr)}.actions{grid-column:1 / 3;grid-row:3}}@media(max-width:768px){.two-product-composer{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;height:auto;min-height:auto}.product-selection,.template-info,.background-selection,.actions{grid-column:1}.product-selection{grid-row:1}.template-info{grid-row:2}.background-selection{grid-row:3}.actions{grid-row:4;flex-direction:column}.action-hint{margin-left:0;text-align:center}}.export-progress{display:flex;align-items:center;gap:12px;flex:1;max-width:300px}.progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:4px;transition:width .3s ease}.progress-text{font-size:13px;font-weight:500;color:#4caf50;min-width:40px}.export-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffebee;border:1px solid #ef9a9a;border-radius:6px;font-size:13px;color:#c62828}.retry-btn{margin-left:auto;padding:4px 12px;border:none;border-radius:4px;background:#ef5350;color:#fff;font-size:12px;cursor:pointer;transition:background .2s}.retry-btn:hover{background:#d32f2f}.export-complete{display:flex;flex-direction:column;gap:12px;padding:16px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;flex:1}.success-message{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#2e7d32}.success-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#4caf50;color:#fff;border-radius:50%;font-size:12px}.download-buttons{display:flex;gap:8px}.download-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.download-btn.primary{background:#1976d2;color:#fff}.download-btn.primary:hover{background:#1565c0}.download-btn.secondary{background:#f5f5f5;color:#333;border:1px solid #ddd}.download-btn.secondary:hover{background:#e0e0e0}.export-details{display:flex;gap:16px;font-size:12px;color:#666}.detail-item{display:flex;align-items:center;gap:4px}@media(max-width:768px){.export-progress{max-width:100%}.export-complete{width:100%}.download-buttons{flex-direction:column}.download-btn{justify-content:center}}.dimension-info{display:flex;align-items:center;gap:4px;font-size:10px;color:#666}.dimension-info.manual{color:#1976d2}.dimension-info.scraped{color:#4caf50}.edit-dimensions-btn,.add-dimensions-btn{padding:2px 4px;border:none;background:transparent;cursor:pointer;font-size:10px;opacity:.6;transition:opacity .2s}.edit-dimensions-btn:hover,.add-dimensions-btn:hover{opacity:1}.add-dimensions-btn{color:#1976d2;font-weight:500;text-decoration:underline}.dimension-warning{display:flex;align-items:center;gap:4px;font-size:10px;color:#f57c00;font-style:italic}.dimension-entry-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dimension-entry-modal{background:#fff;border-radius:12px;padding:24px;max-width:450px;width:90%;box-shadow:0 8px 32px #0003}.dimension-entry-modal h4{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}.validation-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.validation-warning-modal{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 8px 32px #0003}.validation-warning-modal h4{margin:0 0 16px;font-size:18px;font-weight:600;color:#e65100}.warning-intro{font-size:14px;color:#666;margin-bottom:16px}.warning-list{background:#fff3e0;border:1px solid #ffcc80;border-radius:8px;padding:12px;margin-bottom:16px}.warning-item{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid #ffe0b2}.warning-item:last-child{border-bottom:none}.warning-icon{font-size:14px;flex-shrink:0}.warning-text{font-size:13px;color:#e65100;line-height:1.4}.warning-actions{display:flex;flex-direction:column;gap:12px}.fallback-note,.no-fallback-note{font-size:13px;color:#666;margin:0;padding:8px 12px;background:#f5f5f5;border-radius:6px}.fallback-note{background:#e8f5e9;color:#2e7d32}.no-fallback-note{background:#ffebee;color:#c62828}.accept-fallbacks-btn{padding:12px 24px;border:none;border-radius:6px;background:#ff9800;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.accept-fallbacks-btn:hover{background:#f57c00}.cancel-validation-btn{padding:10px 20px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#666;font-size:14px;cursor:pointer;transition:all .2s}.cancel-validation-btn:hover{background:#f5f5f5;border-color:#ccc}.angle-validation-status{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.angle-validation-status.valid{background:#e8f5e9;color:#2e7d32}.angle-validation-status.warning{background:#fff3e0;color:#e65100}.angle-validation-status.error{background:#ffebee;color:#c62828}.validation-status-icon{font-size:16px}.view-warnings-btn{margin-left:auto;padding:4px 8px;border:1px solid currentColor;border-radius:4px;background:transparent;color:inherit;font-size:11px;cursor:pointer;transition:all .2s}.view-warnings-btn:hover{background:#0000000d}.low-confidence-modal h4{color:#1565c0}.low-confidence-item{flex-direction:column;align-items:flex-start}.low-confidence-details{display:flex;flex-direction:column;gap:4px;width:100%}.low-confidence-details .product-name{font-weight:600;color:#333;font-size:14px}.low-confidence-details .angle-info{font-size:13px;color:#666}.low-confidence-details .angle-info strong{color:#1565c0}.low-confidence-details .angle-description{font-size:12px;color:#888;font-style:italic}.low-confidence-note{background:#e3f2fd;color:#1565c0}.three-product-composer{display:grid;grid-template-columns:340px 1fr 280px;grid-template-rows:1fr auto;gap:16px;height:calc(100vh - 120px);min-height:500px;padding:16px;background:#f5f5f5}.three-product-composer .composer-panel{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;overflow-y:auto}.three-product-composer .composer-panel h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.three-product-composer .composer-panel h4{margin:16px 0 8px;font-size:13px;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.5px}.three-product-composer .panel-hint{font-size:13px;color:#666;margin-bottom:16px}.three-product-composer .product-selection{grid-row:1 / 3}.three-product-composer .selected-products{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e0e0e0}.three-product-composer .empty-selection{font-size:13px;color:#999;font-style:italic;padding:12px;text-align:center;background:#f9f9f9;border-radius:6px}.three-product-composer .selected-list{display:flex;flex-direction:column;gap:10px}.three-product-composer .selected-product-card{display:flex;align-items:center;gap:10px;padding:12px;border-radius:8px;position:relative;transition:all .2s}.three-product-composer .selected-product-card.primary{background:#e8f5e9;border:1px solid #a5d6a7}.three-product-composer .selected-product-card.accent{background:#fff3e0;border:2px solid #ffb74d}.three-product-composer .product-role-badge{position:absolute;top:-8px;left:12px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.three-product-composer .product-role-badge.primary{background:#4caf50;color:#fff}.three-product-composer .product-role-badge.accent{background:#ff9800;color:#fff}.three-product-composer .selected-thumbnail{width:56px;height:56px;object-fit:contain;background:#fff;border-radius:4px;border:1px solid #e0e0e0}.three-product-composer .selected-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.three-product-composer .selected-name{font-size:13px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.three-product-composer .selected-sku{font-size:11px;color:#666}.three-product-composer .selected-dimensions{font-size:10px;color:#4caf50}.three-product-composer .selected-angle{font-size:10px;color:#1976d2;font-style:italic}.three-product-composer .product-actions{display:flex;flex-direction:column;gap:4px}.three-product-composer .set-accent-btn{width:28px;height:28px;border:none;border-radius:50%;background:#fff3e0;color:#ff9800;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.three-product-composer .set-accent-btn:hover{background:#ff9800;color:#fff;transform:scale(1.1)}.three-product-composer .clear-accent-btn{width:28px;height:28px;border:none;border-radius:50%;background:#e3f2fd;color:#1976d2;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.three-product-composer .clear-accent-btn:hover{background:#1976d2;color:#fff}.three-product-composer .remove-btn{width:28px;height:28px;border:none;border-radius:50%;background:#ffebee;color:#ef5350;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.three-product-composer .remove-btn:hover{background:#ef5350;color:#fff}.three-product-composer .composition-status{display:flex;align-items:center;gap:8px;padding:12px;border-radius:6px;font-size:13px;font-weight:500;margin-bottom:16px}.three-product-composer .composition-status.enabled{background:#e8f5e9;color:#2e7d32}.three-product-composer .composition-status.disabled{background:#fff3e0;color:#e65100}.three-product-composer .status-icon{font-size:16px}.three-product-composer .dimension-warning-banner{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff3e0;border:1px solid #ffcc80;border-radius:6px;font-size:12px;color:#e65100;margin-bottom:16px}.three-product-composer .warning-icon{font-size:16px}.three-product-composer .available-products{margin-top:16px}.three-product-composer .product-grid{display:flex;flex-direction:column;gap:8px}.three-product-composer .available-product{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid #e0e0e0;border-radius:6px;background:#fafafa;transition:all .2s}.three-product-composer .available-product:hover{border-color:#2196f3;background:#f0f7ff}.three-product-composer .available-product.selected{border-color:#4caf50;background:#e8f5e9}.three-product-composer .available-product.no-dimensions{opacity:.7}.three-product-composer .product-thumb{width:40px;height:40px;object-fit:contain;background:#fff;border-radius:4px}.three-product-composer .product-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.three-product-composer .product-details .product-name{font-size:12px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.three-product-composer .product-details .product-sku{font-size:11px;color:#666}.three-product-composer .dimension-info{display:flex;align-items:center;gap:4px;font-size:10px;color:#666}.three-product-composer .dimension-info.manual{color:#1976d2}.three-product-composer .dimension-info.scraped{color:#4caf50}.three-product-composer .edit-dimensions-btn,.three-product-composer .add-dimensions-btn{padding:2px 4px;border:none;background:transparent;cursor:pointer;font-size:10px;opacity:.6;transition:opacity .2s}.three-product-composer .edit-dimensions-btn:hover,.three-product-composer .add-dimensions-btn:hover{opacity:1}.three-product-composer .add-dimensions-btn{color:#1976d2;font-weight:500;text-decoration:underline}.three-product-composer .dimension-warning{display:flex;align-items:center;gap:4px;font-size:10px;color:#f57c00;font-style:italic}.three-product-composer .select-btn{width:28px;height:28px;border:none;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s}.three-product-composer .select-btn.add{background:#2196f3;color:#fff}.three-product-composer .select-btn.add:hover:not(:disabled){background:#1976d2}.three-product-composer .select-btn.add:disabled{background:#ccc;cursor:not-allowed}.three-product-composer .select-btn.remove{background:#f44336;color:#fff}.three-product-composer .select-btn.remove:hover{background:#d32f2f}.three-product-composer .template-info{grid-column:2;grid-row:1}.three-product-composer .template-display{padding:12px;background:#f5f5f5;border-radius:8px}.three-product-composer .template-card{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:8px}.three-product-composer .template-card.active{border-color:#ff9800;background:#fff8e1}.three-product-composer .template-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff3e0;border-radius:8px;font-size:24px}.three-product-composer .template-details{flex:1;display:flex;flex-direction:column;gap:4px}.three-product-composer .template-name{font-size:14px;font-weight:600;color:#333}.three-product-composer .template-desc{font-size:12px;color:#666}.three-product-composer .template-placeholder{padding:20px;text-align:center;background:#f9f9f9;border-radius:8px;border:2px dashed #ddd}.three-product-composer .template-placeholder p{font-size:13px;color:#666;margin-bottom:16px}.three-product-composer .template-preview-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;background:#fff;border-radius:6px}.three-product-composer .preview-icon{font-size:28px}.three-product-composer .preview-name{font-size:13px;font-weight:500;color:#333}.three-product-composer .preview-desc{font-size:11px;color:#666}.three-product-composer .role-assignments{margin-top:16px}.three-product-composer .role-assignment{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:4px;margin-bottom:4px}.three-product-composer .role-assignment.accent{background:#fff3e0}.three-product-composer .product-label{font-size:12px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.three-product-composer .role-value{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.three-product-composer .role-value.primary{background:#e8f5e9;color:#2e7d32}.three-product-composer .role-value.accent{background:#fff3e0;color:#e65100}.three-product-composer .manual-accent-indicator{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#e3f2fd;border-radius:4px;font-size:11px;color:#1565c0;margin-top:8px}.three-product-composer .indicator-icon{font-size:14px}.three-product-composer .angle-assignments{margin-top:16px}.three-product-composer .angle-assignment{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:4px;margin-bottom:4px}.three-product-composer .angle-value{font-size:12px;font-weight:500;color:#1976d2}.three-product-composer .scaling-info{margin-top:20px;padding-top:16px;border-top:1px solid #e0e0e0}.three-product-composer .scale-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f5f5f5;border-radius:4px;margin-bottom:4px}.three-product-composer .scale-item.accent{background:#fff3e0}.three-product-composer .scale-product{font-size:12px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.three-product-composer .scale-value{font-size:12px;font-weight:600;color:#1976d2}.three-product-composer .depth-boost-indicator{font-size:10px;font-weight:400;color:#ff9800}.three-product-composer .background-selection{grid-column:3;grid-row:1}.three-product-composer .loading-backgrounds{padding:20px;text-align:center;color:#666;font-size:13px}.three-product-composer .selected-background{display:flex;align-items:center;gap:12px;padding:12px;background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;margin-bottom:16px}.three-product-composer .selected-bg-thumb{width:60px;height:40px;object-fit:cover;border-radius:4px}.three-product-composer .selected-bg-info{flex:1;display:flex;flex-direction:column;gap:4px}.three-product-composer .bg-name{font-size:13px;font-weight:500;color:#333}.three-product-composer .clear-bg-btn{padding:4px 8px;border:none;border-radius:4px;background:#ef5350;color:#fff;font-size:11px;cursor:pointer;align-self:flex-start}.three-product-composer .clear-bg-btn:hover{background:#d32f2f}.three-product-composer .background-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.three-product-composer .background-option{display:flex;flex-direction:column;align-items:center;padding:8px;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s}.three-product-composer .background-option:hover{border-color:#2196f3}.three-product-composer .background-option.selected{border-color:#4caf50;background:#e8f5e9}.three-product-composer .bg-thumb{width:100%;height:50px;object-fit:cover;border-radius:4px;margin-bottom:4px}.three-product-composer .bg-label{font-size:11px;color:#666;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.three-product-composer .actions{grid-column:2 / 4;grid-row:2;display:flex;align-items:center;gap:12px;padding:16px 20px;flex-wrap:wrap}.three-product-composer .start-processing-btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background:#ff9800;color:#fff}.three-product-composer .start-processing-btn:hover:not(:disabled){background:#f57c00}.three-product-composer .start-processing-btn:disabled{background:#ccc;cursor:not-allowed}.three-product-composer .preview-btn,.three-product-composer .export-btn{padding:12px 24px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.three-product-composer .preview-btn{background:#2196f3;color:#fff}.three-product-composer .preview-btn:hover:not(:disabled){background:#1976d2}.three-product-composer .export-btn{background:#4caf50;color:#fff}.three-product-composer .export-btn:hover:not(:disabled){background:#43a047}.three-product-composer .preview-btn:disabled,.three-product-composer .export-btn:disabled{background:#ccc;cursor:not-allowed}.three-product-composer .action-hint{font-size:13px;color:#666;margin:0 0 0 auto}.three-product-composer .export-progress{display:flex;align-items:center;gap:12px;flex:1;max-width:300px}.three-product-composer .progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.three-product-composer .progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:4px;transition:width .3s ease}.three-product-composer .progress-text{font-size:13px;font-weight:500;color:#4caf50;min-width:40px}.three-product-composer .export-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#ffebee;border:1px solid #ef9a9a;border-radius:6px;font-size:13px;color:#c62828}.three-product-composer .error-icon{font-size:16px}.three-product-composer .retry-btn{margin-left:auto;padding:4px 12px;border:none;border-radius:4px;background:#ef5350;color:#fff;font-size:12px;cursor:pointer;transition:background .2s}.three-product-composer .retry-btn:hover{background:#d32f2f}.three-product-composer .export-complete{display:flex;flex-direction:column;gap:12px;padding:16px;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:8px;flex:1}.three-product-composer .success-message{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#2e7d32}.three-product-composer .success-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#4caf50;color:#fff;border-radius:50%;font-size:12px}.three-product-composer .download-buttons{display:flex;gap:8px}.three-product-composer .download-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.three-product-composer .download-btn.primary{background:#1976d2;color:#fff}.three-product-composer .download-btn.primary:hover{background:#1565c0}.three-product-composer .download-btn.secondary{background:#f5f5f5;color:#333;border:1px solid #ddd}.three-product-composer .download-btn.secondary:hover{background:#e0e0e0}.three-product-composer .export-details{display:flex;gap:16px;font-size:12px;color:#666}.three-product-composer .detail-item{display:flex;align-items:center;gap:4px}.three-product-composer .dimension-entry-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.three-product-composer .dimension-entry-modal{background:#fff;border-radius:12px;padding:24px;max-width:450px;width:90%;box-shadow:0 8px 32px #0003}.three-product-composer .dimension-entry-modal h4{margin:0 0 16px;font-size:18px;font-weight:600;color:#333}@media(max-width:1200px){.three-product-composer{grid-template-columns:300px 1fr;grid-template-rows:auto auto auto}.three-product-composer .product-selection{grid-row:1;grid-column:1}.three-product-composer .template-info{grid-column:2;grid-row:1}.three-product-composer .background-selection{grid-column:1 / 3;grid-row:2}.three-product-composer .background-grid{grid-template-columns:repeat(4,1fr)}.three-product-composer .actions{grid-column:1 / 3;grid-row:3}}@media(max-width:768px){.three-product-composer{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;height:auto;min-height:auto}.three-product-composer .product-selection,.three-product-composer .template-info,.three-product-composer .background-selection,.three-product-composer .actions{grid-column:1}.three-product-composer .product-selection{grid-row:1}.three-product-composer .template-info{grid-row:2}.three-product-composer .background-selection{grid-row:3}.three-product-composer .actions{grid-row:4;flex-direction:column}.three-product-composer .action-hint{margin-left:0;text-align:center}.three-product-composer .export-progress{max-width:100%}.three-product-composer .export-complete{width:100%}.three-product-composer .download-buttons{flex-direction:column}.three-product-composer .download-btn{justify-content:center}}.three-product-composer .validation-warning-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.three-product-composer .validation-warning-modal{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 8px 32px #0003}.three-product-composer .validation-warning-modal h4{margin:0 0 16px;font-size:18px;font-weight:600;color:#e65100}.three-product-composer .warning-intro{font-size:14px;color:#666;margin-bottom:16px}.three-product-composer .warning-list{background:#fff3e0;border:1px solid #ffcc80;border-radius:8px;padding:12px;margin-bottom:16px}.three-product-composer .warning-item{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid #ffe0b2}.three-product-composer .warning-item:last-child{border-bottom:none}.three-product-composer .warning-item .warning-icon{font-size:14px;flex-shrink:0}.three-product-composer .warning-text{font-size:13px;color:#e65100;line-height:1.4}.three-product-composer .warning-actions{display:flex;flex-direction:column;gap:12px}.three-product-composer .fallback-note,.three-product-composer .no-fallback-note{font-size:13px;color:#666;margin:0;padding:8px 12px;background:#f5f5f5;border-radius:6px}.three-product-composer .fallback-note{background:#e8f5e9;color:#2e7d32}.three-product-composer .no-fallback-note{background:#ffebee;color:#c62828}.three-product-composer .accept-fallbacks-btn{padding:12px 24px;border:none;border-radius:6px;background:#ff9800;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.three-product-composer .accept-fallbacks-btn:hover{background:#f57c00}.three-product-composer .cancel-validation-btn{padding:10px 20px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#666;font-size:14px;cursor:pointer;transition:all .2s}.three-product-composer .cancel-validation-btn:hover{background:#f5f5f5;border-color:#ccc}.three-product-composer .low-confidence-modal h4{color:#1565c0}.three-product-composer .low-confidence-item{flex-direction:column;align-items:flex-start}.three-product-composer .low-confidence-details{display:flex;flex-direction:column;gap:4px;width:100%}.three-product-composer .low-confidence-details .product-name{font-weight:600;color:#333;font-size:14px}.three-product-composer .low-confidence-details .angle-info{font-size:13px;color:#666}.three-product-composer .low-confidence-details .angle-info strong{color:#1565c0}.three-product-composer .low-confidence-details .angle-description{font-size:12px;color:#888;font-style:italic}.three-product-composer .low-confidence-note{background:#e3f2fd;color:#1565c0}.three-product-composer .custom-upload-section{margin-top:1rem;padding-top:1rem;border-top:1px solid #ddd}.three-product-composer .upload-btn{display:inline-block;padding:.6rem 1.2rem;background:#6c757d;color:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s ease;width:100%;text-align:center}.three-product-composer .upload-btn:hover{background:#5a6268}.three-product-composer .upload-btn input[type=file]{display:none}.composition-preview{display:flex;flex-direction:column;background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.preview-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.preview-status{font-size:12px;color:#666;background:#f0f0f0;padding:4px 8px;border-radius:4px}.preview-canvas-container{position:relative;background:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s}.preview-canvas-container:hover{border-color:#2196f3}.preview-canvas{display:block}.preview-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#ffffffe6;z-index:10}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;animation:spin 1s linear infinite}.preview-loading span{font-size:14px;color:#666}.preview-empty{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#fffc;pointer-events:none}.empty-icon{font-size:48px;opacity:.5}.empty-text{font-size:14px;color:#666;text-align:center;max-width:200px}.preview-info{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.info-item{font-size:11px;color:#999;font-family:monospace}@media(max-width:768px){.preview-header{flex-direction:column;align-items:flex-start;gap:8px}.preview-info{flex-direction:column;gap:4px}}.composition-bg-selector{display:flex;flex-direction:column;gap:12px}.composition-bg-selector.compact{gap:8px}.bg-selector-header{display:flex;flex-direction:column;gap:8px}.bg-selector-header h4{margin:0;font-size:14px;font-weight:600;color:#333}.category-tabs{display:flex;gap:4px;flex-wrap:wrap}.category-tab{padding:4px 10px;border:1px solid #e0e0e0;border-radius:16px;background:#fff;font-size:12px;color:#666;cursor:pointer;transition:all .2s}.category-tab:hover{border-color:#2196f3;color:#2196f3}.category-tab.active{background:#2196f3;border-color:#2196f3;color:#fff}.bg-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px;color:#666;font-size:13px}.loading-spinner-small{width:20px;height:20px;border:2px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;animation:spin 1s linear infinite}.bg-error{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#ffebee;border-radius:6px;color:#c62828;font-size:13px}.error-icon{font-size:16px}.selected-bg-display{display:flex;align-items:center;gap:12px;padding:10px;background:#e3f2fd;border:1px solid #90caf9;border-radius:8px}.selected-bg-preview{width:60px;height:40px;object-fit:cover;border-radius:4px}.selected-bg-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.selected-bg-name{font-size:13px;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-bg-category{font-size:11px;color:#666}.clear-selection-btn{width:24px;height:24px;border:none;border-radius:50%;background:#ef5350;color:#fff;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s;flex-shrink:0}.clear-selection-btn:hover{background:#d32f2f}.bg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bg-grid.compact-grid{grid-template-columns:repeat(4,1fr);gap:6px}.bg-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s}.bg-item:hover{border-color:#2196f3;transform:translateY(-1px)}.bg-item:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.bg-item.selected{border-color:#4caf50;background:#e8f5e9}.bg-thumbnail-wrapper{position:relative;width:100%;aspect-ratio:16 / 10;overflow:hidden;border-radius:4px}.bg-thumbnail{width:100%;height:100%;object-fit:cover}.selected-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#4caf504d}.check-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#4caf50;color:#fff;border-radius:50%;font-size:14px;font-weight:700}.bg-name{font-size:11px;color:#666;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.bg-empty{padding:24px;text-align:center;color:#999;font-size:13px;background:#f9f9f9;border-radius:6px}.selection-hint{font-size:12px;color:#666;text-align:center;margin:0;font-style:italic}.composition-bg-selector.compact .bg-selector-header h4{font-size:12px}.composition-bg-selector.compact .selected-bg-display{padding:6px}.composition-bg-selector.compact .selected-bg-preview{width:40px;height:28px}.composition-bg-selector.compact .selected-bg-name{font-size:11px}.composition-bg-selector.compact .bg-item{padding:4px}@media(max-width:600px){.bg-grid{grid-template-columns:repeat(2,1fr)}.bg-grid.compact-grid{grid-template-columns:repeat(3,1fr)}}.auto-process-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#000;color:#fff;border:2px solid #000000;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.auto-process-button:hover:not(:disabled){background:#333}.auto-process-button:disabled{opacity:.5;cursor:not-allowed}.button-icon{font-size:1rem}.button-spinner{width:16px;height:16px;border:2px solid #ffffff;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.background-selector-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.background-selector-modal{background:#fff;border-radius:8px;border:2px solid #000000;width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.background-selector-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #000000}.background-selector-modal .modal-header h2{margin:0;font-size:1.25rem;color:#000;font-weight:700}.background-selector-modal .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#000;padding:0;line-height:1}.background-selector-modal .close-button:hover{color:#666}.background-selector-modal .modal-content{flex:1;overflow-y:auto;padding:1.5rem}.background-selector-modal .modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #000000}.loading-backgrounds{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}.loading-backgrounds p{color:#666;margin:0}.cancel-button,.confirm-button{padding:.75rem 1.5rem;border:2px solid #000000;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-button{background:#fff;color:#000}.cancel-button:hover{background:#f0f0f0}.confirm-button{background:#000;color:#fff}.confirm-button:hover:not(:disabled){background:#333}.confirm-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.background-selector-modal{width:95%;max-height:95vh}.background-selector-modal .modal-footer{flex-direction:column}.cancel-button,.confirm-button{width:100%}}.auto-generate-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auto-generate-modal{background:var(--color-surface, #ffffff);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.auto-generate-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border, #e0e0e0)}.auto-generate-modal .modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text, #1a1a1a)}.auto-generate-modal .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary, #666);padding:4px 8px;border-radius:4px;transition:background-color .2s}.auto-generate-modal .close-button:hover{background:var(--color-hover, #f0f0f0)}.auto-generate-modal .modal-content{padding:24px;overflow-y:auto;flex:1 1 auto;min-height:0}.auto-generate-modal .progress-section{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0}.auto-generate-modal .progress-spinner{width:48px;height:48px;border:4px solid var(--color-border, #e0e0e0);border-top-color:var(--color-primary, #3b82f6);border-radius:50%;animation:auto-generate-spin 1s linear infinite}@keyframes auto-generate-spin{to{transform:rotate(360deg)}}.auto-generate-modal .current-step{font-size:1rem;color:var(--color-text, #1a1a1a);font-weight:500;text-align:center}.auto-generate-modal .progress-bar{width:100%;height:8px;background:var(--color-border, #e0e0e0);border-radius:4px;overflow:hidden}.auto-generate-modal .progress-fill{height:100%;background:var(--color-primary, #3b82f6);border-radius:4px;transition:width .3s ease}.auto-generate-modal .progress-text{font-size:.875rem;color:var(--color-text-secondary, #666)}.auto-generate-modal .selected-input-preview{margin-top:20px;padding:16px;background:var(--color-background, #f5f5f5);border-radius:8px;border:1px solid var(--color-border, #e0e0e0)}.auto-generate-modal .selected-input-preview h4{margin:0 0 12px;font-size:.875rem;font-weight:600;color:var(--color-text, #1a1a1a)}.auto-generate-modal .input-image-container{display:flex;justify-content:center;margin-bottom:12px;background:#fff;border-radius:4px;padding:8px}.auto-generate-modal .input-preview-image{max-width:200px;max-height:200px;object-fit:contain;border-radius:4px}.auto-generate-modal .input-details{display:flex;flex-direction:column;gap:6px;font-size:.8rem}.auto-generate-modal .input-detail-row{display:flex;gap:8px;align-items:flex-start}.auto-generate-modal .detail-label{font-weight:600;color:var(--color-text-secondary, #666);min-width:80px}.auto-generate-modal .category-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:500;font-size:.75rem}.auto-generate-modal .category-product{background:var(--color-success-light, #dcfce7);color:var(--color-success, #22c55e)}.auto-generate-modal .category-system{background:var(--color-warning-light, #fef3c7);color:var(--color-warning, #f59e0b)}.auto-generate-modal .category-uncategorized{background:var(--color-border, #e0e0e0);color:var(--color-text-secondary, #666)}.auto-generate-modal .confidence-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:500;font-size:.75rem}.auto-generate-modal .confidence-high{background:var(--color-success-light, #dcfce7);color:var(--color-success, #22c55e)}.auto-generate-modal .confidence-medium{background:var(--color-warning-light, #fef3c7);color:var(--color-warning, #f59e0b)}.auto-generate-modal .confidence-low{background:var(--color-error-light, #fee2e2);color:var(--color-error, #ef4444)}.auto-generate-modal .selection-reason{color:var(--color-text-secondary, #666);font-style:italic}.auto-generate-modal .result-section{display:flex;flex-direction:column;gap:20px}.auto-generate-modal .result-image-container{display:flex;justify-content:center;background:var(--color-background, #f5f5f5);border-radius:8px;padding:16px}.auto-generate-modal .result-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.auto-generate-modal .result-info{text-align:center}.auto-generate-modal .result-product-name{font-size:1.125rem;font-weight:600;color:var(--color-text, #1a1a1a);margin-bottom:8px}.auto-generate-modal .result-angle{font-size:.875rem;color:var(--color-text-secondary, #666)}.auto-generate-modal .angle-badge{display:inline-block;background:var(--color-primary-light, #dbeafe);color:var(--color-primary, #3b82f6);padding:2px 8px;border-radius:4px;font-weight:500;margin-left:4px}.auto-generate-modal .steps-summary{background:var(--color-background, #f5f5f5);border-radius:8px;padding:16px}.auto-generate-modal .steps-summary h3{margin:0 0 12px;font-size:.875rem;font-weight:600;color:var(--color-text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.auto-generate-modal .steps-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.auto-generate-modal .steps-list li{display:flex;align-items:center;gap:8px;font-size:.875rem}.auto-generate-modal .step-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem}.auto-generate-modal .step-completed .step-icon{background:var(--color-success, #22c55e);color:#fff}.auto-generate-modal .step-failed .step-icon{background:var(--color-error, #ef4444);color:#fff}.auto-generate-modal .step-processing .step-icon{background:var(--color-primary, #3b82f6);color:#fff;animation:auto-generate-pulse 1s ease-in-out infinite}.auto-generate-modal .step-skipped .step-icon{background:var(--color-border, #e0e0e0);color:var(--color-text-secondary, #666)}@keyframes auto-generate-pulse{0%,to{opacity:1}50%{opacity:.5}}.auto-generate-modal .step-name{color:var(--color-text, #1a1a1a)}.auto-generate-modal .fallback-badge{font-size:.75rem;color:var(--color-warning, #f59e0b);background:#f59e0b1a;padding:2px 6px;border-radius:4px}.auto-generate-modal .result-actions{display:flex;gap:12px;justify-content:center}.auto-generate-modal .download-button,.auto-generate-modal .continue-button{padding:12px 24px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.auto-generate-modal .download-button{background:var(--color-primary, #3b82f6);color:#fff;border:none}.auto-generate-modal .download-button:hover{background:var(--color-primary-dark, #2563eb)}.auto-generate-modal .continue-button{background:transparent;color:var(--color-primary, #3b82f6);border:1px solid var(--color-primary, #3b82f6)}.auto-generate-modal .continue-button:hover{background:#3b82f61a}.auto-generate-modal .error-section{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px 0;text-align:center}.auto-generate-modal .error-icon{font-size:3rem}.auto-generate-modal .error-message{color:var(--color-error, #ef4444);font-size:.875rem;max-width:400px;line-height:1.5}.auto-generate-modal .error-actions{display:flex;gap:12px}.auto-generate-modal .retry-button,.auto-generate-modal .manual-button{padding:10px 20px;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.auto-generate-modal .retry-button{background:var(--color-primary, #3b82f6);color:#fff;border:none}.auto-generate-modal .retry-button:hover{background:var(--color-primary-dark, #2563eb)}.auto-generate-modal .manual-button{background:transparent;color:var(--color-text-secondary, #666);border:1px solid var(--color-border, #e0e0e0)}.auto-generate-modal .manual-button:hover{background:var(--color-hover, #f0f0f0)}.system-image-input{display:flex;flex-direction:column;gap:1rem}.input-method-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem}.tab-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:none;border-radius:.5rem .5rem 0 0;cursor:pointer;font-size:.875rem;font-weight:500;color:#6b7280;transition:all .2s ease}.tab-button:hover:not(:disabled){background:#f3f4f6;color:#374151}.tab-button.active{background:#3b82f6;color:#fff}.tab-button:disabled{opacity:.5;cursor:not-allowed}.tab-icon{font-size:1rem}.input-content{display:flex;flex-direction:column;gap:1rem}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;border:2px dashed #d1d5db;border-radius:.75rem;background:#f9fafb;cursor:pointer;transition:all .2s ease;min-height:150px}.upload-zone:hover{border-color:#3b82f6;background:#eff6ff}.upload-zone.drag-active{border-color:#3b82f6;background:#dbeafe;border-style:solid}.file-input-hidden{display:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.upload-icon{font-size:2.5rem}.upload-text{font-size:1rem;font-weight:500;color:#374151;margin:0}.upload-hint{font-size:.75rem;color:#6b7280;margin:0}.url-input-section,.scrape-select-section{display:flex;flex-direction:column;gap:.75rem}.url-input-row{display:flex;gap:.5rem}.url-input{flex:1;padding:.75rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;transition:border-color .2s ease}.url-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.url-input:disabled{background:#f3f4f6;cursor:not-allowed}.url-submit-button{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s ease;white-space:nowrap}.url-submit-button:hover:not(:disabled){background:#2563eb}.url-submit-button:disabled{background:#9ca3af;cursor:not-allowed}.url-hint{font-size:.75rem;color:#6b7280;margin:0}.scraped-options{margin-top:1rem}.scraped-options-title{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .75rem}.scraped-options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;max-height:300px;overflow-y:auto;padding:.25rem}.scraped-option{display:flex;flex-direction:column;border:2px solid #e5e7eb;border-radius:.5rem;overflow:hidden;cursor:pointer;transition:all .2s ease;background:#fff}.scraped-option:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.scraped-option.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.scraped-option.likely-system{border-color:#10b981}.scraped-option.likely-system.selected{border-color:#3b82f6}.scraped-option-image{position:relative;aspect-ratio:1;overflow:hidden;background:#f3f4f6}.scraped-option-image img{width:100%;height:100%;object-fit:cover}.system-badge{position:absolute;top:4px;right:4px;background:#10b981e6;padding:2px 6px;border-radius:4px;font-size:.75rem}.scraped-option-info{padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.option-label{font-size:.75rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.confidence-badge{font-size:.625rem;color:#10b981;font-weight:500}.input-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626}.error-icon{font-size:1rem}.error-text{font-size:.875rem}.image-preview{margin-top:1rem}.preview-title{font-size:.875rem;font-weight:600;color:#374151;margin:0 0 .75rem}.preview-container{display:flex;justify-content:center;padding:1rem;background:#f3f4f6;border-radius:.5rem}.preview-image{max-width:100%;max-height:300px;object-fit:contain;border-radius:.25rem;box-shadow:0 1px 3px #0000001a}.product-detection-overlay{display:flex;flex-direction:column;gap:1rem}.detection-image-container{position:relative;width:100%;background:#f3f4f6;border-radius:.5rem;overflow:hidden}.detection-image{display:block;width:100%;height:auto}.bounding-box{position:absolute;border:2px solid;border-radius:4px;cursor:pointer;transition:all .2s ease;box-sizing:border-box}.bounding-box:hover,.bounding-box.hovered{border-width:3px;z-index:10}.bounding-box.selected{border-width:3px;z-index:20}.box-label{position:absolute;top:-24px;left:-2px;display:flex;align-items:center;gap:.375rem;padding:2px 8px;border-radius:4px 4px 0 0;font-size:.75rem;font-weight:500;color:#fff;white-space:nowrap}.product-index{font-weight:600}.confidence-indicator{padding:1px 4px;border-radius:2px;font-size:.625rem;background:#fff3}.confidence-indicator.high{background:#10b9814d}.confidence-indicator.medium{background:#f59e0b4d}.confidence-indicator.low{background:#ef44444d}.corner-handle{position:absolute;width:8px;height:8px;border-style:solid;border-width:2px}.corner-handle.top-left{top:-1px;left:-1px;border-right:none;border-bottom:none;border-radius:4px 0 0}.corner-handle.top-right{top:-1px;right:-1px;border-left:none;border-bottom:none;border-radius:0 4px 0 0}.corner-handle.bottom-left{bottom:-1px;left:-1px;border-right:none;border-top:none;border-radius:0 0 0 4px}.corner-handle.bottom-right{bottom:-1px;right:-1px;border-left:none;border-top:none;border-radius:0 0 4px}.detection-summary{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#f9fafb;border-radius:.5rem}.summary-count{font-size:.875rem;font-weight:600;color:#374151}.detection-legend{display:flex;flex-wrap:wrap;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;transition:all .2s ease}.legend-item:hover{border-color:#3b82f6;background:#eff6ff}.legend-item.selected{border-color:#3b82f6;background:#dbeafe}.legend-color{width:12px;height:12px;border-radius:2px}.legend-label{font-size:.75rem;font-weight:500;color:#374151}.legend-confidence{font-size:.625rem;padding:1px 4px;border-radius:2px;font-weight:500}.legend-confidence.high{background:#d1fae5;color:#065f46}.legend-confidence.medium{background:#fef3c7;color:#92400e}.legend-confidence.low{background:#fee2e2;color:#991b1b}@media(max-width:640px){.box-label{font-size:.625rem;padding:1px 6px;top:-20px}.corner-handle{width:6px;height:6px}.detection-legend{flex-direction:column}}.product-identification-panel{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.panel-title{font-size:1rem;font-weight:600;color:#111827;margin:0}.review-badge{padding:.25rem .75rem;background:#fef3c7;color:#92400e;font-size:.75rem;font-weight:500;border-radius:9999px}.identifying-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#6b7280;font-size:.875rem}.product-list{display:flex;flex-direction:column;max-height:500px;overflow-y:auto}.product-item{display:flex;flex-direction:column;gap:.75rem;padding:1rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background .2s ease}.product-item:last-child{border-bottom:none}.product-item:hover{background:#f9fafb}.product-item.selected{background:#eff6ff;border-left:3px solid #3b82f6}.product-item.needs-review{background:#fffbeb}.product-item.needs-review.selected{background:#fef3c7;border-left-color:#f59e0b}.product-header{display:flex;align-items:center;justify-content:space-between}.product-indicator{display:flex;align-items:center;gap:.5rem}.color-dot{width:12px;height:12px;border-radius:50%}.product-number{font-size:.875rem;font-weight:600;color:#374151}.confidence-badge{padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:9999px}.confidence-badge.high{background:#d1fae5;color:#065f46}.confidence-badge.medium{background:#fef3c7;color:#92400e}.confidence-badge.low{background:#fee2e2;color:#991b1b}.product-preview{width:80px;height:80px;border-radius:.375rem;overflow:hidden;background:#f3f4f6;flex-shrink:0}.product-preview img{width:100%;height:100%;object-fit:cover}.identification-details{display:flex;flex-direction:column;gap:.25rem}.product-name{font-size:.875rem;font-weight:500;color:#111827;line-height:1.3}.model-number{font-size:.75rem;color:#6b7280;font-family:monospace}.confidence-label{font-size:.75rem;font-weight:500}.confidence-label.high{color:#059669}.confidence-label.medium{color:#d97706}.confidence-label.low{color:#dc2626}.not-identified{display:flex;align-items:center;gap:.375rem;font-size:.875rem;color:#6b7280}.warning-icon{font-size:1rem}.review-warning{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;background:#fef3c7;border-radius:.25rem;font-size:.75rem;color:#92400e;margin-top:.25rem}.review-icon{font-size:.875rem}.edit-button{align-self:flex-start;margin-top:.5rem;padding:.375rem .75rem;background:transparent;border:1px solid #d1d5db;border-radius:.375rem;font-size:.75rem;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.edit-button:hover{background:#f3f4f6;border-color:#9ca3af}.manual-input-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#f9fafb;border-radius:.5rem}.input-label{font-size:.75rem;font-weight:500;color:#374151}.manual-input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s ease}.manual-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.manual-input.error{border-color:#ef4444}.input-error{font-size:.75rem;color:#dc2626}.input-actions{display:flex;gap:.5rem;margin-top:.25rem}.cancel-button,.submit-button{flex:1;padding:.5rem;border-radius:.375rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button{background:#fff;border:1px solid #d1d5db;color:#374151}.cancel-button:hover{background:#f3f4f6}.submit-button{background:#3b82f6;border:none;color:#fff}.submit-button:hover{background:#2563eb}.retrieved-product-groups{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.groups-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.groups-title{font-size:1rem;font-weight:600;color:#111827;margin:0}.groups-summary{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.summary-divider{color:#d1d5db}.summary-stat.selected{color:#3b82f6;font-weight:500}.loading-state{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#6b7280;font-size:.875rem}.spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.groups-list{display:flex;flex-direction:column}.product-group{border-bottom:1px solid #e5e7eb}.product-group:last-child{border-bottom:none}.group-header{display:flex;align-items:center;gap:.75rem;padding:1rem;cursor:pointer;transition:background .2s ease}.group-header:hover{background:#f9fafb}.group-header.expanded{background:#f3f4f6}.group-indicator{display:flex;align-items:center;gap:.5rem}.color-bar{width:4px;height:32px;border-radius:2px}.expand-icon{font-size:.625rem;color:#6b7280;transition:transform .2s ease}.expand-icon.expanded{transform:rotate(90deg)}.group-info{flex:1;min-width:0}.group-name{font-size:.875rem;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-meta{display:flex;align-items:center;gap:.75rem;margin-top:.25rem;font-size:.75rem;color:#6b7280}.model-number{font-family:monospace;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}.dimensions{color:#9ca3af}.group-actions{display:flex;align-items:center;gap:.75rem}.selected-badge{padding:.25rem .5rem;background:#dbeafe;color:#1d4ed8;font-size:.75rem;font-weight:500;border-radius:9999px}.select-all-checkbox{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:#6b7280;cursor:pointer}.select-all-checkbox input{cursor:pointer}.group-content{padding:1rem;padding-top:0;background:#fafafa}.reference-section{margin-bottom:1rem}.reference-label{display:block;font-size:.75rem;color:#6b7280;margin-bottom:.5rem}.bounding-box-preview{position:relative;width:150px;border-radius:.375rem;overflow:hidden;background:#e5e7eb}.bounding-box-preview img{display:block;width:100%;height:auto}.preview-box{position:absolute;border:2px solid;border-radius:2px;background:#3b82f61a;pointer-events:none}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.image-item{position:relative;border:2px solid #e5e7eb;border-radius:.5rem;overflow:hidden;cursor:pointer;transition:all .2s ease;background:#fff}.image-item:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a}.image-item.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.image-checkbox{position:absolute;top:4px;left:4px;z-index:10;background:#fff;border-radius:4px;padding:2px;box-shadow:0 1px 2px #0000001a}.image-checkbox input{cursor:pointer}.image-item img{display:block;width:100%;aspect-ratio:1;object-fit:cover}.image-label{display:flex;flex-direction:column;gap:.125rem;padding:.375rem;background:#f9fafb}.view-label{font-size:.625rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-badge{font-size:.5rem;padding:1px 4px;border-radius:2px;font-weight:500;width:fit-content}.category-badge.system{background:#dbeafe;color:#1d4ed8}.empty-state{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;color:#6b7280;font-size:.875rem}.empty-icon{font-size:2rem}@media(max-width:640px){.groups-header{flex-direction:column;align-items:flex-start;gap:.5rem}.group-header{flex-wrap:wrap}.group-actions{width:100%;justify-content:flex-end;margin-top:.5rem}.images-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.system-analysis-workflow{display:flex;flex-direction:column;gap:1.5rem;max-width:1200px;margin:0 auto;padding:1.5rem}.workflow-header{text-align:center}.workflow-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 .5rem}.workflow-description{font-size:.875rem;color:#6b7280;margin:0}.progress-steps{display:flex;justify-content:center;gap:.5rem;padding:1rem 0}.progress-step{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f3f4f6;border-radius:9999px;transition:all .2s ease}.progress-step.active{background:#3b82f6;color:#fff}.progress-step.complete{background:#10b981;color:#fff}.step-indicator{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff3;border-radius:50%;font-size:.75rem;font-weight:600}.progress-step:not(.active):not(.complete) .step-indicator{background:#d1d5db;color:#6b7280}.step-label{font-size:.75rem;font-weight:500}.analysis-progress{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f9fafb;border-radius:.5rem}.progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:4px;transition:width .3s ease}.progress-message{font-size:.875rem;color:#6b7280;text-align:center}.workflow-error{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626}.error-icon{font-size:1.25rem}.error-text{flex:1;font-size:.875rem}.dismiss-error{padding:.25rem .5rem;background:transparent;border:none;font-size:1.25rem;color:#dc2626;cursor:pointer;opacity:.7;transition:opacity .2s ease}.dismiss-error:hover{opacity:1}.workflow-content{min-height:400px}.step-content{display:flex;flex-direction:column;gap:1.5rem}.step-actions{display:flex;justify-content:center;padding-top:1rem}.analysis-results{display:flex;flex-direction:column;gap:1.5rem}.results-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem}.section-title{font-size:1rem;font-weight:600;color:#111827;margin:0 0 1rem}.analysis-summary{background:#f9fafb;border-radius:.75rem;padding:1.5rem}.summary-title{font-size:1rem;font-weight:600;color:#111827;margin:0 0 1rem;text-align:center}.summary-stats{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.stat{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem;background:#fff;border-radius:.5rem;min-width:100px}.stat.warning{background:#fef3c7}.stat-value{font-size:1.5rem;font-weight:700;color:#111827}.stat.warning .stat-value{color:#92400e}.stat-label{font-size:.75rem;color:#6b7280;text-align:center}.workflow-actions{display:flex;justify-content:center;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.primary-button,.secondary-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.primary-button{background:#3b82f6;color:#fff;border:none}.primary-button:hover:not(:disabled){background:#2563eb}.primary-button:disabled{background:#9ca3af;cursor:not-allowed}.secondary-button{background:#fff;color:#374151;border:1px solid #d1d5db}.secondary-button:hover{background:#f3f4f6;border-color:#9ca3af}.button-badge{padding:.125rem .5rem;background:#fff3;border-radius:9999px;font-size:.625rem}@media(max-width:768px){.system-analysis-workflow{padding:1rem}.progress-steps{flex-wrap:wrap}.progress-step{padding:.375rem .75rem}.step-label{display:none}.progress-step.active .step-label,.progress-step.complete .step-label{display:inline}.summary-stats{gap:1rem}.stat{min-width:80px;padding:.75rem}.workflow-actions{flex-direction:column}.primary-button,.secondary-button{width:100%;justify-content:center}}.background-selection-section{margin-top:1rem}.loading-backgrounds{text-align:center;padding:2rem;color:#6b7280;font-size:.875rem}.background-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.background-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem;border:2px solid #e5e7eb;border-radius:.5rem;cursor:pointer;transition:all .2s ease}.background-option:hover{border-color:#3b82f6;background:#f0f9ff}.background-option.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 2px #3b82f633}.background-thumbnail{width:100%;aspect-ratio:1;object-fit:cover;border-radius:.25rem}.background-name{font-size:.75rem;color:#374151;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.process-all-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;box-shadow:0 2px 4px #10b9814d}.process-all-button:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.process-all-button:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none;transform:none}@media(max-width:768px){.background-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.background-option{padding:.375rem}.background-name{font-size:.625rem}}.product-card{position:relative;display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;transition:border-color .2s,box-shadow .2s;overflow:hidden;max-width:100%}.product-card:hover{border-color:#ccc;box-shadow:0 2px 8px #00000014}.product-card-selected{border-color:#000;background-color:#fafafa}.product-card-checkbox{position:absolute;top:.5rem;left:.5rem;z-index:2}.product-card-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#000000}.product-card-thumbnail{position:relative;width:100%;aspect-ratio:1 / 1;border:1px solid #e0e0e0;border-radius:4px;overflow:hidden;background-color:#f5f5f5;cursor:pointer;transition:border-color .2s;flex-shrink:0}.product-card-thumbnail:hover{border-color:#000}.product-card-thumbnail:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #0003}.product-card-thumbnail img{width:100%;height:100%;object-fit:cover}.product-card-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#999;text-transform:uppercase}.product-card-ai-badge{position:absolute;top:.375rem;right:.375rem;padding:.125rem .375rem;font-size:.625rem;font-weight:700;color:#fff;background-color:#000;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.product-card-approved-badge{position:absolute;bottom:.375rem;left:.375rem;width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;background-color:#0891b2;border-radius:50%}.product-card-info{display:flex;flex-direction:column;gap:.125rem;min-width:0;overflow:hidden}.product-card-name{font-weight:600;font-size:.875rem;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.product-card-sku{font-size:.75rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.product-card-record-type{display:inline-block;padding:.125rem .375rem;font-size:.625rem;font-weight:600;color:#7c3aed;background-color:#ede9fe;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;width:fit-content}.product-card-status{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-completed{color:#166534;background-color:#dcfce7}.status-completed .status-icon{color:#16a34a}.status-failed{color:#991b1b;background-color:#fee2e2}.status-failed .status-icon{color:#dc2626}.status-processing{color:#1e40af;background-color:#dbeafe}.status-pending{color:#4b5563;background-color:#f3f4f6}.status-pending .status-icon{color:#9ca3af}.status-not-generated{color:#4b5563;background-color:#f3f4f6}.status-not-generated .status-icon{color:#9ca3af}.status-queued{color:#6b21a8;background-color:#f3e8ff}.status-queued .status-icon{color:#9333ea}.status-awaiting-approval{color:#b45309;background-color:#fef3c7}.status-awaiting-approval .status-icon{color:#f59e0b}.status-approved{color:#0e7490;background-color:#cffafe}.status-approved .status-icon{color:#0891b2}.status-icon{font-size:.875rem;line-height:1}.status-label{line-height:1}.status-spinner{width:12px;height:12px;border:2px solid #3b82f6;border-top-color:transparent;border-radius:50%;animation:status-spin .8s linear infinite}@keyframes status-spin{to{transform:rotate(360deg)}}.product-card-error{display:flex;flex-direction:column;gap:.375rem;padding:.25rem .5rem;background-color:#fef2f2;border-radius:4px}.error-text{font-size:.6875rem;color:#991b1b;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-view-details{align-self:flex-start;padding:.1875rem .5rem;font-size:.625rem;font-weight:500;color:#991b1b;background-color:transparent;border:1px solid #fca5a5;border-radius:3px;cursor:pointer;transition:all .15s}.product-card-view-details:hover{background-color:#fee2e2;border-color:#f87171}.product-card-view-details:focus{outline:none;box-shadow:0 0 0 2px #fef2f2,0 0 0 4px #f87171}.product-card-regenerate{display:flex;align-items:center;justify-content:center;gap:.375rem;width:100%;padding:.5rem;font-size:.75rem;font-weight:600;color:#000;background-color:#fff;border:2px solid #000000;border-radius:4px;cursor:pointer;transition:all .2s}.product-card-regenerate:hover{background-color:#f0f0f0}.product-card-regenerate:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.product-card-regenerate:active{background-color:#e0e0e0}.regenerate-icon{font-size:.875rem}@media(max-width:600px){.product-card{padding:.5rem}.product-card-name{font-size:.8125rem}.product-card-sku{font-size:.6875rem}.product-card-status{font-size:.6875rem;padding:.1875rem .375rem}.product-card-regenerate{padding:.375rem;font-size:.6875rem}}.filter-tabs-container{display:flex;flex-direction:column;gap:.75rem}.filter-tabs{display:flex;flex-wrap:nowrap;gap:.5rem;padding:.5rem 0;border-bottom:2px solid #e0e0e0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.filter-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:#666;background-color:transparent;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-tab:hover{color:#000;background-color:#f5f5f5}.filter-tab:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.filter-tab-active{color:#000;background-color:#fff;border-color:#000;font-weight:600}.filter-tab-active:hover{background-color:#fff}.filter-tab-label{line-height:1.2}.filter-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.25rem;padding:0 .375rem;font-size:.6875rem;font-weight:600;color:#666;background-color:#f0f0f0;border-radius:10px;transition:all .2s ease}.count-badge-active{color:#000;background-color:#e0e0e0}.count-badge-completed{color:#166534;background-color:#dcfce7}.count-badge-completed.count-badge-active{color:#166534;background-color:#bbf7d0}.count-badge-failed{color:#991b1b;background-color:#fee2e2}.count-badge-failed.count-badge-active{color:#991b1b;background-color:#fecaca}.count-badge-processing{color:#1e40af;background-color:#dbeafe}.count-badge-processing.count-badge-active{color:#1e40af;background-color:#bfdbfe}.count-badge-pending{color:#4b5563;background-color:#f3f4f6}.count-badge-pending.count-badge-active{color:#374151;background-color:#e5e7eb}.count-badge-not-generated{color:#6b7280;background-color:#f3f4f6}.count-badge-not-generated.count-badge-active{color:#4b5563;background-color:#e5e7eb}.count-badge-queued{color:#7c3aed;background-color:#ede9fe}.count-badge-queued.count-badge-active{color:#6d28d9;background-color:#ddd6fe}.count-badge-awaiting-approval{color:#d97706;background-color:#fef3c7}.count-badge-awaiting-approval.count-badge-active{color:#b45309;background-color:#fde68a}.count-badge-approved{color:#0891b2;background-color:#cffafe}.count-badge-approved.count-badge-active{color:#0e7490;background-color:#a5f3fc}.count-badge-not-in-stock{color:#6b7280;background-color:#f3f4f6}.count-badge-not-in-stock.count-badge-active{color:#4b5563;background-color:#e5e7eb}@media(max-width:768px){.filter-tabs{gap:.375rem;padding:.375rem 0}.filter-tab{padding:.5rem .75rem;font-size:.8125rem;gap:.375rem}.filter-tab-count{min-width:1.25rem;height:1.125rem;padding:0 .25rem;font-size:.625rem}}@media(max-width:480px){.filter-tabs{gap:.25rem}.filter-tab{padding:.375rem .5rem;font-size:.75rem;gap:.25rem;flex:1 1 auto;justify-content:center}.filter-tab-label{display:none}.filter-tab:before{content:attr(data-status);text-transform:capitalize}.filter-tab[data-status=all]:before{content:"All"}}.filter-tab-pulsing{animation:tab-pulse 2s ease-in-out infinite}@keyframes tab-pulse{0%,to{background-color:transparent;box-shadow:none}50%{background-color:#dbeafe;box-shadow:0 0 8px #3b82f666}}.filter-tab-pulsing .filter-tab-label{animation:text-pulse 2s ease-in-out infinite}@keyframes text-pulse{0%,to{color:#666}50%{color:#1e40af}}.filter-tabs-container .queue-processor-controls{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background-color:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.queue-processor-info{display:flex;flex-direction:column;gap:.125rem;flex:1}.queue-processor-title{font-size:.875rem;font-weight:600;color:#1f2937}.queue-processor-description{font-size:.75rem;color:#6b7280}.queue-processor-indicator{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500}.queue-processor-running{color:#059669}.queue-processor-paused{color:#d97706}.queue-processor-stopped{color:#6b7280}.queue-processor-pulse{width:8px;height:8px;background-color:#059669;border-radius:50%;animation:processor-pulse 1.5s ease-in-out infinite}@keyframes processor-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.queue-stat{font-size:.8125rem;color:#4b5563}.queue-stat-active{color:#2563eb}.queue-processor-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.queue-processor-btn-start{background-color:#059669;color:#fff}.queue-processor-btn-start:hover:not(:disabled){background-color:#047857}.queue-processor-btn-stop{background-color:#dc2626;color:#fff}.queue-processor-btn-stop:hover:not(:disabled){background-color:#b91c1c}.queue-btn-loading{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:btn-spin .8s linear infinite}@keyframes btn-spin{to{transform:rotate(360deg)}}.image-preview-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background-color:#000000d9;animation:modal-fade-in .2s ease-out;padding:2rem;box-sizing:border-box}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.image-preview-modal-content{position:relative;display:flex;flex-direction:column;background-color:#fff;border-radius:12px;max-width:800px;max-height:85vh;width:90vw;overflow:hidden;box-shadow:0 25px 50px -12px #00000080;pointer-events:auto}.image-preview-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background-color:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.image-preview-modal-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.image-preview-modal-title{margin:0;font-size:1.125rem;font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-preview-modal-sku{font-size:.875rem;color:#666}.image-preview-modal-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.image-preview-modal-ai-badge{padding:.375rem .75rem;font-size:.75rem;font-weight:600;color:#fff;background-color:#000;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.image-preview-modal-regenerate{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#000;background-color:#fff;border:2px solid #000000;border-radius:4px;cursor:pointer;transition:all .2s}.image-preview-modal-regenerate:hover{background-color:#f0f0f0}.image-preview-modal-regenerate:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.image-preview-modal-regenerate .regenerate-icon{font-size:1rem}.image-preview-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:1.25rem;color:#666;background-color:transparent;border:2px solid #e0e0e0;border-radius:4px;cursor:pointer;transition:all .2s}.image-preview-modal-close:hover{color:#000;border-color:#000}.image-preview-modal-close:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #0003}.image-preview-modal-image-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:400px;overflow:hidden;background-color:#f5f5f5;padding:1rem}.image-preview-modal-image{max-width:100%;max-height:100%;width:auto;height:auto;min-width:300px;min-height:300px;object-fit:contain;border-radius:4px;animation:image-scale-in .2s ease-out}@keyframes image-scale-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.image-preview-modal-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:48px;height:48px;font-size:2rem;color:#fff;background-color:#0009;border:none;border-radius:50%;cursor:pointer;transition:all .2s;z-index:10}.image-preview-modal-nav:hover{background-color:#000c}.image-preview-modal-nav:focus{outline:none;box-shadow:0 0 0 2px #fff}.image-preview-modal-nav-prev{left:1rem}.image-preview-modal-nav-next{right:1rem}.image-preview-modal-counter{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);padding:.375rem .75rem;font-size:.875rem;font-weight:500;color:#fff;background-color:#000000b3;border-radius:4px}.image-preview-modal-product-nav{display:flex;justify-content:center;gap:1rem;padding:1rem;background-color:#f5f5f5;border-top:1px solid #e5e7eb;flex-shrink:0}.image-preview-modal-product-nav-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#333;background-color:#fff;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;transition:all .2s}.image-preview-modal-product-nav-btn:hover{border-color:#000;background-color:#f9f9f9}.image-preview-modal-product-nav-btn:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #0000001a}@media(max-width:768px){.image-preview-modal-backdrop{padding:1rem}.image-preview-modal-content{width:95vw;max-height:90vh}.image-preview-modal-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:.75rem}.image-preview-modal-actions{width:100%;justify-content:space-between}.image-preview-modal-title{font-size:1rem}.image-preview-modal-sku{font-size:.75rem}.image-preview-modal-image-container{min-height:300px}.image-preview-modal-image{min-width:200px;min-height:200px}.image-preview-modal-nav{width:40px;height:40px;font-size:1.5rem}.image-preview-modal-nav-prev{left:.5rem}.image-preview-modal-nav-next{right:.5rem}.image-preview-modal-regenerate{padding:.375rem .75rem;font-size:.75rem}.image-preview-modal-product-nav{flex-direction:column;gap:.5rem;padding:.75rem}.image-preview-modal-product-nav-btn{width:100%;text-align:center}}@media(max-width:480px){.image-preview-modal-close{width:32px;height:32px;font-size:1rem}.image-preview-modal-ai-badge{padding:.25rem .5rem;font-size:.625rem}}.batch-action-toolbar{position:sticky;bottom:0;left:0;right:0;z-index:100;background-color:#fff;border-top:2px solid #000000;box-shadow:0 -4px 12px #0000001a;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.batch-toolbar-content{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1400px;margin:0 auto;padding:.75rem 1.5rem}.batch-selection-info{display:flex;align-items:center;gap:.5rem}.batch-selection-count{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;height:1.75rem;padding:0 .5rem;font-size:.875rem;font-weight:700;color:#fff;background-color:#000;border-radius:4px}.batch-selection-label{font-size:.875rem;font-weight:500;color:#333}.batch-progress{display:flex;align-items:center;gap:.75rem;flex:1;max-width:300px}.batch-progress-bar{flex:1;height:6px;background-color:#e0e0e0;border-radius:3px;overflow:hidden}.batch-progress-fill{height:100%;background-color:#000;border-radius:3px;transition:width .3s ease}.batch-progress-text{font-size:.8125rem;font-weight:600;color:#666;white-space:nowrap}.batch-actions{display:flex;align-items:center;gap:.75rem}.batch-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.batch-action-btn:focus{outline:none;box-shadow:0 0 0 2px #fff,0 0 0 4px #000}.batch-action-btn:disabled{opacity:.5;cursor:not-allowed}.batch-action-clear{color:#333;background-color:transparent;border:2px solid #cccccc}.batch-action-clear:hover:not(:disabled){color:#000;border-color:#999;background-color:#f5f5f5}.batch-action-regenerate{color:#fff;background-color:#000;border:2px solid #000000}.batch-action-regenerate:hover:not(:disabled){background-color:#333;border-color:#333}.batch-regenerate-icon{flex-shrink:0}.batch-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.batch-toolbar-content{flex-wrap:wrap;padding:.625rem 1rem;gap:.75rem}.batch-selection-info{flex:1 1 auto}.batch-progress{order:3;flex:1 1 100%;max-width:none}.batch-actions{flex:0 0 auto}.batch-action-btn{padding:.5rem .75rem;font-size:.8125rem}}@media(max-width:480px){.batch-toolbar-content{padding:.5rem .75rem;gap:.5rem}.batch-selection-label{display:none}.batch-action-clear{padding:.5rem}.batch-action-clear:after{content:"Clear"}.batch-action-clear{font-size:0}.batch-action-clear:after{font-size:.8125rem}.batch-action-regenerate{padding:.5rem .625rem;font-size:.8125rem}}.batch-action-requeue{color:#fff;background-color:#2563eb;border:2px solid #2563eb}.batch-action-requeue:hover:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8}.batch-requeue-icon{flex-shrink:0}.batch-action-publish{color:#fff;background-color:#0891b2;border:2px solid #0891b2}.batch-action-publish:hover:not(:disabled){background-color:#0e7490;border-color:#0e7490}.batch-publish-icon{flex-shrink:0}.batch-spinner-publish{border-color:#ffffff4d;border-top-color:#fff}.batch-action-unqueue{color:#fff;background-color:#6b7280;border:2px solid #6b7280}.batch-action-unqueue:hover:not(:disabled){background-color:#4b5563;border-color:#4b5563}.batch-unqueue-icon{flex-shrink:0}.batch-action-reject{color:#fff;background-color:#dc2626;border:2px solid #dc2626}.batch-action-reject:hover:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.batch-reject-icon{flex-shrink:0}.batch-spinner-reject{border-color:#ffffff4d;border-top-color:#fff}.failure-reason-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;animation:failure-reason-overlay-fade-in .2s ease-out}@keyframes failure-reason-overlay-fade-in{0%{opacity:0}to{opacity:1}}.failure-reason-selector{position:relative;width:90vw;max-width:600px;max-height:90vh;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #0000000d;z-index:10000;animation:failure-reason-selector-slide-in .25s ease-out;overflow:hidden;display:flex;flex-direction:column}@keyframes failure-reason-selector-slide-in{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.failure-reason-selector-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(to bottom,#fef2f2,#fee2e2);border-bottom:1px solid #fecaca;flex-shrink:0}.failure-reason-selector-title{margin:0;font-size:18px;font-weight:600;color:#991b1b}.failure-reason-selector-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:18px;color:#991b1b;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease}.failure-reason-selector-close:hover{background:#991b1b1a}.failure-reason-selector-close:focus{outline:none;box-shadow:0 0 0 2px #991b1b4d}.failure-reason-selector-search{padding:16px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.failure-reason-selector-input{width:100%;padding:14px 16px;font-size:16px;color:#1f2937;background:#f9fafb;border:1px solid #d1d5db;border-radius:10px;outline:none;transition:all .15s ease;box-sizing:border-box}.failure-reason-selector-input:focus{background:#fff;border-color:#dc2626;box-shadow:0 0 0 3px #dc262626}.failure-reason-selector-input::placeholder{color:#9ca3af}.failure-reason-selector-input-error{border-color:#dc2626;background:#fef2f2}.failure-reason-selector-error{display:block;margin-top:8px;font-size:13px;color:#dc2626}.failure-reason-selector-list{flex:1;overflow-y:auto;padding:8px 0;min-height:200px;max-height:50vh}.failure-reason-selector-item{display:flex;align-items:center;gap:12px;padding:14px 24px;cursor:pointer;transition:background .1s ease}.failure-reason-selector-item:hover{background:#f3f4f6}.failure-reason-selector-item-highlighted{background:#fef2f2}.failure-reason-selector-item-highlighted:hover{background:#fee2e2}.failure-reason-selector-item-text{flex:1;font-size:15px;color:#374151;line-height:1.4}.failure-reason-selector-item-create{border-top:1px solid #e5e7eb;margin-top:8px;padding-top:16px;color:#059669}.failure-reason-selector-item-create .failure-reason-selector-item-text{color:#059669}.failure-reason-selector-item-create strong{color:#047857}.failure-reason-selector-item-create.failure-reason-selector-item-disabled{cursor:wait;opacity:.7}.failure-reason-selector-item-create.failure-reason-selector-item-disabled:hover{background:transparent}.failure-reason-selector-item-create.failure-reason-selector-item-disabled .failure-reason-selector-item-text{color:#6b7280}.failure-reason-selector-create-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:18px;font-weight:700;color:#059669;background:#d1fae5;border-radius:50%;flex-shrink:0}.failure-reason-selector-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:32px 24px;font-size:15px;color:#6b7280}.failure-reason-selector-loading-inline{display:flex;align-items:center;gap:10px;padding:12px 24px;font-size:13px;color:#9ca3af;background:#f9fafb;border-bottom:1px solid #e5e7eb}.failure-reason-selector-spinner-small{display:inline-block;width:14px;height:14px;border:2px solid #e5e7eb;border-top-color:#dc2626;border-radius:50%;animation:failure-reason-spinner .7s linear infinite}.failure-reason-selector-spinner{display:inline-block;width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#dc2626;border-radius:50%;animation:failure-reason-spinner .7s linear infinite}@keyframes failure-reason-spinner{to{transform:rotate(360deg)}}.failure-reason-selector-empty{padding:32px 24px;text-align:center;font-size:15px;color:#6b7280}.failure-reason-selector-footer{padding:14px 24px;background:#f9fafb;border-top:1px solid #e5e7eb;flex-shrink:0}.failure-reason-selector-hint{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:#9ca3af}.failure-reason-selector-hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;font-family:inherit;font-size:11px;color:#6b7280;background:#fff;border:1px solid #d1d5db;border-radius:4px;box-shadow:0 1px #d1d5db}@media(max-width:640px){.failure-reason-selector{width:95vw;max-height:95vh;border-radius:12px}.failure-reason-selector-header{padding:16px 20px}.failure-reason-selector-title{font-size:16px}.failure-reason-selector-search{padding:12px 20px}.failure-reason-selector-input{padding:12px 14px;font-size:16px}.failure-reason-selector-item{padding:12px 20px}.failure-reason-selector-list{max-height:60vh}.failure-reason-selector-footer{padding:12px 20px}.failure-reason-selector-hint{flex-wrap:wrap}}.generation-logs-section{margin:.75rem 1.5rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background-color:#f8fafc;overflow:hidden}.generation-logs-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .875rem;font-size:.8125rem;font-weight:600;color:#475569;background-color:transparent;border:none;cursor:pointer;transition:background-color .15s ease;text-align:left}.generation-logs-toggle:hover{background-color:#f1f5f9}.generation-logs-toggle-icon{font-size:.625rem;color:#64748b;transition:transform .2s ease}.generation-logs-toggle-icon.expanded{transform:rotate(90deg)}.generation-logs-toggle-text{flex:1}.generation-logs-badge{font-size:.6875rem;font-weight:700;padding:.125rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.generation-logs-badge-product{background-color:#22c55e26;color:#15803d}.generation-logs-badge-system{background-color:#7c3aed26;color:#6d28d9}.generation-logs-content{padding:.875rem;border-top:1px solid #e2e8f0;background-color:#fff}.generation-logs-grid{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;align-items:baseline}.generation-logs-row{display:contents}.generation-logs-label{font-size:.75rem;font-weight:600;color:#64748b;white-space:nowrap}.generation-logs-value{font-size:.8125rem;color:#1e293b}.generation-logs-code{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.75rem;color:#0369a1;background-color:#0369a114;padding:.125rem .375rem;border-radius:4px}.generation-logs-link{font-size:.8125rem;color:#2563eb;text-decoration:none;transition:color .15s ease}.generation-logs-link:hover{color:#1d4ed8;text-decoration:underline}.generation-logs-angle{font-weight:600;color:#7c3aed;background-color:#7c3aed1a;padding:.125rem .5rem;border-radius:4px}.generation-logs-count{font-weight:700;color:#0369a1;background-color:#0369a11a;padding:.125rem .5rem;border-radius:4px}.generation-logs-status{font-weight:600;padding:.125rem .5rem;border-radius:4px}.generation-logs-status-processing{color:#0369a1;background-color:#0369a11a}.generation-logs-status-completed{color:#15803d;background-color:#22c55e1a}.generation-logs-status-failed{color:#dc2626;background-color:#dc26261a}.generation-logs-timeline{margin-top:.875rem;border-top:1px solid #e2e8f0;padding-top:.75rem}.generation-logs-timeline-summary{font-size:.75rem;font-weight:600;color:#64748b;cursor:pointer;padding:.25rem 0;-webkit-user-select:none;user-select:none}.generation-logs-timeline-summary:hover{color:#475569}.generation-logs-steps{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.generation-logs-step{display:flex;align-items:flex-start;gap:.5rem;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;border-left:2px solid transparent}.generation-logs-step-info{background-color:#f0f9ff;border-left-color:#0ea5e9}.generation-logs-step-success{background-color:#f0fdf4;border-left-color:#22c55e}.generation-logs-step-warn{background-color:#fffbeb;border-left-color:#f59e0b}.generation-logs-step-error{background-color:#fef2f2;border-left-color:#ef4444}.generation-logs-step-time{font-family:SF Mono,Monaco,monospace;font-size:.6875rem;color:#64748b;flex-shrink:0}.generation-logs-step-message{color:#334155;word-break:break-word}.generation-logs-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem .875rem;font-size:.8125rem;color:#64748b}.generation-logs-loading-spinner{width:14px;height:14px;border:2px solid #e2e8f0;border-top-color:#7c3aed;border-radius:50%;animation:generation-logs-spin .8s linear infinite}@keyframes generation-logs-spin{to{transform:rotate(360deg)}}@media(max-width:640px){.generation-logs-grid{grid-template-columns:1fr;gap:.375rem}.generation-logs-row{display:flex;flex-direction:column;gap:.125rem;padding-bottom:.375rem;border-bottom:1px solid #f1f5f9}.generation-logs-row:last-child{border-bottom:none;padding-bottom:0}}.quality-score-container{display:inline-flex;flex-direction:column;gap:8px;font-family:inherit}.quality-score-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid transparent}.quality-score-high{background-color:#dcfce7;color:#166534;border-color:#22c55e}.quality-score-medium{background-color:#fef9c3;color:#854d0e;border-color:#eab308}.quality-score-low{background-color:#fee2e2;color:#991b1b;border-color:#ef4444}.quality-score-badge .toggle-icon{font-size:10px;transition:transform .15s ease}.quality-score-badge .toggle-icon.expanded{transform:rotate(90deg)}.quality-details{padding:10px;border:1px solid #e5e7eb;border-radius:6px;background:#f9fafb;font-size:13px}.quality-check-item{display:flex;justify-content:space-between;align-items:flex-start;padding:6px 0;border-bottom:1px solid #e5e7eb}.quality-check-item:last-child{border-bottom:none}.check-name{font-weight:500}.check-status{margin-left:6px}.check-score{color:#6b7280;margin-left:auto;padding-left:12px;white-space:nowrap}.check-rationale{color:#6b7280;font-size:12px;margin-top:2px}.attempt-history{margin-top:8px;padding:8px;background:#f3f4f6;border-radius:4px;font-size:12px;color:#374151}.attempt-history-title{font-weight:600;margin-bottom:4px}.quality-warning{display:flex;align-items:center;gap:6px;margin-top:6px;padding:6px 10px;background-color:#fff7ed;border:1px solid #f97316;border-radius:4px;color:#c2410c;font-size:13px;font-weight:500}.quality-score-not-evaluated{background:#e5e7eb;color:#6b7280;cursor:default}.approval-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:block;background-color:#000000eb;animation:approval-modal-fade-in .25s ease-out;padding:0;box-sizing:border-box;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;overflow-x:hidden}@keyframes approval-modal-fade-in{0%{opacity:0}to{opacity:1}}.approval-modal-content{position:relative;display:flex;flex-direction:column;background-color:#fff;border-radius:0;width:100%;min-height:100vh;overflow:visible;box-shadow:none;pointer-events:auto;animation:approval-modal-slide-up .3s ease-out;padding-bottom:2rem}.approval-modal-content.approval-modal-loading{justify-content:center;align-items:center;gap:1rem}.approval-modal-loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:approval-modal-spin .8s linear infinite}@keyframes approval-modal-spin{to{transform:rotate(360deg)}}.approval-modal-loading-text{font-size:1rem;color:#6b7280;margin:0}@keyframes approval-modal-slide-up{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.approval-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:linear-gradient(to bottom,#fff,#fafafa);border-bottom:1px solid #e5e7eb;flex-shrink:0}.approval-modal-info{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.approval-modal-title{margin:0;font-size:1.25rem;font-weight:600;color:#000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.approval-modal-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.approval-modal-sku{font-size:.875rem;color:#666}.approval-modal-source-link{font-size:.75rem;color:#2563eb;text-decoration:none;display:inline-block;max-width:350px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s}.approval-modal-source-link:hover{color:#1d4ed8;text-decoration:underline}.approval-modal-source-link-loading{color:#9ca3af;cursor:default;animation:pulse-opacity 1.5s ease-in-out infinite}.approval-modal-source-link-loading:hover{color:#9ca3af;text-decoration:none}@keyframes pulse-opacity{0%,to{opacity:.6}50%{opacity:1}}.approval-modal-endpoint-badge{font-size:.75rem;font-weight:600;padding:.25rem .5rem;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.approval-modal-endpoint-product{color:#1d4ed8;background-color:#2563eb1a;border:1px solid rgba(37,99,235,.2)}.approval-modal-endpoint-system{color:#7c3aed;background-color:#7c3aed1a;border:1px solid rgba(124,58,237,.2)}.approval-modal-generation-details{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;flex-wrap:wrap}.approval-modal-generation-details-unavailable{background-color:#fef3c7;border-color:#fcd34d}.approval-modal-generation-label{font-weight:600;color:#475569}.approval-modal-generation-endpoint{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;color:#0369a1;background-color:#0369a11a;padding:.125rem .375rem;border-radius:4px;word-break:break-all;overflow-wrap:break-word}.approval-modal-generation-separator{color:#94a3b8;font-weight:500}.approval-modal-generation-identifier{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-weight:600;color:#059669;background-color:#0596691a;padding:.125rem .375rem;border-radius:4px}.approval-modal-generation-record-type{font-size:.6875rem;font-weight:700;padding:.125rem .375rem;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.approval-modal-generation-record-type-product{color:#1d4ed8;background-color:#2563eb26}.approval-modal-generation-record-type-system{color:#7c3aed;background-color:#7c3aed26}.approval-modal-generation-unavailable-text{color:#92400e;font-style:italic}.approval-modal-input-image-section{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;padding:.5rem .75rem;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.8125rem;flex-wrap:wrap}.approval-modal-input-image-unavailable{background-color:#fef3c7;border-color:#fcd34d}.approval-modal-input-image-label{font-weight:600;color:#475569}.approval-modal-input-image-container{position:relative;width:48px;height:48px;border-radius:4px;overflow:hidden;background-color:#f1f5f9;border:1px solid #e2e8f0;flex-shrink:0}.approval-modal-input-image-thumbnail{width:100%;height:100%;object-fit:cover}.approval-modal-input-image-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f1f5f9;color:#94a3b8;font-size:.625rem;text-align:center;gap:.125rem}.approval-modal-input-image-error-icon{font-size:1rem}.approval-modal-input-image-error-text{font-size:.5rem;line-height:1.2}.approval-modal-input-image-source{font-size:.6875rem;font-weight:600;padding:.125rem .375rem;border-radius:4px;text-transform:uppercase;letter-spacing:.025em}.approval-modal-input-image-source-system-image{color:#7c3aed;background-color:#7c3aed1a;border:1px solid rgba(124,58,237,.2)}.approval-modal-input-image-source-primary-product-image{color:#1d4ed8;background-color:#2563eb1a;border:1px solid rgba(37,99,235,.2)}.approval-modal-input-image-source-vision-derived{color:#059669;background-color:#0596691a;border:1px solid rgba(5,150,105,.2)}.approval-modal-input-image-unavailable-text{color:#92400e;font-style:italic}.approval-modal-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:1.25rem;color:#6b7280;background-color:#f3f4f6;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .2s ease;flex-shrink:0}.approval-modal-close:hover:not(:disabled){color:#1f2937;background-color:#e5e7eb;border-color:#d1d5db;transform:scale(1.05)}.approval-modal-close:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.approval-modal-close:active:not(:disabled){transform:scale(.95)}.approval-modal-close:disabled{opacity:.5;cursor:not-allowed}.approval-modal-image-container{position:relative;flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:400px;max-height:calc(90vh - 280px);overflow:hidden;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:1rem}.approval-modal-comparison{display:flex;gap:1.5rem;width:100%;height:100%;max-width:1200px;justify-content:center;align-items:stretch}.approval-modal-left-column{flex:1;display:flex;flex-direction:column;gap:.75rem;max-width:50%;min-width:0}.approval-modal-original-section,.approval-modal-iframe-section{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;min-height:0}.approval-modal-iframe-wrapper{position:relative;width:100%;flex:1;min-height:150px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px -1px #0000001a,0 1px 2px -1px #0000000f,0 0 0 1px #0000000d;overflow:hidden}.approval-modal-iframe{width:100%;height:100%;border:none}.approval-modal-iframe-hidden{position:absolute;opacity:0;pointer-events:none}.approval-modal-iframe-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f9fafb;color:#9ca3af}.approval-modal-iframe-loading-text{font-size:.875rem;animation:pulse-opacity 1.5s ease-in-out infinite}.approval-modal-iframe-fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;background-color:#f9fafb;color:#6b7280}.approval-modal-iframe-fallback-text{font-size:.875rem}.approval-modal-iframe-fallback-link{font-size:.875rem;color:#2563eb;text-decoration:none;padding:.5rem 1rem;border:1px solid #2563eb;border-radius:6px;transition:background-color .15s ease,color .15s ease}.approval-modal-iframe-fallback-link:hover{background-color:#2563eb;color:#fff}.approval-modal-right-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;max-width:50%;min-width:0}.approval-modal-image-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.75rem;max-width:450px}.approval-modal-image-label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;padding:.375rem .75rem;background-color:#ffffffe6;border-radius:6px;box-shadow:0 1px 2px #0000000d}.approval-modal-image-label-ai{color:#059669;background-color:#10b9811a}.approval-modal-image-wrapper{position:relative;width:100%;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #0000000d;overflow:hidden}.approval-modal-image-wrapper-small{position:relative;flex:1;width:100%;aspect-ratio:auto;max-height:100%}.approval-modal-image-badge{position:absolute;top:8px;left:8px;background:#000000bf;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600;z-index:10;pointer-events:none}.approval-modal-image-wrapper-large{flex:1;width:100%;aspect-ratio:auto;max-height:100%}.approval-modal-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;animation:approval-image-scale-in .2s ease-out}@keyframes approval-image-scale-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.approval-modal-image-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#666}.approval-modal-error-icon{font-size:3rem}.approval-modal-error-text{font-size:1rem;text-align:center}.approval-modal-nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:60px;height:60px;font-size:2.5rem;font-weight:300;color:#fff;background-color:#00000080;border:2px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;transition:all .2s ease;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.approval-modal-nav:hover:not(:disabled){background-color:#000000bf;border-color:#fff6;transform:translateY(-50%) scale(1.1);box-shadow:0 4px 12px #0000004d}.approval-modal-nav:focus{outline:none;border-color:#fff9;box-shadow:0 0 0 4px #fff3}.approval-modal-nav:active:not(:disabled){transform:translateY(-50%) scale(.95)}.approval-modal-nav:disabled{opacity:.4;cursor:not-allowed}.approval-modal-nav-prev{left:1.5rem}.approval-modal-nav-next{right:1.5rem}.approval-modal-position{text-align:center;padding:.75rem;font-size:.875rem;font-weight:600;color:#6b7280;background-color:#f9fafb;letter-spacing:.025em}.approval-modal-actions{display:flex;gap:1rem;padding:1.5rem;background:linear-gradient(to top,#fff,#fafafa);border-top:1px solid #e5e7eb;flex-shrink:0;min-height:92px}.approval-modal-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.625rem;padding:1.125rem 1.75rem;font-size:1.125rem;font-weight:700;letter-spacing:.025em;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;min-height:60px;text-transform:uppercase;box-shadow:0 2px 4px #0000001a}.approval-modal-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.approval-modal-btn:active:not(:disabled){transform:scale(.98)}.approval-modal-btn-icon{font-size:1.375rem;font-weight:700}.approval-modal-btn-approve{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 6px #16a34a40,0 2px 4px #16a34a26}.approval-modal-btn-approve:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 12px #16a34a59,0 4px 6px #16a34a33;transform:translateY(-2px)}.approval-modal-btn-approve:focus{outline:none;box-shadow:0 0 0 4px #16a34a4d,0 4px 6px #16a34a40}.approval-modal-btn-reject{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 6px #dc262640,0 2px 4px #dc262626}.approval-modal-btn-reject:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 12px #dc262659,0 4px 6px #dc262633;transform:translateY(-2px)}.approval-modal-btn-reject:focus{outline:none;box-shadow:0 0 0 4px #dc26264d,0 4px 6px #dc262640}.approval-modal-info-text{margin:0;padding:0 1.5rem 1rem;font-size:.8125rem;color:#6b7280;text-align:center;font-style:italic}.approval-modal-spinner{display:inline-block;width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:approval-spinner .7s linear infinite}@keyframes approval-spinner{to{transform:rotate(360deg)}}.approval-modal-btn-animating{pointer-events:none}.approval-modal-btn-approve.approval-modal-btn-animating{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 0 20px #10b98180,0 4px 6px #10b98140;animation:approval-btn-pulse .3s ease-out}.approval-modal-btn-reject.approval-modal-btn-animating{background:linear-gradient(135deg,#f87171,#ef4444);box-shadow:0 0 20px #ef444480,0 4px 6px #ef444440;animation:approval-btn-pulse .3s ease-out}@keyframes approval-btn-pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.approval-modal-btn-icon-animated{animation:approval-icon-bounce .3s ease-out}@keyframes approval-icon-bounce{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.approval-modal-selector-container{width:100%;display:flex;justify-content:center;align-items:center;padding:0}@media(max-width:768px){.approval-modal-backdrop{padding:.75rem}.approval-modal-content{width:100%;max-height:95vh;border-radius:12px}.approval-modal-header{padding:1rem 1.25rem}.approval-modal-title{font-size:1rem}.approval-modal-sku{font-size:.75rem}.approval-modal-generation-details{font-size:.75rem;padding:.375rem .5rem;gap:.375rem}.approval-modal-generation-endpoint,.approval-modal-generation-identifier{font-size:.6875rem}.approval-modal-generation-record-type{font-size:.625rem}.approval-modal-input-image-section{font-size:.75rem;padding:.375rem .5rem;gap:.5rem}.approval-modal-input-image-container{width:40px;height:40px}.approval-modal-input-image-source{font-size:.625rem}.approval-modal-close{width:40px;height:40px;font-size:1rem}.approval-modal-image-container{min-height:300px;padding:1rem}.approval-modal-comparison{flex-direction:column;gap:1rem;align-items:center}.approval-modal-left-column{max-width:100%;width:100%;flex-direction:row;gap:.75rem}.approval-modal-original-section,.approval-modal-iframe-section{flex:1}.approval-modal-right-column,.approval-modal-image-column{max-width:100%;width:100%}.approval-modal-image-wrapper{max-width:280px;margin:0 auto}.approval-modal-image-wrapper-small,.approval-modal-image-wrapper-large{max-width:100%}.approval-modal-iframe-wrapper{min-height:120px}.approval-modal-image-label{font-size:.75rem}.approval-modal-nav{width:48px;height:48px;font-size:2rem}.approval-modal-nav-prev{left:.75rem}.approval-modal-nav-next{right:.75rem}.approval-modal-actions{flex-direction:column;padding:1.25rem;gap:.75rem}.approval-modal-btn{padding:1rem 1.25rem;font-size:1rem;min-height:52px}}@media(max-width:480px){.approval-modal-nav{width:40px;height:40px;font-size:1.5rem}.approval-modal-image-wrapper{max-width:220px}.approval-modal-left-column{flex-direction:column}}.approval-modal-generation-details-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background-color:#f8fafc;border-top:1px solid #e2e8f0;font-size:.8125rem;flex-wrap:wrap}.approval-modal-generation-details-footer .generation-logs-section{margin-top:0;margin-left:.75rem;border:none;background-color:transparent}.approval-modal-generation-details-footer .generation-logs-toggle{padding:.25rem .5rem;font-size:.75rem;background-color:#7c3aed1a;border-radius:4px}.approval-modal-generation-details-footer .generation-logs-content{position:absolute;bottom:100%;left:50%;transform:translate(-50%);width:300px;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 -4px 12px #00000026;margin-bottom:.5rem;z-index:100}@media(max-width:768px){.approval-modal-generation-details-footer{font-size:.75rem;padding:.375rem .75rem;gap:.375rem}}.kanban-card{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000000d}.kanban-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-1px)}.kanban-card:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.kanban-card:active{transform:translateY(0)}.kanban-card-thumbnail{position:relative;width:100%;aspect-ratio:1;border-radius:6px;overflow:hidden;background-color:#f3f4f6}.kanban-card-thumbnail img{width:100%;height:100%;object-fit:contain}.kanban-card-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#9ca3af;background-color:#f3f4f6}.kanban-card-ai-badge{position:absolute;top:4px;right:4px;padding:2px 6px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;font-size:.625rem;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.kanban-card-approved-badge{position:absolute;top:4px;left:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;font-size:.75rem;font-weight:700;border-radius:50%}.kanban-card-info{display:flex;flex-direction:column;gap:.125rem}.kanban-card-name{font-size:.8125rem;font-weight:500;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.kanban-card-sku{font-size:.6875rem;color:#6b7280;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.kanban-card-record-type{display:inline-block;padding:.125rem .375rem;font-size:.5625rem;font-weight:600;color:#7c3aed;background-color:#ede9fe;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem;width:fit-content}.kanban-card-processing{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:4px}.kanban-card-processing span{font-size:.6875rem;font-weight:600;color:#1d4ed8;text-transform:uppercase;letter-spacing:.5px}.kanban-card-spinner{width:14px;height:14px;border:2px solid #93c5fd;border-top-color:#1d4ed8;border-radius:50%;animation:kanban-spin .8s linear infinite}@keyframes kanban-spin{to{transform:rotate(360deg)}}.kanban-card-error{padding:.375rem .5rem;background-color:#fef2f2;border-radius:4px;border-left:3px solid #dc2626}.kanban-card-error-text{font-size:.6875rem;font-weight:500;color:#dc2626;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.kanban-card-actions{display:flex;align-items:center;justify-content:center;min-height:32px}.kanban-card-approval-actions{display:flex;align-items:center;gap:.5rem}.kanban-card-btn{display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000001a}.kanban-card-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 2px 6px #00000026}.kanban-card-btn:active:not(:disabled){transform:scale(.98)}.kanban-card-btn:focus{outline:none}.kanban-card-btn:disabled{opacity:.5;cursor:not-allowed}.kanban-card-btn-approve{width:32px;height:32px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:1rem}.kanban-card-btn-approve:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 3px 8px #16a34a59}.kanban-card-btn-approve:focus{box-shadow:0 0 0 3px #16a34a4d}.kanban-card-btn-reject{width:32px;height:32px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:1rem}.kanban-card-btn-reject:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 3px 8px #dc262659}.kanban-card-btn-reject:focus{box-shadow:0 0 0 3px #dc26264d}.kanban-card-btn-generate{padding:.375rem .75rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:.75rem}.kanban-card-btn-generate:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 3px 8px #2563eb59}.kanban-card-btn-generate:focus{box-shadow:0 0 0 3px #3b82f64d}.kanban-card-btn-publish{padding:.375rem .75rem;background:linear-gradient(135deg,#0891b2,#0e7490);color:#fff;font-size:.75rem}.kanban-card-btn-publish:hover:not(:disabled){background:linear-gradient(135deg,#0e7490,#155e75);box-shadow:0 3px 8px #0e749059}.kanban-card-btn-publish:focus{box-shadow:0 0 0 3px #0891b24d}.kanban-card-inline-loading{display:flex;align-items:center;justify-content:center;width:100%;height:32px;background-color:#f3f4f6;border-radius:6px}.kanban-card-inline-spinner{width:18px;height:18px;border:2.5px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:kanban-spin .6s linear infinite}.kanban-column{display:flex;flex-direction:column;min-width:280px;max-width:320px;flex:1 0 280px;height:100%;background-color:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;overflow:hidden}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0}.kanban-column-title{margin:0;font-size:.875rem;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.025em}.kanban-column-count{display:flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;font-size:.75rem;font-weight:600;color:#6b7280;background-color:#f3f4f6;border-radius:12px}.kanban-column-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:.75rem}.kanban-column-products{display:flex;flex-direction:column;gap:.5rem}.kanban-column-empty{display:flex;align-items:center;justify-content:center;height:100%;min-height:120px;padding:1.5rem}.kanban-column-empty-text{font-size:.8125rem;color:#9ca3af;font-style:italic}.kanban-column--not-generated .kanban-column-header{border-left:3px solid #9ca3af}.kanban-column--not-generated .kanban-column-count{background-color:#f3f4f6;color:#6b7280}.kanban-column--queued .kanban-column-header{border-left:3px solid #7c3aed}.kanban-column--queued .kanban-column-count{background-color:#ede9fe;color:#6d28d9}.kanban-column--processing .kanban-column-header{border-left:3px solid #3b82f6}.kanban-column--processing .kanban-column-count{background-color:#dbeafe;color:#1d4ed8}.kanban-column--awaiting-approval .kanban-column-header{border-left:3px solid #d97706}.kanban-column--awaiting-approval .kanban-column-count{background-color:#fef3c7;color:#b45309}.kanban-column--approved .kanban-column-header{border-left:3px solid #0891b2}.kanban-column--approved .kanban-column-count{background-color:#cffafe;color:#0e7490}.kanban-column--completed .kanban-column-header{border-left:3px solid #22c55e}.kanban-column--completed .kanban-column-count{background-color:#dcfce7;color:#15803d}.kanban-column--failed .kanban-column-header{border-left:3px solid #ef4444}.kanban-column--failed .kanban-column-count{background-color:#fee2e2;color:#b91c1c}.kanban-column-content::-webkit-scrollbar{width:6px}.kanban-column-content::-webkit-scrollbar-track{background:transparent}.kanban-column-content::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.kanban-column-content::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.kanban-view{display:flex;flex-direction:column;width:100%;height:calc(100vh - 200px);min-height:400px;overflow:hidden}.kanban-board{display:flex;flex-direction:row;gap:1rem;padding:1rem;height:100%;overflow-x:auto;overflow-y:hidden}.kanban-board::-webkit-scrollbar{height:8px}.kanban-board::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.kanban-board::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.kanban-board::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.kanban-board>.kanban-column{flex:0 0 280px;min-width:280px;max-width:320px}@media(max-width:1200px){.kanban-view{height:calc(100vh - 180px)}.kanban-board{padding:.75rem;gap:.75rem}.kanban-board>.kanban-column{flex:0 0 260px;min-width:260px}}@media(max-width:768px){.kanban-view{height:calc(100vh - 160px)}.kanban-board{padding:.5rem;gap:.5rem}.kanban-board>.kanban-column{flex:0 0 240px;min-width:240px}}.failure-reason-filter{position:relative;display:inline-block}.failure-reason-filter-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#374151;cursor:pointer;transition:all .15s ease}.failure-reason-filter-btn:hover:not(:disabled){border-color:#9ca3af;background:#f9fafb}.failure-reason-filter-btn:disabled{opacity:.5;cursor:not-allowed}.failure-reason-filter-btn-open{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.failure-reason-filter-btn-active{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.failure-reason-filter-icon{flex-shrink:0}.failure-reason-filter-chevron{flex-shrink:0;transition:transform .15s ease}.failure-reason-filter-chevron-open{transform:rotate(180deg)}.failure-reason-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:50;min-width:280px;max-width:400px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.failure-reason-dropdown-header{display:flex;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #e5e7eb;background:#f9fafb;border-radius:8px 8px 0 0}.failure-reason-action-btn{padding:4px 8px;background:transparent;border:none;font-size:12px;color:#3b82f6;cursor:pointer;border-radius:4px;transition:background .15s ease}.failure-reason-action-btn:hover:not(:disabled){background:#eff6ff}.failure-reason-action-btn:disabled{color:#9ca3af;cursor:not-allowed}.failure-reason-list{max-height:300px;overflow-y:auto;padding:4px 0}.failure-reason-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;transition:background .1s ease}.failure-reason-item:hover{background:#f3f4f6}.failure-reason-item-selected{background:#eff6ff}.failure-reason-item-selected:hover{background:#dbeafe}.failure-reason-checkbox{flex-shrink:0;width:16px;height:16px;cursor:pointer;accent-color:#3b82f6}.failure-reason-text{flex:1;font-size:13px;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.failure-reason-count{flex-shrink:0;padding:2px 6px;background:#e5e7eb;border-radius:10px;font-size:11px;font-weight:500;color:#6b7280}.failure-reason-item-selected .failure-reason-count{background:#bfdbfe;color:#1d4ed8}.batch-queue-button{position:relative;display:inline-block}.batch-queue-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s}.batch-queue-btn:hover:not(:disabled){background:#059669}.batch-queue-btn:disabled{opacity:.5;cursor:not-allowed}.batch-queue-btn-open{background:#059669}.batch-queue-icon{flex-shrink:0}.batch-queue-chevron{flex-shrink:0;transition:transform .2s}.batch-queue-chevron-open{transform:rotate(180deg)}.batch-queue-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:batch-queue-spin .8s linear infinite}@keyframes batch-queue-spin{to{transform:rotate(360deg)}}.batch-queue-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:160px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:100;overflow:hidden}.batch-queue-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:none;border:none;font-size:14px;color:#374151;cursor:pointer;transition:background-color .15s;text-align:left}.batch-queue-option:hover:not(:disabled){background:#f3f4f6}.batch-queue-option:disabled{opacity:.5;cursor:not-allowed}.batch-queue-option+.batch-queue-option{border-top:1px solid #f3f4f6}.batch-queue-option-size{font-weight:500}.batch-queue-option-note{font-size:12px;color:#9ca3af;margin-left:8px}.record-type-filter{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.record-type-filter-btn{padding:.5rem .75rem;background-color:#fff;border:none;font-size:.8125rem;font-weight:500;color:#6b7280;cursor:pointer;transition:background-color .15s,color .15s;white-space:nowrap}.record-type-filter-btn:not(:last-child){border-right:1px solid #d1d5db}.record-type-filter-btn:hover:not(:disabled):not(.record-type-filter-btn-active){background-color:#f3f4f6}.record-type-filter-btn-active{background-color:#3b82f6;color:#fff}.record-type-filter-btn:disabled{opacity:.5;cursor:not-allowed}.processing-logs-accordion{border:1px solid #e5e7eb;border-radius:6px;background-color:#f9fafb;overflow:hidden;margin-top:.5rem}.processing-logs-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:none;border:none;cursor:pointer;font-size:.75rem;color:#374151;text-align:left;transition:background-color .15s}.processing-logs-header:hover{background-color:#f3f4f6}.processing-logs-chevron{font-size:.625rem;color:#6b7280;flex-shrink:0}.processing-logs-title{font-weight:500;flex:1}.processing-logs-status{flex-shrink:0}.processing-logs-status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .375rem;border-radius:9999px;font-size:.625rem;font-weight:500}.processing-logs-status-processing{background-color:#dbeafe;color:#1d4ed8}.processing-logs-status-completed{background-color:#dcfce7;color:#15803d}.processing-logs-status-failed{background-color:#fee2e2;color:#dc2626}.processing-logs-spinner{width:8px;height:8px;border:1.5px solid #93c5fd;border-top-color:#1d4ed8;border-radius:50%;animation:logs-spin .6s linear infinite}@keyframes logs-spin{to{transform:rotate(360deg)}}.processing-logs-loading{font-size:.625rem;color:#9ca3af}.processing-logs-content{border-top:1px solid #e5e7eb;background-color:#1f2937;max-height:200px;overflow-y:auto}.processing-logs-error{padding:.5rem .75rem;color:#fca5a5;font-size:.75rem}.processing-logs-empty{padding:.75rem;color:#9ca3af;font-size:.75rem;text-align:center}.processing-logs-list{padding:.5rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.6875rem;line-height:1.5}.processing-logs-entry{display:flex;align-items:flex-start;gap:.5rem;padding:.125rem 0}.processing-logs-time{color:#6b7280;flex-shrink:0;min-width:70px}.processing-logs-icon{flex-shrink:0;width:12px;text-align:center}.processing-logs-message{flex:1;word-break:break-word}.processing-logs-entry-info{color:#d1d5db}.processing-logs-entry-info .processing-logs-icon{color:#60a5fa}.processing-logs-entry-success{color:#86efac}.processing-logs-entry-success .processing-logs-icon{color:#22c55e}.processing-logs-entry-warn{color:#fde68a}.processing-logs-entry-warn .processing-logs-icon{color:#f59e0b}.processing-logs-entry-error{color:#fca5a5}.processing-logs-entry-error .processing-logs-icon{color:#ef4444}.processing-logs-current-step{padding:.375rem .75rem;background-color:#374151;border-top:1px solid #4b5563;color:#60a5fa;font-size:.6875rem;font-weight:500}.processing-logs-content::-webkit-scrollbar{width:6px}.processing-logs-content::-webkit-scrollbar-track{background:#374151}.processing-logs-content::-webkit-scrollbar-thumb{background:#6b7280;border-radius:3px}.processing-logs-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.catalog-dashboard{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;max-width:1400px;margin:0 auto}.catalog-header{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.5rem}.catalog-back-link{display:inline-flex;align-items:center;gap:.25rem;color:#3b82f6;text-decoration:none;font-size:.875rem;font-weight:500;transition:color .15s}.catalog-back-link:hover{color:#2563eb;text-decoration:underline}.catalog-header-row{display:flex;justify-content:space-between;align-items:center}.catalog-header-title{display:flex;flex-direction:column;align-items:center;gap:.25rem;text-align:center}.catalog-header-title h1{margin:0;font-size:1.75rem;font-weight:600;color:#1a1a2e}.catalog-product-count{font-size:.875rem;color:#6b7280}.catalog-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.catalog-search{position:relative;flex:1;min-width:200px;max-width:400px}.catalog-search-input{width:100%;padding:.625rem 2.5rem .625rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.catalog-search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.catalog-search-input::placeholder{color:#9ca3af}.catalog-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);padding:.25rem;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:.75rem;line-height:1}.catalog-search-clear:hover{color:#6b7280}.catalog-sort{display:flex;align-items:center;gap:.5rem}.catalog-sort-label{font-size:.875rem;color:#6b7280;white-space:nowrap}.catalog-sort-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;background-color:#fff;cursor:pointer}.catalog-sort-select:focus{outline:none;border-color:#3b82f6}.catalog-sort-order{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;cursor:pointer;font-size:1rem;line-height:1;transition:background-color .15s}.catalog-sort-order:hover{background-color:#f3f4f6}.catalog-select-dropdown{position:relative}.catalog-select-all{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;font-size:.875rem;cursor:pointer;transition:background-color .15s}.catalog-select-all:hover:not(:disabled){background-color:#f3f4f6}.catalog-select-all:disabled{opacity:.5;cursor:not-allowed}.catalog-select-dropdown-menu{position:absolute;top:100%;left:0;z-index:50;min-width:180px;margin-top:4px;padding:4px 0;background-color:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.catalog-select-dropdown-item{display:block;width:100%;padding:.5rem 1rem;border:none;background:none;font-size:.875rem;text-align:left;cursor:pointer;transition:background-color .15s}.catalog-select-dropdown-item:hover{background-color:#f3f4f6}.catalog-requeue-all-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid #2563eb;border-radius:6px;background-color:#2563eb;color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s;white-space:nowrap;flex-shrink:0}.catalog-requeue-all-btn:hover:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8}.catalog-requeue-all-btn:disabled{opacity:.5;cursor:not-allowed}.catalog-requeue-icon{flex-shrink:0}.catalog-requeue-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:catalog-requeue-spin .7s linear infinite}@keyframes catalog-requeue-spin{to{transform:rotate(360deg)}}.catalog-approved-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.catalog-publish-all-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid #059669;border-radius:6px;background-color:#059669;color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s;white-space:nowrap;flex-shrink:0}.catalog-publish-all-btn:hover:not(:disabled){background-color:#047857;border-color:#047857}.catalog-publish-all-btn:disabled{opacity:.5;cursor:not-allowed}.catalog-publish-icon{flex-shrink:0}.catalog-publish-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:catalog-publish-spin .7s linear infinite}@keyframes catalog-publish-spin{to{transform:rotate(360deg)}}.catalog-failed-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.catalog-reset-stuck-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid #f59e0b;border-radius:6px;background-color:#f59e0b;color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s;white-space:nowrap;flex-shrink:0}.catalog-reset-stuck-btn:hover:not(:disabled){background-color:#d97706;border-color:#d97706}.catalog-reset-stuck-btn:disabled{opacity:.5;cursor:not-allowed}.catalog-reset-icon{flex-shrink:0}.catalog-error{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626}.catalog-error-connection{background-color:#fffbeb;border-color:#fde68a;color:#d97706}.catalog-error-content{display:flex;align-items:flex-start;gap:.75rem;flex:1}.catalog-error-icon{font-size:1.25rem;line-height:1;flex-shrink:0}.catalog-error-text{display:flex;flex-direction:column;gap:.25rem}.catalog-error-message{font-size:.875rem;font-weight:500}.catalog-error-recovery{font-size:.75rem;opacity:.8}.catalog-error-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.catalog-error-retry{padding:.375rem .75rem;background-color:#dc2626;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:background-color .15s}.catalog-error-retry:hover:not(:disabled){background-color:#b91c1c}.catalog-error-retry:disabled{opacity:.6;cursor:not-allowed}.catalog-error-connection .catalog-error-retry{background-color:#d97706}.catalog-error-connection .catalog-error-retry:hover:not(:disabled){background-color:#b45309}.catalog-error-dismiss{padding:.25rem;background:none;border:none;color:inherit;cursor:pointer;font-size:.875rem;line-height:1;opacity:.7}.catalog-error-dismiss:hover{opacity:1}.catalog-warning{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background-color:#fffbeb;border:1px solid #fde68a;border-radius:6px;color:#d97706;font-size:.875rem}.catalog-warning-icon{font-size:1rem;flex-shrink:0}.catalog-warning-message{flex:1}.catalog-error-details-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.catalog-error-details-modal{background-color:#fff;border-radius:8px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column}.catalog-error-details-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb}.catalog-error-details-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937}.catalog-error-details-close{padding:.25rem;background:none;border:none;color:#6b7280;cursor:pointer;font-size:1rem;line-height:1}.catalog-error-details-close:hover{color:#1f2937}.catalog-error-details-content{padding:1.25rem;overflow-y:auto;flex:1}.catalog-error-details-text{margin:0;padding:1rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;line-height:1.5;color:#374151;white-space:pre-wrap;word-break:break-word}.catalog-error-details-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid #e5e7eb}.catalog-error-details-copy{padding:.5rem 1rem;background-color:#fff;border:1px solid #d1d5db;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color .15s}.catalog-error-details-copy:hover{background-color:#f3f4f6}.catalog-error-details-dismiss{padding:.5rem 1rem;background-color:#1f2937;color:#fff;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color .15s}.catalog-error-details-dismiss:hover{background-color:#374151}.catalog-loading-skeleton{padding:0}.skeleton-row td{padding:.625rem .75rem}.skeleton-box{display:block;background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-checkbox{width:1rem;height:1rem}.skeleton-thumbnail{width:3rem;height:3rem;border-radius:4px}.skeleton-name{width:70%;height:.875rem}.skeleton-sku{width:5rem;height:.875rem}.skeleton-status{width:4.5rem;height:1.25rem;border-radius:9999px}.skeleton-actions{width:3.5rem;height:1.5rem}.skeleton-text{color:#9ca3af}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.catalog-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:#6b7280}.catalog-loading-spinner{width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.catalog-product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;padding:.5rem 0}.catalog-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280;text-align:center}.catalog-empty p{margin:0;font-size:1rem}.catalog-empty-hint{margin-top:.5rem!important;font-size:.875rem!important;color:#9ca3af}.catalog-pagination{display:flex;justify-content:center;align-items:center;gap:.25rem;padding:1rem 0;margin-top:auto}.pagination-btn{min-width:2rem;height:2rem;padding:0 .5rem;border:1px solid #d1d5db;border-radius:4px;background-color:#fff;font-size:.875rem;cursor:pointer;transition:background-color .15s,border-color .15s}.pagination-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn-active{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.pagination-btn-active:hover{background-color:#2563eb;border-color:#2563eb}.pagination-ellipsis{padding:0 .25rem;color:#9ca3af}@media(max-width:768px){.catalog-dashboard{padding:1rem}.catalog-header-title{flex-direction:column;gap:.25rem}.catalog-header-title h1{font-size:1.5rem}.catalog-controls{flex-direction:column;align-items:stretch}.catalog-search{max-width:none}.catalog-sort{justify-content:space-between}.catalog-product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.catalog-view-toggle{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.catalog-view-btn{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;background-color:#fff;border:none;cursor:pointer;transition:background-color .15s,color .15s;color:#6b7280}.catalog-view-btn:not(:last-child){border-right:1px solid #d1d5db}.catalog-view-btn:hover:not(.catalog-view-btn-active){background-color:#f3f4f6}.catalog-view-btn-active{background-color:#3b82f6;color:#fff}.catalog-table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px;background-color:#fff}.catalog-table{width:100%;border-collapse:collapse;font-size:.875rem}.catalog-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;white-space:nowrap}.catalog-table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;vertical-align:middle}.catalog-table tbody tr:last-child td{border-bottom:none}.catalog-table-row:hover{background-color:#f9fafb}.catalog-table-row-selected{background-color:#eff6ff}.catalog-table-row-selected:hover{background-color:#dbeafe}.catalog-table-checkbox{width:40px;text-align:center}.catalog-table-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer}.catalog-table-image{width:60px}.catalog-table-image-btn{position:relative;display:block;padding:0;background:none;border:none;cursor:pointer;width:48px;height:48px}.catalog-table-thumbnail{width:48px;height:48px;object-fit:contain;border-radius:4px;background-color:#f3f4f6}.catalog-table-no-image{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;border-radius:4px;font-size:.625rem;color:#9ca3af}.catalog-table-image-failed{width:48px;height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#fef2f2;border-radius:4px;color:#dc2626;gap:2px}.catalog-table-image-failed svg{width:20px;height:20px}.catalog-table-image-failed span{font-size:.5rem;font-weight:500}.catalog-table-image-processing{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-color:#fffc;border-radius:4px;z-index:1}.catalog-table-image-spinner{width:20px;height:20px;border:3px solid #dbeafe;border-top-color:#1d4ed8;border-radius:50%;animation:spin .8s linear infinite}.catalog-table-thumbnail-processing{opacity:.5}.catalog-table-ai-badge{position:absolute;top:-4px;right:-4px;padding:2px 4px;background-color:#8b5cf6;color:#fff;font-size:.5rem;font-weight:600;border-radius:3px}.catalog-table-approved-badge{position:absolute;bottom:-4px;left:-4px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background-color:#0891b2;color:#fff;font-size:.625rem;font-weight:700;border-radius:50%}.catalog-table-name{min-width:200px;max-width:300px}.catalog-table-name-text{display:block;color:#1f2937;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.catalog-table-sku{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.8125rem;color:#6b7280;white-space:normal;word-break:break-all;max-width:180px;min-width:100px}.catalog-table-manufacturer{color:#6b7280;white-space:nowrap}.catalog-table-status{white-space:nowrap}.catalog-table-status-badge{display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.catalog-table-status-pending,.catalog-table-status-not_generated{background-color:#f3f4f6;color:#6b7280}.catalog-table-status-queued{background-color:#ede9fe;color:#7c3aed}.catalog-table-status-processing{background-color:#dbeafe;color:#1d4ed8;display:inline-flex;align-items:center;gap:.375rem}.catalog-table-status-processing:before{content:"";display:inline-block;width:10px;height:10px;border:2px solid #93c5fd;border-top-color:#1d4ed8;border-radius:50%;animation:spin .8s linear infinite}.catalog-table-status-failed{background-color:#fee2e2;color:#dc2626}.catalog-table-status-not_in_stock{background-color:#f3f4f6;color:#6b7280}.catalog-table-status-awaiting_approval{background-color:#fef3c7;color:#d97706}.catalog-table-status-approved{background-color:#cffafe;color:#0891b2}.catalog-table-status-completed{background-color:#dcfce7;color:#15803d}.catalog-table-generated-at{white-space:nowrap;font-size:.875rem;color:#6b7280}.catalog-table-pending-upload{display:block;margin-top:.25rem;font-size:.6875rem;color:#0891b2;font-weight:500;font-style:italic}.catalog-table-failure-reason{display:block;margin-top:.25rem;font-size:.6875rem;color:#dc2626;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.catalog-table-out-of-stock-message{display:block;margin-top:.25rem;font-size:.6875rem;color:#6b7280;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help;font-style:italic}.catalog-table-price{font-weight:500;color:#374151;white-space:nowrap}.catalog-table-actions{white-space:nowrap}.catalog-table-action-btn{padding:.375rem;background:none;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .15s}.catalog-table-action-btn:hover:not(:disabled){opacity:1}.catalog-table-action-btn:disabled{opacity:.3;cursor:not-allowed}.catalog-table-action-error{color:#dc2626}.catalog-table-action-generate{padding:.375rem .75rem;background-color:#2563eb;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;opacity:1;cursor:pointer;transition:background-color .15s}.catalog-table-action-generate:hover{background-color:#1d4ed8}.catalog-table-action-generate:disabled{background-color:#93c5fd;cursor:not-allowed}.catalog-table-action-publish{padding:.375rem .75rem;background-color:#0891b2;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;opacity:1;cursor:pointer;transition:background-color .15s}.catalog-table-action-publish:hover{background-color:#0e7490}.catalog-table-action-retry{padding:.375rem .75rem;background-color:#6b7280;color:#fff;border:none;border-radius:4px;font-size:.8125rem;font-weight:500;opacity:1;cursor:pointer;transition:background-color .15s}.catalog-table-action-retry:hover{background-color:#4b5563}@media(max-width:768px){.catalog-view-toggle,.catalog-table-manufacturer,.catalog-table-price{display:none}.catalog-table-name{min-width:150px;max-width:200px}.catalog-table-name-text{max-width:180px}}.queue-processor-controls{display:flex;align-items:center;gap:1rem}.queue-processor-status{display:flex;align-items:center}.queue-processor-indicator{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.queue-processor-running{background-color:#dcfce7;color:#15803d}.queue-processor-paused{background-color:#fef3c7;color:#d97706}.queue-processor-stopped{background-color:#f3f4f6;color:#6b7280}.queue-processor-pulse{position:relative;width:8px;height:8px;background-color:#22c55e;border-radius:50%}.queue-processor-pulse:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background-color:#22c55e;opacity:.4;animation:pulse-ring 1.5s ease-out infinite}.queue-processor-pulse:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background-color:#22c55e;animation:pulse-dot 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(1);opacity:.4}to{transform:scale(2.5);opacity:0}}@keyframes pulse-dot{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.queue-processor-stats{display:flex;align-items:center;gap:.75rem}.queue-stat{font-size:.75rem;color:#6b7280;font-weight:500}.queue-stat-failed{color:#dc2626}.queue-stat-active{color:#3b82f6}.queue-processor-btn{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s,transform .1s;min-width:80px}.queue-processor-btn:hover:not(:disabled){transform:translateY(-1px)}.queue-processor-btn:active:not(:disabled){transform:translateY(0)}.queue-processor-btn:disabled{opacity:.6;cursor:not-allowed}.queue-processor-btn-start{background-color:#22c55e;color:#fff}.queue-processor-btn-start:hover:not(:disabled){background-color:#16a34a}.queue-processor-btn-stop{background-color:#ef4444;color:#fff}.queue-processor-btn-stop:hover:not(:disabled){background-color:#dc2626}.queue-btn-loading{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:768px){.queue-processor-controls{flex-wrap:wrap;gap:.5rem}.queue-processor-stats{order:3;width:100%;justify-content:center}}.catalog-table-row-processing{background-color:#eff6ff}.catalog-table-row-processing:hover{background-color:#dbeafe}.catalog-table-logs-row,.catalog-table-logs-row:hover{background-color:#f8fafc}.catalog-table-logs-cell{padding:0!important;border-bottom:1px solid #e5e7eb}.catalog-table-logs-cell .processing-logs-accordion{border:none;border-radius:0;margin:0}.catalog-table-ai-image{width:80px}.catalog-table-ai-btn{position:relative;display:block;padding:0;background:none;border:2px solid transparent;border-radius:8px;cursor:default;width:48px;height:48px;transition:all .2s ease}.catalog-table-ai-btn-clickable{cursor:pointer}.catalog-table-ai-btn-clickable:hover{transform:scale(1.05)}.catalog-table-ai-btn-clickable:focus{outline:none}.catalog-table-ai-btn-clickable:active{transform:scale(.98)}.catalog-table-ai-processing{display:flex;flex-direction:column;align-items:center;justify-content:center;width:48px;height:48px;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:8px;gap:4px}.catalog-table-ai-spinner{width:16px;height:16px;border:2.5px solid #93c5fd;border-top-color:#1d4ed8;border-radius:50%;animation:spin .8s linear infinite}.catalog-table-ai-processing span{font-size:.5rem;font-weight:600;color:#1d4ed8;text-transform:uppercase;letter-spacing:.5px}.catalog-table-ai-pending{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background-color:#f3f4f6;border-radius:8px;border:1px dashed #d1d5db}.catalog-table-ai-pending span{font-size:.5rem;font-weight:600;color:#9ca3af;text-transform:uppercase}.catalog-table-approval-actions{display:inline-flex;align-items:center;gap:6px;margin-right:8px}.catalog-table-inline-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:6px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000001a}.catalog-table-inline-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 2px 6px #00000026}.catalog-table-inline-btn:active:not(:disabled){transform:scale(.95);box-shadow:0 1px 2px #0000001a}.catalog-table-inline-btn:focus{outline:none}.catalog-table-inline-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.catalog-table-inline-approve{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.catalog-table-inline-approve:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 3px 8px #16a34a59}.catalog-table-inline-approve:focus{box-shadow:0 0 0 3px #16a34a4d}.catalog-table-inline-reject{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.catalog-table-inline-reject:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 3px 8px #dc262659}.catalog-table-inline-reject:focus{box-shadow:0 0 0 3px #dc26264d}.catalog-table-inline-loading{display:flex;align-items:center;justify-content:center;width:66px;height:30px;background-color:#f3f4f6;border-radius:6px}.catalog-table-inline-spinner{width:18px;height:18px;border:2.5px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:inline-spin .6s linear infinite}@keyframes inline-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.catalog-table-ai-image{display:none}.catalog-table-approval-actions{flex-direction:column;gap:4px}.catalog-table-inline-btn{width:26px;height:26px;font-size:.8rem}.catalog-table-inline-loading{width:56px;height:26px}.catalog-table-inline-spinner{width:16px;height:16px}}.catalog-ai-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.catalog-ai-preview-modal{background-color:#1a1a2e;border-radius:12px;box-shadow:0 25px 50px -12px #00000080;max-width:90vw;max-height:90vh;width:auto;display:flex;flex-direction:column;overflow:hidden}.catalog-ai-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background-color:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1)}.catalog-ai-preview-info{display:flex;flex-direction:column;gap:.25rem}.catalog-ai-preview-info h3{margin:0;font-size:1.125rem;font-weight:600;color:#fff}.catalog-ai-preview-sku{font-size:.8125rem;color:#fff9;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.catalog-ai-preview-actions{display:flex;align-items:center;gap:.75rem}.catalog-ai-preview-badge{padding:.375rem .75rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;font-size:.75rem;font-weight:600;border-radius:9999px;text-transform:uppercase;letter-spacing:.5px}.catalog-ai-preview-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background-color:#ffffff1a;border:none;border-radius:8px;color:#fff;font-size:1.25rem;cursor:pointer;transition:background-color .15s}.catalog-ai-preview-close:hover{background-color:#fff3}.catalog-ai-preview-content{display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:auto;flex:1}.catalog-ai-preview-image{max-width:100%;max-height:calc(90vh - 120px);object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #0000004d}@media(max-width:768px){.catalog-ai-preview-modal{max-width:95vw;max-height:95vh}.catalog-ai-preview-header{padding:.75rem 1rem}.catalog-ai-preview-info h3{font-size:1rem}.catalog-ai-preview-content{padding:1rem}.catalog-ai-preview-image{max-height:calc(95vh - 100px)}}.catalog-not-generated-controls,.catalog-queued-controls{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.catalog-unqueue-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.375rem;cursor:pointer;transition:all .15s ease;white-space:nowrap}.catalog-unqueue-btn:hover:not(:disabled){background-color:#fee2e2;border-color:#fca5a5}.catalog-unqueue-btn:disabled{opacity:.5;cursor:not-allowed}.catalog-unqueue-icon{flex-shrink:0}.catalog-unqueue-spinner{width:14px;height:14px;border:2px solid #fecaca;border-top-color:#dc2626;border-radius:50%;animation:spin .8s linear infinite}.catalog-table-row{transition:background-color .3s ease,opacity .3s ease,transform .3s ease}.catalog-table-row-transitioning{position:relative}.catalog-table-row-transition-in{animation:row-highlight-pulse .5s ease-out}@keyframes row-highlight-pulse{0%{background-color:#fef3c7;transform:scale(1.005)}50%{background-color:#fef9c3}to{background-color:transparent;transform:scale(1)}}.catalog-table-status-badge{transition:background-color .3s ease,color .3s ease,transform .2s ease}.catalog-table-row-transitioning .catalog-table-status-badge{animation:status-badge-pulse .5s ease-out}@keyframes status-badge-pulse{0%{transform:scale(1.1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.catalog-table-ai-btn img,.catalog-table-ai-processing,.catalog-table-ai-pending{transition:opacity .3s ease,transform .2s ease}.catalog-table-row-processing{animation:processing-row-pulse 2s ease-in-out infinite}@keyframes processing-row-pulse{0%,to{background-color:#eff6ff}50%{background-color:#dbeafe}}.catalog-table-actions>*{transition:opacity .2s ease,transform .2s ease}.catalog-table-inline-loading{animation:fade-in .2s ease-out}@keyframes fade-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.catalog-table-thumbnail{transition:opacity .3s ease,transform .2s ease}.catalog-table-image-btn:hover .catalog-table-thumbnail{transform:scale(1.05)}.catalog-table-row[data-status=failed]{animation:error-flash .5s ease-out}@keyframes error-flash{0%{background-color:#fee2e2}to{background-color:transparent}}.catalog-inline-reject-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.catalog-inline-reject-modal{background-color:#1a1a2e;border-radius:12px;box-shadow:0 25px 50px -12px #00000080;max-width:480px;width:100%;overflow:hidden}@media(max-width:768px){.catalog-inline-reject-modal{max-width:95vw;margin:0 1rem}}.batch-reject-header{padding:1.25rem 1.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.1)}.batch-reject-header h3{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:#fff}.batch-reject-subtitle{margin:0;font-size:.875rem;color:#fff9}.composition-test-page{max-width:1600px;margin:0 auto;padding:20px}.test-page-header{margin-bottom:30px}.back-link{color:#666;text-decoration:none;font-size:14px}.back-link:hover{color:#333}.test-page-header h1{margin:10px 0 5px;font-size:28px}.test-page-header .subtitle{color:#666;margin:0}.product-input-section{background:#f8f9fa;padding:20px;border-radius:8px;margin-bottom:30px}.product-input-section h2{margin:0 0 15px;font-size:18px}.url-input-row{display:flex;gap:10px}.product-url-input{flex:1;padding:12px 16px;border:1px solid #ddd;border-radius:6px;font-size:14px}.add-product-btn{padding:12px 24px;background:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.add-product-btn:disabled{background:#ccc;cursor:not-allowed}.error-message{color:#dc3545;margin-top:10px;font-size:14px}.available-products-list{margin-top:20px}.available-products-list h3{font-size:14px;color:#666;margin-bottom:10px}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.product-card{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border:1px solid #ddd;border-radius:6px}.product-card img{width:50px;height:50px;object-fit:contain;border-radius:4px}.product-card .product-info{flex:1;display:flex;flex-direction:column;gap:2px}.product-card .product-name{font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.product-card .product-sku{font-size:11px;color:#666}.product-card .product-dims{font-size:10px;color:#28a745}.product-card .product-dims.missing{color:#dc3545}.product-card .remove-btn{width:24px;height:24px;border:none;background:#f0f0f0;border-radius:50%;cursor:pointer;font-size:16px;color:#666}.product-card .remove-btn:hover{background:#dc3545;color:#fff}.composition-layout{display:grid;grid-template-columns:1fr 1fr;gap:30px}.composer-section,.preview-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px}@media(max-width:1200px){.composition-layout{grid-template-columns:1fr}}.unified-processing-status{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;margin:16px 0}.unified-processing-status--complete{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;text-align:center;padding:24px}.processing-complete-icon{font-size:48px;margin-bottom:12px}.processing-complete-message{font-size:18px;font-weight:600;color:#166534}.unified-processing-status--error{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;text-align:center;padding:24px}.processing-error-icon{font-size:48px;margin-bottom:12px}.processing-error-message{font-size:16px;color:#991b1b}.processing-fallback-notice{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;padding:8px 16px;background:#fff9;border-radius:6px;font-size:13px;color:#6b7280}.fallback-icon{font-size:14px}.processing-steps-list{display:flex;flex-direction:column;gap:12px}.processing-step-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;transition:all .2s ease}.processing-step-item.complete{background:#f0fdf4}.processing-step-item.current{background:#eff6ff;border:1px solid #93c5fd}.processing-step-item.pending{opacity:.5}.step-indicator{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:18px}.processing-step-item.complete .step-indicator{background:#22c55e;color:#fff}.processing-step-item.current .step-indicator{background:#3b82f6;color:#fff;animation:pulse-indicator 1.5s ease-in-out infinite}.processing-step-item.pending .step-indicator{background:#e5e7eb;color:#9ca3af}@keyframes pulse-indicator{0%,to{transform:scale(1);box-shadow:0 0 #3b82f666}50%{transform:scale(1.05);box-shadow:0 0 0 8px #3b82f600}}.step-check{font-weight:700}.step-content{flex:1;min-width:0}.step-label{font-weight:600;font-size:15px;color:#1f2937;margin-bottom:4px}.processing-step-item.complete .step-label{color:#166534}.processing-step-item.current .step-label{color:#1e40af}.step-description{font-size:13px;color:#6b7280;margin-bottom:8px}.step-progress-bar{height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.step-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;transition:width .3s ease}.processing-current-step{text-align:center}.current-step-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px}.current-step-icon{font-size:28px;animation:bounce-icon 1s ease-in-out infinite}@keyframes bounce-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.current-step-label{font-size:20px;font-weight:600;color:#1f2937}.current-step-description{font-size:14px;color:#6b7280;margin-bottom:16px}.current-step-progress{display:flex;align-items:center;gap:12px}.progress-bar-container{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:4px;transition:width .3s ease;animation:shimmer 2s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.progress-percentage{font-size:14px;font-weight:600;color:#3b82f6;min-width:45px;text-align:right}.processing-summary{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin:16px 0}.summary-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.summary-icon{font-size:18px}.summary-title{font-weight:600;font-size:15px;color:#1f2937;flex:1}.summary-count{font-size:13px;color:#6b7280;background:#e5e7eb;padding:2px 8px;border-radius:12px}.summary-list{display:flex;flex-direction:column;gap:8px}.summary-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;font-size:14px}.summary-item.applied{background:#f0fdf4;color:#166534}.summary-item.skipped{background:#f3f4f6;color:#9ca3af}.item-status{font-weight:700;width:20px;text-align:center}.summary-item.applied .item-status{color:#22c55e}.item-label{flex:1}.item-fallback{font-size:12px;color:#f59e0b;font-style:italic}@media(max-width:480px){.unified-processing-status{padding:16px}.processing-step-item{padding:10px}.step-indicator{width:32px;height:32px;font-size:16px}.current-step-label{font-size:18px}}.url-input-form{width:100%;max-width:800px}.url-input-container{display:flex;flex-direction:column;gap:.5rem}.url-input-label{font-size:.875rem;font-weight:600;color:#000}.url-input-wrapper{display:flex;gap:.75rem;align-items:stretch}.url-input{flex:1;padding:.75rem 1rem;font-size:1rem;border:2px solid #000000;border-radius:8px;background-color:#fff;color:#000;transition:border-color .2s}.url-input::placeholder{color:#666;font-style:italic}.url-input:focus{outline:none;box-shadow:0 0 0 1px #000}.url-input:disabled{opacity:.6;cursor:not-allowed}.url-input-error{border-width:3px;border-style:dashed}.url-submit-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#000;background-color:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;transition:background-color .2s;white-space:nowrap}.url-submit-button:hover:not(:disabled){background-color:#f0f0f0}.url-submit-button:disabled{opacity:.6;cursor:not-allowed}.url-error-message{font-size:.875rem;color:#000;margin-top:.25rem;font-weight:500}.loading-indicator{display:flex;align-items:center;gap:.5rem}.loading-spinner{width:16px;height:16px;border:2px solid #cccccc;border-top-color:#000;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:600px){.url-input-wrapper{flex-direction:column}.url-submit-button{width:100%}}.url-options{margin-top:.5rem}.url-option-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem}.url-option-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#000000}.url-option-text{display:flex;align-items:center;gap:.5rem;color:#333}.url-option-hint{font-size:.75rem;color:#666;font-style:italic}.auto-process-section{margin-top:1.5rem;padding:1rem;background:#f8f8f8;border:1px solid #e0e0e0;border-radius:8px;text-align:center}.auto-process-hint{margin:0 0 .75rem;font-size:.875rem;color:#666}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#000;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-width:320px;min-height:100vh;background:#fff;color:#000}.app{max-width:1280px;margin:0 auto;padding:2rem}h1{font-size:2.5em;line-height:1.1;margin-bottom:1rem;color:#000;font-weight:700}h2,h3{color:#000;font-weight:600}.home{display:flex;flex-direction:column;align-items:center}.subtitle{color:#000;margin-bottom:2rem;text-align:center;font-style:italic}.error-message{margin-top:1rem;padding:.75rem 1rem;background-color:#fff;border:2px solid #000000;border-radius:8px;color:#000;font-size:.875rem;max-width:800px;width:100%;text-align:center;font-weight:500}.phase-cta{margin-top:2rem;padding:1.5rem;background:#fff;border-radius:8px;text-align:center;border:1px solid #000000}.phase-cta p{margin-bottom:1rem;color:#000}.cta-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#000;background:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;transition:background .2s}.cta-button:hover:not(:disabled){background:#f0f0f0}.cta-button:disabled{opacity:.5;cursor:not-allowed}.multi-view-phase{width:100%;max-width:1000px}.multi-view-phase h2{margin-bottom:.5rem}.multi-view-phase>p{color:#666;margin-bottom:1.5rem}.background-phase{width:100%;max-width:800px}.background-phase h2{margin-bottom:.5rem}.background-phase>p{color:#000;margin-bottom:1.5rem}.background-upload-section{background:#fff;border:2px dashed #000000;border-radius:12px;padding:2rem;text-align:center}.upload-background-btn{padding:1rem 2rem;font-size:1.1rem;font-weight:500;color:#000;background:#fff;border:2px solid #000000;border-radius:8px;cursor:pointer;transition:background .2s}.upload-background-btn:hover{background:#f0f0f0}.uploaded-background-preview{margin-top:1.5rem}.uploaded-background-preview p{color:#000;margin-bottom:.5rem}.uploaded-background-preview img{max-width:100%;max-height:200px;border-radius:8px;border:1px solid #000000}.composite-preview{margin-top:2rem;background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #000000}.composite-preview h3{margin-bottom:1rem;color:#000}.preview-images{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.preview-item{text-align:center}.preview-item p{color:#000;margin-bottom:.5rem;font-size:.875rem}.preview-item img{max-width:100%;max-height:250px;border-radius:8px;border:1px solid #000000}@media(max-width:600px){.preview-images{grid-template-columns:1fr}}.background-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.background-option{position:relative;background:#fff;border:2px solid #000000;border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s}.background-option:hover{background:#f0f0f0}.background-option.selected{border-width:3px;background:#f0f0f0}.option-preview{height:120px;border-radius:8px;overflow:hidden;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center;border:1px solid #000000}.studio-bg-preview{width:100%;height:100%;object-fit:cover}.custom-preview{background:#f5f5f5;border:2px dashed #000000}.custom-preview img{width:100%;height:100%;object-fit:cover}.upload-icon{font-size:2rem}.option-label{display:flex;flex-direction:column;gap:.25rem}.option-name{font-weight:600;color:#000}.option-desc{font-size:.8rem;color:#000;font-style:italic}.selected-check{position:absolute;top:.75rem;right:.75rem;width:24px;height:24px;background:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;color:#fff}@media(max-width:500px){.background-options{grid-template-columns:1fr}}.composite-container{position:relative;width:100%;max-width:500px;margin:0 auto;aspect-ratio:1 / 1;border-radius:8px;overflow:hidden;border:1px solid #000000}.composite-background{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.composite-product{position:absolute;bottom:5%;left:50%;transform:translate(-50%);max-width:85%;max-height:85%;object-fit:contain}.preview-note{color:#000;font-size:.875rem;margin-bottom:1rem;text-align:center;font-style:italic}.bg-removal-progress{text-align:center;padding:2rem}.bg-removal-progress p{color:#000;margin-bottom:1rem}.progress-bar{width:100%;max-width:400px;height:8px;background:#e0e0e0;border-radius:4px;margin:0 auto .5rem;overflow:hidden;border:1px solid #000000}.progress-fill{height:100%;background:#000;border-radius:4px;transition:width .3s ease}.progress-text{color:#000;font-size:.875rem}.image-selection-phase{width:100%;max-width:900px}.image-selection-phase h2{margin-bottom:.5rem;color:#000}.product-info{color:#000;font-size:.9rem;margin-bottom:1rem;font-style:italic}.product-dimensions{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem .75rem;background-color:#f5f5f5;border:1px solid #000000;border-radius:6px;font-size:.875rem}.product-dimensions.missing{background-color:#fff8e6;border-color:#d4a800}.dimensions-label{color:#333;font-weight:500}.dimensions-value{color:#000;font-family:monospace}.product-dimensions.missing .dimensions-value{color:#8a6d00;font-style:italic;font-family:inherit}.dimensions-source{color:#666;font-size:.75rem}.selection-prompt{color:#000;margin-bottom:1rem}.image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.gallery-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid #000000;background:#fff;transition:all .2s}.gallery-item:hover{transform:scale(1.02)}.gallery-item.selected{border-width:3px}.gallery-item img{width:100%;height:100%;object-fit:contain;background:#fff}.gallery-item .selected-badge{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px}.gallery-item .image-label{position:absolute;bottom:0;left:0;right:0;padding:4px 8px;background:#fff;color:#000;font-size:.75rem;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;border-top:1px solid #000000}.selected-image-preview{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;border:1px solid #000000}.selected-image-preview h3{margin-bottom:1rem;color:#000}.selected-image-preview img{max-width:100%;max-height:400px;border-radius:8px;background:#fff;border:1px solid #000000}.lighting-phase{width:100%;max-width:600px}.lighting-phase h2{margin-bottom:.5rem}.lighting-phase>p{color:#000;margin-bottom:1.5rem}.final-result{margin-bottom:2rem}.download-section{margin-top:1.5rem;padding:1.5rem;background:#fff;border-radius:12px;text-align:center;border:1px solid #000000}.download-section h3{margin-bottom:.5rem;color:#000}.download-section p{color:#000;font-size:.9rem;margin-bottom:1rem}.download-btn{background:#fff;border:2px solid #000000;color:#000;font-weight:600}.download-btn:hover:not(:disabled){background:#f0f0f0}.cta-button.secondary{background:#fff;border:1px solid #000000;color:#000}.cta-button.secondary:hover:not(:disabled){background:#f0f0f0}.loading-state{padding:3rem;text-align:center;background:#fff;border-radius:12px;margin-bottom:1.5rem;border:1px solid #000000}.loading-state p{color:#000}.lighting-content{width:100%}.comparison-section{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}@media(min-width:800px){.comparison-section{grid-template-columns:1fr 1fr}}.comparison-item{text-align:center}.comparison-item h3{margin-bottom:1rem;color:#000;font-size:1rem}.integrated-result{width:100%;height:100%;object-fit:contain}.integration-controls{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;border:1px solid #000000}.integration-info{color:#000;margin-bottom:1rem}.ai-enhance-btn{background:#fff;border:2px solid #000000;color:#000;font-weight:600}.ai-enhance-btn:hover:not(:disabled){background:#f0f0f0}.integration-progress{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem}.spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#000;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.progress-note{color:#000;font-size:.875rem;font-style:italic}.integration-error{color:#000;display:flex;flex-direction:column;align-items:center;gap:1rem;font-weight:500}.integration-success{display:flex;flex-direction:column;align-items:center;gap:1rem;color:#000;font-weight:500}.integration-success .fallback-notice{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff3e0;border:1px solid #ffcc80;border-radius:6px;font-size:13px;color:#e65100;font-weight:400}.integration-success .fallback-icon{font-size:14px;flex-shrink:0}.download-options{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.ai-download{background:#fff;border:2px solid #000000;color:#000;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-weight:600}.ai-download:hover{background:#f0f0f0}.model-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;justify-content:center}.model-selector label{color:#000;font-weight:500}.model-selector select{padding:.5rem 1rem;border-radius:8px;border:2px solid #000000;background:#fff;color:#000;font-size:.9rem;cursor:pointer;min-width:220px}.model-selector select:focus{outline:none}.model-selector select option{background:#fff;color:#000}.composition-phase{width:100%;max-width:700px;text-align:center}.composition-phase h2{margin-bottom:.5rem;font-size:1.75rem}.composition-phase>p{color:#000;margin-bottom:2rem}.final-image-display{margin-bottom:2rem}.composite-container.large{max-width:600px;margin:0 auto}.final-actions{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:2rem;border:1px solid #000000}.final-actions h3{margin-bottom:1rem;color:#000}.shared-backgrounds-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #000000}.shared-backgrounds-section h3{margin-bottom:.25rem;color:#000;font-size:1rem}.section-desc{color:#000;font-size:.85rem;margin-bottom:1rem;font-style:italic}.shared-backgrounds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem}.shared-bg-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid #000000;transition:all .2s}.shared-bg-item:hover{transform:scale(1.02)}.shared-bg-item.selected{border-width:3px}.shared-bg-item img{width:100%;height:100%;object-fit:cover}.shared-bg-item .bg-name{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:#fff;color:#000;font-size:.7rem;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;border-top:1px solid #000000}.shared-bg-item .selected-badge{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px}.loading-text{color:#000;font-size:.9rem;text-align:center;padding:1rem;font-style:italic}.final-image-container{width:100%;max-width:600px;margin:0 auto;border-radius:8px;overflow:hidden;border:1px solid #000000}.final-image{width:100%;height:auto;display:block}.home-header{width:100%;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.home-header .header-content{text-align:left}.home-header h1{margin-bottom:.5rem}.home-header .subtitle{margin-bottom:0;text-align:left}.header-nav{display:flex;gap:.75rem;align-items:center}.nav-link{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#fff;background:#2563eb;border:2px solid #2563eb;border-radius:8px;text-decoration:none;transition:background .2s,border-color .2s;white-space:nowrap}.nav-link:hover{background:#1d4ed8;border-color:#1d4ed8}.admin-link{padding:.5rem 1rem;font-size:.9rem;font-weight:500;color:#000;background:#fff;border:2px solid #000000;border-radius:8px;text-decoration:none;transition:background .2s;white-space:nowrap}.admin-link:hover{background:#f0f0f0}@media(max-width:600px){.home-header{flex-direction:column;align-items:center;gap:1rem}.home-header .header-content,.home-header .subtitle{text-align:center}.header-nav{flex-direction:column;width:100%}.nav-link,.admin-link{width:100%;text-align:center}}.system-analysis-promo{margin:1.5rem 0;padding:1.25rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9;border-radius:12px}.promo-content{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.promo-icon{font-size:2rem;flex-shrink:0}.promo-text{flex:1;min-width:200px}.promo-text h3{margin:0 0 .25rem;font-size:1.1rem;font-weight:600;color:#0c4a6e}.promo-text p{margin:0;font-size:.9rem;color:#0369a1}.promo-button{padding:.75rem 1.25rem;background:#0ea5e9;color:#fff;font-size:.9rem;font-weight:600;text-decoration:none;border-radius:8px;transition:background .2s;white-space:nowrap}.promo-button:hover{background:#0284c7}@media(max-width:600px){.promo-content{flex-direction:column;text-align:center}.promo-button{width:100%;text-align:center}}
