/* ── QUOTE LINE ITEM — Inline Price Edit ── */
.qli-td-price {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 5px;
  white-space: nowrap;
}
.qli-price-display {
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  color: var(--text-secondary);
}
.qli-price-edit-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-disabled);
  font-size: 11px;
  padding: 2px 4px;
  border-radius: var(--radius-sm);
  line-height: 1;
  flex-shrink: 0;
  transition: color var(--dur-fast) ease, background var(--dur-fast) ease;
  opacity: 0;
}
.qli-table tbody tr:hover .qli-price-edit-btn { opacity: 1; }
.qli-price-edit-btn:hover {
  color: var(--brand-primary);
  background: rgba(var(--brand-primary-rgb), 0.10);
  opacity: 1;
}
.qli-price-input {
  width: 72px;
  padding: 3px 6px;
  border: 1.5px solid var(--brand-primary);
  border-radius: var(--radius-sm);
  font: 600 11px var(--font-mono);
  text-align: right;
  color: var(--text-primary);
  background: white;
  box-shadow: 0 0 0 3px rgba(var(--brand-primary-rgb), 0.12);
  outline: none;
  -moz-appearance: textfield;
}
.qli-price-input::-webkit-inner-spin-button,
.qli-price-input::-webkit-outer-spin-button { opacity: 1; }
.qli-price-confirm-btn {
  background: var(--brand-primary);
  color: white;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 6px;
  line-height: 1;
  flex-shrink: 0;
  transition: background var(--dur-fast) ease;
}
.qli-price-confirm-btn:hover { background: var(--brand-secondary); }

/* ── QUOTE LINE ITEM — Per-line Multiplier (INTERNAL ONLY) ── */
.qli-td-multiplier {
  text-align: center;
  white-space: nowrap;
  background: rgba(var(--brand-accent-rgb), 0.04);
}
.qli-multiplier-input {
  width: 64px;
  padding: 3px 6px;
  border: 1.5px solid rgba(var(--brand-accent-rgb), 0.35);
  border-radius: var(--radius-sm);
  font: 600 11px var(--font-mono);
  text-align: right;
  color: var(--text-primary);
  background: white;
  outline: none;
  -moz-appearance: textfield;
  transition: border-color var(--dur-fast) ease, box-shadow var(--dur-fast) ease;
}
.qli-multiplier-input:focus {
  border-color: var(--brand-accent);
  box-shadow: 0 0 0 3px rgba(var(--brand-accent-rgb), 0.15);
}
.qli-table th.th-internal {
  background: rgba(var(--brand-accent-rgb), 0.08);
  position: relative;
}
.th-internal-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 1px 6px;
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--brand-accent);
  background: rgba(var(--brand-accent-rgb), 0.15);
  border-radius: 10px;
  vertical-align: middle;
}

/* ── IMPORT WIZARD — item_name combine-columns builder ── */
.mapping-row-item-name { align-items: flex-start; }

.mapping-item-name-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.combine-toggle-link {
  background: none;
  border: none;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  color: var(--brand-primary);
  padding: 0;
  text-align: left;
  transition: opacity 120ms ease;
}
.combine-toggle-link:hover { opacity: 0.7; }

.combine-builder { display: flex; flex-direction: column; gap: 6px; }

.combine-col-row { display: flex; align-items: center; gap: 6px; }

.combine-plus {
  font-size: 12px; font-weight: 700; color: var(--text-tertiary);
  width: 16px; text-align: center; flex-shrink: 0;
}

.combine-remove-col {
  background: none; border: none; cursor: pointer;
  color: var(--text-disabled); font-size: 13px; padding: 2px 4px;
  border-radius: var(--radius-sm); flex-shrink: 0; transition: color 120ms ease;
}
.combine-remove-col:hover { color: var(--status-danger); }

.combine-add-col {
  background: none; border: 1px dashed rgba(0,0,0,0.15);
  border-radius: var(--radius-sm); padding: 4px 10px;
  font-size: 11px; font-weight: 500; color: var(--text-secondary);
  cursor: pointer; width: fit-content; transition: border-color 120ms ease, color 120ms ease;
}
.combine-add-col:hover { border-color: var(--brand-primary); color: var(--brand-primary); }

.combine-sep-row { display: flex; align-items: center; gap: 8px; }
.combine-sep-label {
  font-size: 11px; font-weight: 600; color: var(--text-tertiary);
  text-transform: uppercase; letter-spacing: 0.04em; white-space: nowrap;
}
.combine-sep-input {
  width: 64px; padding: 4px 8px; border: 1px solid rgba(0,0,0,0.12);
  border-radius: var(--radius-sm); font: 13px var(--font-mono);
  color: var(--text-primary); background: white; outline: none; transition: border-color 120ms ease;
}
.combine-sep-input:focus { border-color: var(--brand-primary); }

.combine-preview {
  font-size: 12px; color: var(--text-secondary); padding: 5px 10px;
  background: rgba(var(--brand-primary-rgb), 0.05);
  border-left: 3px solid var(--brand-primary);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  transition: opacity 150ms ease;
}
.combine-preview strong { color: var(--text-primary); }

/* ── IMPORT WIZARD — Description append builder ── */
.mapping-row-description { align-items: flex-start; }
.mapping-desc-wrap { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.desc-append-row { display: flex; align-items: center; gap: 6px; }
.desc-append-label {
  font-size: 11px; font-weight: 600; color: var(--text-tertiary);
  white-space: nowrap; flex-shrink: 0; min-width: 52px;
}
.desc-append-preview {
  border-left-color: var(--brand-accent);
  background: rgba(var(--brand-accent-rgb), 0.05);
}

/* ── IMPORT WIZARD — Conflict resolution step ── */

/* ── Shared banner ── */
.conflict-summary-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.25);
  border-radius: var(--radius-md);
  margin-bottom: 20px;
}
.conflict-summary-icon { font-size: 22px; flex-shrink: 0; }
.conflict-summary-text { display: flex; flex-direction: column; gap: 2px; }
.conflict-summary-text strong { font-size: 14px; color: var(--text-primary); }
.conflict-summary-sub { font-size: 12px; color: var(--text-secondary); }

/* ── Bulk mode ── */
.conflict-bulk { display: flex; flex-direction: column; }

.conflict-bulk-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}

.conflict-bulk-btn-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.conflict-bulk-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 16px 12px;
  border: 2px solid rgba(0,0,0,0.10);
  border-radius: var(--radius-md);
  background: white;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font-body);
  color: var(--text-primary);
  transition: border-color 150ms ease, background 150ms ease, color 150ms ease;
}
.conflict-bulk-btn:hover {
  border-color: var(--brand-primary);
  background: rgba(var(--brand-primary-rgb), 0.04);
  color: var(--brand-primary);
}
.conflict-bulk-btn.active {
  border-color: var(--brand-primary);
  background: rgba(var(--brand-primary-rgb), 0.08);
  color: var(--brand-primary);
}
.conflict-bulk-sub {
  font-size: 11px;
  font-weight: 400;
  color: var(--text-tertiary);
}
.conflict-bulk-btn.active .conflict-bulk-sub { color: var(--brand-primary); opacity: 0.7; }

.conflict-detail-link {
  background: none; border: none; cursor: pointer;
  font-size: 12px; font-weight: 600; color: var(--brand-primary);
  padding: 0; text-align: left; width: fit-content;
  transition: opacity 120ms ease;
}
.conflict-detail-link:hover { opacity: 0.7; }

/* Mini SKU list in bulk mode */
.conflict-sku-list {
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: var(--radius-md);
  overflow: hidden;
  max-height: 260px;
  overflow-y: auto;
}
.conflict-sku-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  font-size: 12px;
}
.conflict-sku-row:last-child { border-bottom: none; }
.conflict-sku-row:nth-child(even) { background: rgba(0,0,0,0.02); }
.conflict-sku-val {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--brand-primary);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.conflict-sku-res {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  flex-shrink: 0;
}
.conflict-sku-res.incoming {
  background: rgba(var(--brand-primary-rgb), 0.10);
  color: var(--brand-primary);
}
.conflict-sku-res.existing {
  background: rgba(0,0,0,0.07);
  color: var(--text-tertiary);
}

/* Conflict type badges */
.conflict-type-badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border-radius: 3px;
  flex-shrink: 0;
  white-space: nowrap;
}
.conflict-type-badge.csv { background: rgba(99,102,241,0.12); color: #4f46e5; }
.conflict-type-badge.db  { background: rgba(245,158,11,0.12);  color: #d97706; }

/* ── Detail mode ── */
.conflict-detail { display: flex; flex-direction: column; }

.conflict-detail-bulk-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
}

.conflict-bulk-mini {
  background: none;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: var(--radius-sm);
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  transition: border-color 120ms ease, color 120ms ease;
}
.conflict-bulk-mini:hover { border-color: var(--brand-primary); color: var(--brand-primary); }

.conflict-card {
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 12px;
}
.conflict-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-elevated);
  border-bottom: 1px solid rgba(0,0,0,0.07);
  flex-wrap: wrap;
}
.conflict-card-sku {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--brand-primary);
  flex: 1;
  min-width: 0;
}

/* Per-card toggle */
.conflict-toggle {
  display: flex;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: var(--radius-sm);
  overflow: hidden;
  flex-shrink: 0;
}
.conflict-toggle-btn {
  background: white;
  border: none;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  padding: 5px 12px;
  color: var(--text-secondary);
  font-family: var(--font-body);
  transition: background 120ms ease, color 120ms ease;
  border-left: 1px solid rgba(0,0,0,0.08);
}
.conflict-toggle-btn:first-child { border-left: none; }
.conflict-toggle-btn:hover { background: rgba(var(--brand-primary-rgb), 0.06); color: var(--brand-primary); }
.conflict-toggle-btn.active {
  background: var(--brand-primary);
  color: white;
}

/* Field comparison table */
.conflict-field-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.conflict-field-table th {
  padding: 7px 10px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-tertiary);
  background: white;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.conflict-col-incoming { color: var(--brand-primary) !important; }
.conflict-col-existing { color: var(--text-tertiary) !important; }

.conflict-field-table td { padding: 7px 10px; border-bottom: 1px solid rgba(0,0,0,0.04); vertical-align: top; }
.conflict-field-table tr:last-child td { border-bottom: none; }
.conflict-field-label {
  font-size: 11px; font-weight: 600; color: var(--text-tertiary);
  white-space: nowrap; width: 110px;
}
.conflict-field-val {
  max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--text-secondary);
}
.conflict-field-val.incoming { color: var(--text-primary); }

/* Highlight rows where values differ */
.conflict-field-diff td { background: rgba(245,158,11,0.04); }
.conflict-field-diff .conflict-field-val.incoming { font-weight: 600; }
