/**
 * Bulk Enhancement Page Styles
 *
 * Extends the AISales design system for the batch processing feature.
 * Uses CSS custom properties defined in admin.css for consistency.
 *
 * @package AISales_Sales_Manager
 */

/* ==========================================================================
   BATCH PAGE LAYOUT
   ========================================================================== */

.aisales-batch-wrap {
  max-width: 1200px;
}

/* Page Header */
.aisales-batch-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--aisales-space-6);
  padding-bottom: var(--aisales-space-4);
  border-bottom: 1px solid var(--aisales-border-light);
}

.aisales-batch-header__left {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-1);
}

.aisales-batch-title {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  font-size: var(--aisales-font-xl);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

.aisales-batch-title .dashicons {
  color: var(--aisales-primary);
  font-size: 24px;
  width: 24px;
  height: 24px;
}

.aisales-batch-subtitle {
  font-size: var(--aisales-font-base);
  color: var(--aisales-text-secondary);
}

.aisales-batch-header__right {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-4);
}

/* Balance Indicator */
.aisales-balance-indicator {
  display: inline-flex;
  align-items: center;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-2) var(--aisales-space-4);
  background: var(--aisales-bg-subtle);
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-full);
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-medium);
  color: var(--aisales-text-secondary);
}

.aisales-balance-indicator .dashicons {
  color: var(--aisales-success);
  font-size: 16px;
  width: 16px;
  height: 16px;
}

.aisales-balance-indicator #aisales-balance-display {
  font-weight: var(--aisales-font-weight-bold);
  color: var(--aisales-text-primary);
}

/* ==========================================================================
   STEP INDICATOR
   ========================================================================== */

.aisales-batch-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: var(--aisales-space-6);
  padding: var(--aisales-space-4);
  background: var(--aisales-bg-white);
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
}

.aisales-batch-step {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-2) var(--aisales-space-3);
  cursor: default;
  transition: all var(--aisales-transition-fast);
}

.aisales-batch-step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: var(--aisales-bg-muted);
  border: 2px solid var(--aisales-border);
  border-radius: 50%;
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-muted);
  transition: all var(--aisales-transition-fast);
}

.aisales-batch-step__label {
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-medium);
  color: var(--aisales-text-muted);
  transition: color var(--aisales-transition-fast);
}

.aisales-batch-step__connector {
  width: 40px;
  height: 2px;
  background: var(--aisales-border-light);
  transition: background var(--aisales-transition-fast);
}

/* Active step */
.aisales-batch-step--active .aisales-batch-step__number {
  background: var(--aisales-primary);
  border-color: var(--aisales-primary);
  color: var(--aisales-text-inverse);
}

.aisales-batch-step--active .aisales-batch-step__label {
  color: var(--aisales-primary);
}

/* Completed step */
.aisales-batch-step--completed .aisales-batch-step__number {
  background: var(--aisales-success);
  border-color: var(--aisales-success);
  color: transparent;
  font-size: 0;
}

.aisales-batch-step--completed .aisales-batch-step__number::after {
  content: '\f147';
  font-family: dashicons;
  font-size: 16px;
  color: var(--aisales-text-inverse);
}

.aisales-batch-step--completed .aisales-batch-step__label {
  color: var(--aisales-success);
}

.aisales-batch-step--completed + .aisales-batch-step__connector {
  background: var(--aisales-success);
}

/* ==========================================================================
   CONTENT PANELS
   ========================================================================== */

.aisales-batch-content {
  position: relative;
}

.aisales-batch-panel {
  animation: aisales-fade-in var(--aisales-duration-normal) var(--aisales-ease-out);
}

/* ==========================================================================
   STEP 1: PRODUCT SELECTION
   ========================================================================== */

.aisales-batch-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--aisales-space-3);
  margin-bottom: var(--aisales-space-5);
  padding-bottom: var(--aisales-space-4);
  border-bottom: 1px solid var(--aisales-border-lighter);
}

.aisales-batch-filter {
  flex: 1 1 200px;
  max-width: 300px;
}

.aisales-batch-filter .aisales-input,
.aisales-batch-filter .aisales-select {
  width: 100%;
}

.aisales-batch-filter-actions {
  display: flex;
  gap: var(--aisales-space-2);
  margin-left: auto;
}

/* Selected count badge */
.aisales-selected-count {
  display: inline-flex;
  align-items: center;
  gap: var(--aisales-space-1);
  padding: var(--aisales-space-1) var(--aisales-space-3);
  background: var(--aisales-primary-light);
  color: var(--aisales-primary);
  border-radius: var(--aisales-radius-full);
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-medium);
}

/* Products Grid */
.aisales-batch-products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--aisales-space-4);
  max-height: 500px;
  overflow-y: auto;
  padding: var(--aisales-space-2);
  margin: calc(-1 * var(--aisales-space-2));
}

.aisales-batch-products__loading {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-8);
  color: var(--aisales-text-secondary);
}

.aisales-batch-products__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--aisales-space-8);
  color: var(--aisales-text-muted);
}

/* Product Card */
.aisales-product-card {
  display: flex;
  gap: var(--aisales-space-3);
  padding: var(--aisales-space-3);
  background: var(--aisales-bg-white);
  border: 2px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
  cursor: pointer;
  transition: all var(--aisales-transition-fast);
}

.aisales-product-card:hover {
  border-color: var(--aisales-border);
  box-shadow: var(--aisales-shadow-sm);
}

.aisales-product-card--selected {
  border-color: var(--aisales-primary);
  background: var(--aisales-primary-light);
}

.aisales-product-card__checkbox {
  flex-shrink: 0;
  padding-top: 2px;
}

.aisales-product-card__checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.aisales-product-card__image {
  flex-shrink: 0;
  width: 60px;
  height: 60px;
  border-radius: var(--aisales-radius-sm);
  overflow: hidden;
  background: var(--aisales-bg-muted);
}

.aisales-product-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.aisales-product-card__content {
  flex: 1;
  min-width: 0;
}

.aisales-product-card__title {
  font-size: var(--aisales-font-base);
  font-weight: var(--aisales-font-weight-medium);
  color: var(--aisales-text-primary);
  margin-bottom: var(--aisales-space-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.aisales-product-card__meta {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  margin-bottom: var(--aisales-space-1);
}

.aisales-product-card__price {
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

.aisales-product-card__status {
  font-size: var(--aisales-font-xs);
  padding: 1px var(--aisales-space-2);
  border-radius: var(--aisales-radius-sm);
  text-transform: capitalize;
}

.aisales-product-card__status--publish {
  background: var(--aisales-success-light);
  color: var(--aisales-success);
}

.aisales-product-card__status--draft {
  background: var(--aisales-warning-light);
  color: var(--aisales-warning-hover);
}

.aisales-product-card__status--pending {
  background: var(--aisales-info-light);
  color: var(--aisales-info-hover);
}

.aisales-product-card__categories {
  font-size: var(--aisales-font-xs);
  color: var(--aisales-text-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ==========================================================================
   STEP 2: CONFIGURATION
   ========================================================================== */

.aisales-batch-config-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--aisales-space-5);
}

/* Enhancement Options */
.aisales-enhancement-options {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-3);
}

.aisales-enhancement-option {
  display: flex;
  align-items: flex-start;
  gap: var(--aisales-space-3);
  padding: var(--aisales-space-3);
  background: var(--aisales-bg-subtle);
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
  cursor: pointer;
  transition: all var(--aisales-transition-fast);
}

.aisales-enhancement-option:hover {
  background: var(--aisales-bg-muted);
}

.aisales-enhancement-option:has(input:checked) {
  background: var(--aisales-primary-light);
  border-color: var(--aisales-primary);
}

.aisales-enhancement-option input[type="checkbox"] {
  margin-top: 4px;
  flex-shrink: 0;
}

.aisales-enhancement-option__content {
  display: flex;
  gap: var(--aisales-space-3);
  flex: 1;
}

.aisales-enhancement-option__icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--aisales-bg-white);
  border-radius: var(--aisales-radius-md);
}

.aisales-enhancement-option__icon .dashicons {
  font-size: 16px;
  width: 16px;
  height: 16px;
  color: var(--aisales-primary);
}

.aisales-enhancement-option__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.aisales-enhancement-option__info strong {
  font-size: var(--aisales-font-base);
  color: var(--aisales-text-primary);
}

.aisales-enhancement-option__info span {
  font-size: var(--aisales-font-xs);
  color: var(--aisales-text-muted);
}

/* Token Estimate */
.aisales-token-estimate {
  margin-top: var(--aisales-space-5);
  padding: var(--aisales-space-4);
  background: var(--aisales-bg-subtle);
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
}

.aisales-token-estimate__header {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  margin-bottom: var(--aisales-space-3);
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

.aisales-token-estimate__header .dashicons {
  color: var(--aisales-primary);
}

.aisales-token-estimate__body {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-2);
}

.aisales-token-estimate__row {
  display: flex;
  justify-content: space-between;
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-secondary);
}

.aisales-token-estimate__row--total {
  padding-top: var(--aisales-space-2);
  border-top: 1px solid var(--aisales-border-light);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

/* ==========================================================================
   STEP 3: PREVIEW & REFINEMENT
   ========================================================================== */

.aisales-batch-preview-loading {
  padding: var(--aisales-space-8);
}

.aisales-batch-loading-animation {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--aisales-space-4);
}

.aisales-batch-loading-animation .dashicons {
  font-size: 48px;
  width: 48px;
  height: 48px;
  color: var(--aisales-primary);
}

.aisales-spin {
  animation: aisales-spin 1s linear infinite;
}

@keyframes aisales-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.aisales-preview-intro {
  margin-bottom: var(--aisales-space-4);
  color: var(--aisales-text-secondary);
}

/* Preview Tabs */
.aisales-preview-tabs {
  display: flex;
  gap: var(--aisales-space-1);
  margin-bottom: var(--aisales-space-4);
  padding: var(--aisales-space-1);
  background: var(--aisales-bg-muted);
  border-radius: var(--aisales-radius-md);
  overflow-x: auto;
}

.aisales-preview-tab {
  flex-shrink: 0;
  padding: var(--aisales-space-2) var(--aisales-space-4);
  background: transparent;
  border: none;
  border-radius: var(--aisales-radius-sm);
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-medium);
  color: var(--aisales-text-secondary);
  cursor: pointer;
  transition: all var(--aisales-transition-fast);
  white-space: nowrap;
}

.aisales-preview-tab:hover {
  background: var(--aisales-bg-white);
  color: var(--aisales-text-primary);
}

.aisales-preview-tab--active {
  background: var(--aisales-bg-white);
  color: var(--aisales-primary);
  box-shadow: var(--aisales-shadow-xs);
}

/* Preview Content */
.aisales-preview-content {
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
  overflow: hidden;
}

.aisales-preview-product {
  display: none;
  padding: var(--aisales-space-4);
}

.aisales-preview-product--active {
  display: block;
}

.aisales-preview-product__header {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-3);
  margin-bottom: var(--aisales-space-4);
  padding-bottom: var(--aisales-space-3);
  border-bottom: 1px solid var(--aisales-border-lighter);
}

.aisales-preview-product__image {
  width: 60px;
  height: 60px;
  border-radius: var(--aisales-radius-sm);
  object-fit: cover;
  background: var(--aisales-bg-muted);
}

.aisales-preview-product__info h4 {
  margin: 0 0 var(--aisales-space-1);
  font-size: var(--aisales-font-md);
}

.aisales-preview-product__info span {
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-muted);
}

/* Diff Fields */
.aisales-diff-fields {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-4);
}

.aisales-diff-field {
  background: var(--aisales-bg-subtle);
  border: 1px solid var(--aisales-border-light);
  border-radius: var(--aisales-radius-md);
  overflow: hidden;
}

.aisales-diff-field__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--aisales-space-2) var(--aisales-space-3);
  background: var(--aisales-bg-muted);
  border-bottom: 1px solid var(--aisales-border-light);
}

.aisales-diff-field__label {
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

.aisales-diff-field__actions {
  display: flex;
  gap: var(--aisales-space-1);
}

.aisales-diff-field__content {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--aisales-space-3);
  padding: var(--aisales-space-3);
}

.aisales-diff-field__current,
.aisales-diff-field__suggested {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-2);
}

.aisales-diff-field__subtitle {
  font-size: var(--aisales-font-xs);
  font-weight: var(--aisales-font-weight-medium);
  color: var(--aisales-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.aisales-diff-field__value {
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-primary);
  padding: var(--aisales-space-2);
  background: var(--aisales-bg-white);
  border-radius: var(--aisales-radius-sm);
  max-height: 150px;
  overflow-y: auto;
}

.aisales-diff-field__current .aisales-diff-field__value {
  text-decoration: line-through;
  color: var(--aisales-text-muted);
}

.aisales-diff-field__suggested .aisales-diff-field__value {
  border: 1px solid var(--aisales-success-light);
  background: var(--aisales-success-light);
}

.aisales-diff-field__arrow {
  display: flex;
  align-items: center;
  color: var(--aisales-text-muted);
}

/* HTML content in diff fields (descriptions) */
.aisales-diff-field--html .aisales-diff-field__value {
  max-height: 250px;
  line-height: 1.6;
}

.aisales-diff-field--html .aisales-diff-field__value p {
  margin: 0 0 0.75em 0;
}

.aisales-diff-field--html .aisales-diff-field__value p:last-child {
  margin-bottom: 0;
}

.aisales-diff-field--html .aisales-diff-field__value ul,
.aisales-diff-field--html .aisales-diff-field__value ol {
  margin: 0.5em 0;
  padding-left: 1.5em;
}

.aisales-diff-field--html .aisales-diff-field__value li {
  margin-bottom: 0.25em;
}

.aisales-diff-field--html .aisales-diff-field__value strong,
.aisales-diff-field--html .aisales-diff-field__value b {
  font-weight: 600;
}

.aisales-diff-field--html .aisales-diff-field__value em,
.aisales-diff-field--html .aisales-diff-field__value i {
  font-style: italic;
}

.aisales-diff-field--html .aisales-diff-field__value h3,
.aisales-diff-field--html .aisales-diff-field__value h4 {
  font-size: var(--aisales-font-sm);
  font-weight: 600;
  margin: 0.75em 0 0.5em 0;
}

.aisales-diff-field--html .aisales-diff-field__current .aisales-diff-field__value {
  text-decoration: none;
}

.aisales-diff-field--html .aisales-diff-field__current .aisales-diff-field__value * {
  color: var(--aisales-text-muted);
}

/* Collapsible Refinement Panel */
.aisales-card--collapsible .aisales-card__header--clickable {
  cursor: pointer;
  user-select: none;
}

.aisales-card--collapsible .aisales-card__header--clickable:hover {
  background: var(--aisales-bg-subtle);
}

.aisales-collapse-icon {
  transition: transform var(--aisales-transition-fast);
}

.aisales-card--collapsible.aisales-card--expanded .aisales-collapse-icon {
  transform: rotate(180deg);
}

/* Refinement Sections */
.aisales-refinement-sections {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--aisales-space-5);
  margin-bottom: var(--aisales-space-5);
}

.aisales-refinement-section h4 {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  margin: 0 0 var(--aisales-space-3);
  font-size: var(--aisales-font-sm);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-primary);
}

.aisales-refinement-section h4 .dashicons {
  color: var(--aisales-primary);
  font-size: 16px;
  width: 16px;
  height: 16px;
}

.aisales-refinement-options {
  display: flex;
  flex-direction: column;
  gap: var(--aisales-space-2);
}

.aisales-refinement-option {
  display: flex;
  align-items: flex-start;
  gap: var(--aisales-space-2);
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-secondary);
  cursor: pointer;
}

.aisales-refinement-option:hover {
  color: var(--aisales-text-primary);
}

.aisales-refinement-option input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
}

.aisales-refinement-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--aisales-space-4);
  border-top: 1px solid var(--aisales-border-lighter);
}

/* File Upload */
.aisales-file-upload__dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-6);
  border: 2px dashed var(--aisales-border);
  border-radius: var(--aisales-radius-md);
  cursor: pointer;
  transition: all var(--aisales-transition-fast);
}

.aisales-file-upload__dropzone:hover {
  border-color: var(--aisales-primary);
  background: var(--aisales-primary-light);
}

.aisales-file-upload__dropzone.dragging {
  border-color: var(--aisales-primary);
  background: var(--aisales-primary-light);
}

.aisales-file-upload__dropzone .dashicons {
  font-size: 32px;
  width: 32px;
  height: 32px;
  color: var(--aisales-text-muted);
}

.aisales-file-upload__hint {
  font-size: var(--aisales-font-xs);
  color: var(--aisales-text-muted);
}

.aisales-file-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--aisales-space-2);
  margin-top: var(--aisales-space-3);
}

.aisales-file-item {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-2) var(--aisales-space-3);
  background: var(--aisales-bg-muted);
  border-radius: var(--aisales-radius-md);
  font-size: var(--aisales-font-sm);
}

.aisales-file-item__remove {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: var(--aisales-text-muted);
}

.aisales-file-item__remove:hover {
  color: var(--aisales-danger);
}

/* ==========================================================================
   STEP 4: PROCESSING
   ========================================================================== */

.aisales-process-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--aisales-space-4);
  margin-bottom: var(--aisales-space-5);
}

.aisales-process-stat {
  text-align: center;
  padding: var(--aisales-space-4);
  background: var(--aisales-bg-subtle);
  border-radius: var(--aisales-radius-md);
}

.aisales-process-stat__value {
  display: block;
  font-size: var(--aisales-font-2xl);
  font-weight: var(--aisales-font-weight-bold);
  color: var(--aisales-text-primary);
  line-height: 1;
  margin-bottom: var(--aisales-space-1);
}

.aisales-process-stat__label {
  font-size: var(--aisales-font-xs);
  color: var(--aisales-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.aisales-process-stat--success .aisales-process-stat__value {
  color: var(--aisales-success);
}

.aisales-process-stat--danger .aisales-process-stat__value {
  color: var(--aisales-danger);
}

/* Process Progress */
.aisales-process-progress {
  margin-bottom: var(--aisales-space-5);
}

.aisales-process-progress__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: var(--aisales-space-2);
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-secondary);
}

/* Process Log */
.aisales-process-log {
  max-height: 200px;
  overflow-y: auto;
  padding: var(--aisales-space-3);
  background: var(--aisales-bg-dark);
  border-radius: var(--aisales-radius-md);
  font-family: var(--aisales-font-mono);
  font-size: var(--aisales-font-xs);
}

.aisales-process-log__entry {
  display: flex;
  gap: var(--aisales-space-2);
  padding: var(--aisales-space-1) 0;
  color: var(--aisales-text-inverse);
  opacity: 0.8;
}

.aisales-process-log__entry--success {
  color: #4ade80;
}

.aisales-process-log__entry--error {
  color: #f87171;
}

.aisales-process-log__time {
  flex-shrink: 0;
  color: #6b7280;
}

/* ==========================================================================
   STEP 5: RESULTS
   ========================================================================== */

.aisales-results-summary {
  display: flex;
  gap: var(--aisales-space-6);
  margin-bottom: var(--aisales-space-5);
  padding: var(--aisales-space-4);
  background: var(--aisales-success-light);
  border-radius: var(--aisales-radius-md);
}

.aisales-results-summary__stat {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-2);
  font-size: var(--aisales-font-base);
  color: var(--aisales-text-primary);
}

.aisales-results-summary__stat .dashicons {
  font-size: 20px;
  width: 20px;
  height: 20px;
}

.aisales-results-summary__stat--failed {
  background: var(--aisales-danger-light);
  padding: var(--aisales-space-2) var(--aisales-space-3);
  border-radius: var(--aisales-radius-sm);
  margin-left: auto;
}

/* Results Table */
.aisales-results-table-wrapper {
  overflow-x: auto;
}

.aisales-results-table {
  width: 100%;
  border-collapse: collapse;
}

.aisales-results-table th,
.aisales-results-table td {
  padding: var(--aisales-space-3) var(--aisales-space-4);
  text-align: left;
  border-bottom: 1px solid var(--aisales-border-lighter);
}

.aisales-results-table th {
  font-size: var(--aisales-font-xs);
  font-weight: var(--aisales-font-weight-semibold);
  color: var(--aisales-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--aisales-bg-subtle);
}

.aisales-results-table__check {
  width: 40px;
}

.aisales-results-table__product {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-3);
}

.aisales-results-table__product-image {
  width: 40px;
  height: 40px;
  border-radius: var(--aisales-radius-sm);
  object-fit: cover;
  background: var(--aisales-bg-muted);
}

.aisales-results-table__product-name {
  font-weight: var(--aisales-font-weight-medium);
}

.aisales-results-table__changes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--aisales-space-1);
}

.aisales-results-table__change-badge {
  font-size: var(--aisales-font-xs);
  padding: 2px var(--aisales-space-2);
  background: var(--aisales-primary-light);
  color: var(--aisales-primary);
  border-radius: var(--aisales-radius-sm);
}

.aisales-results-table__status--applied {
  color: var(--aisales-success);
}

.aisales-results-table__status--pending {
  color: var(--aisales-warning);
}

.aisales-results-table__status--failed {
  color: var(--aisales-danger);
}

/* Results table uses shared .aisales-action-group styles from admin.css */

/* ==========================================================================
   ACTION BAR
   ========================================================================== */

.aisales-batch-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--aisales-space-5);
  padding-top: var(--aisales-space-4);
  border-top: 1px solid var(--aisales-border-light);
}

.aisales-batch-actions__left,
.aisales-batch-actions__right {
  display: flex;
  align-items: center;
  gap: var(--aisales-space-3);
}

.aisales-batch-info {
  font-size: var(--aisales-font-sm);
  color: var(--aisales-text-muted);
}

/* ==========================================================================
   BUTTON VARIANTS
   ========================================================================== */

.aisales-btn--outline {
  background: transparent;
}

.aisales-btn--danger.aisales-btn--outline {
  color: var(--aisales-danger);
  border-color: var(--aisales-danger);
}

.aisales-btn--danger.aisales-btn--outline:hover {
  background: var(--aisales-danger-light);
}

/* Extra small buttons */
.aisales-btn--xs {
  padding: 2px var(--aisales-space-2);
  font-size: var(--aisales-font-xs);
}

.aisales-btn--xs .dashicons {
  font-size: 12px;
  width: 12px;
  height: 12px;
}

/* ==========================================================================
   CENTERED CARD
   ========================================================================== */

.aisales-card--centered {
  text-align: center;
  max-width: 500px;
  margin: 0 auto;
}

.aisales-card--centered h3 {
  margin-bottom: var(--aisales-space-2);
}

.aisales-card--centered p {
  color: var(--aisales-text-secondary);
  margin-bottom: var(--aisales-space-4);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media screen and (max-width: 1024px) {
  .aisales-batch-config-grid {
    grid-template-columns: 1fr;
  }

  .aisales-process-stats {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (max-width: 782px) {
  .aisales-batch-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--aisales-space-3);
  }

  .aisales-batch-steps {
    overflow-x: auto;
    justify-content: flex-start;
    padding: var(--aisales-space-3);
  }

  .aisales-batch-step__label {
    display: none;
  }

  .aisales-batch-step__connector {
    width: 24px;
  }

  .aisales-batch-products {
    grid-template-columns: 1fr;
  }

  .aisales-batch-filters {
    flex-direction: column;
  }

  .aisales-batch-filter {
    max-width: none;
  }

  .aisales-batch-filter-actions {
    margin-left: 0;
  }

  .aisales-batch-actions {
    flex-direction: column;
    gap: var(--aisales-space-3);
  }

  .aisales-batch-actions__left,
  .aisales-batch-actions__right {
    width: 100%;
    flex-wrap: wrap;
  }

  .aisales-refinement-sections {
    grid-template-columns: 1fr;
  }

  .aisales-diff-field__content {
    grid-template-columns: 1fr;
  }

  .aisales-diff-field__arrow {
    justify-content: center;
    transform: rotate(90deg);
  }

  .aisales-results-table {
    font-size: var(--aisales-font-sm);
  }

  .aisales-results-table th,
  .aisales-results-table td {
    padding: var(--aisales-space-2);
  }
}

/* ==========================================================================
   MODAL OVERRIDES FOR RESULT DETAILS
   ========================================================================== */

body.aisales-modal-open {
  overflow: hidden;
}

/* Make result modal wider */
#aisales-result-modal {
  max-width: 800px;
  width: 95%;
}

#aisales-result-modal .aisales-modal__footer {
  justify-content: flex-end;
  gap: var(--aisales-space-2);
}

/* Modal diff fields */
#aisales-result-modal .aisales-diff-field {
  margin-bottom: var(--aisales-space-4);
}

#aisales-result-modal .aisales-diff-field:last-child {
  margin-bottom: 0;
}
