/* ============================================================
   import.css — Import view styles (paste area, card grid, 3-option flow)
   ============================================================ */

.import-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
  align-items: start;
}

/* ── Paste panel ── */
.import-paste-panel { display: flex; flex-direction: column; gap: var(--space-4); }

.import-paste-panel__title {
  font-size: var(--text-md);
  font-weight: 700;
}

.import-paste-panel__desc {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.6;
}

.import-format-hint {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  line-height: 1.9;
}

.import-textarea {
  min-height: 200px;
  resize: vertical;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.8;
}

.import-actions {
  display: flex;
  gap: var(--space-3);
  align-items: center;
}

.import-count {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* ── Bulk date bar (month+year apply to all) ── */
.bulk-date-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-2);
}

.bulk-date-bar__label {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-secondary);
  white-space: nowrap;
}

/* ── Cards panel ── */
.import-cards-panel { display: flex; flex-direction: column; gap: var(--space-3); }

.import-cards-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.import-cards-panel__title {
  font-size: var(--text-md);
  font-weight: 700;
}

.import-cards-panel__stats {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.import-cards-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-height: calc(100vh - 220px);
  overflow-y: auto;
  padding-right: 4px;
}

/* ── Single import card ── */
.import-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition);
}

.import-card.has-warnings { border-color: var(--color-warn-border); }
.import-card.is-skipped { opacity: 0.4; }
.import-card.is-note { border-color: var(--color-accent); }
.import-card.is-expense { border-color: var(--color-income); }

/* Raw text from user */
.import-card__raw {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: var(--color-surface-2);
  border-radius: var(--radius-sm);
  padding: 6px 9px;
  margin-bottom: var(--space-3);
  line-height: 1.6;
  word-break: break-all;
}

/* Parsed fields grid */
.import-card__fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2) var(--space-3);
  margin-bottom: var(--space-3);
}

.import-card__field--full {
  grid-column: 1 / -1;
}

.import-card__field { display: flex; flex-direction: column; gap: 3px; }

.import-card__field-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
}

.import-card__field--warn .import-card__field-label {
  color: var(--color-warn);
}

.warn-indicator {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 10px;
  color: var(--color-warn);
  font-weight: 600;
  margin-bottom: 2px;
}

/* Action buttons — 3 options */
.import-card__actions {
  display: flex;
  gap: var(--space-2);
  border-top: 1px solid var(--color-border-light);
  padding-top: var(--space-3);
  flex-wrap: wrap;
}

.import-card__btn {
  flex: 1;
  min-width: 0;
  text-align: center;
  padding: 6px var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: var(--transition);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}

/* Option 1: Record Expense */
.import-card__btn--record {
  background: var(--color-income-bg);
  color: var(--color-income);
}
.import-card__btn--record:hover { background: var(--color-income); color: #fff; }
.import-card__btn--record.selected { background: var(--color-income); color: #fff; }

/* Option 3: Skip */
.import-card__btn--skip {
  background: var(--color-surface-2);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
}
.import-card__btn--skip:hover { background: var(--color-border); color: var(--color-text-primary); }
.import-card__btn--skip.selected { background: var(--color-border); color: var(--color-text-secondary); }

/* ── Confirm bar (appears after decisions made) ── */
.import-confirm-bar {
  position: sticky;
  bottom: 0;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.06);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  margin-top: var(--space-3);
}

.import-confirm-bar__summary {
  display: flex;
  gap: var(--space-4);
  font-size: var(--text-sm);
}

.import-confirm-bar__item { display: flex; align-items: center; gap: var(--space-2); }
.import-confirm-bar__count { font-weight: 700; }

/* ── Validation state ── */
.import-card--validating {
  pointer-events: none;
  opacity: 0.7;
}

.validation-errors {
  margin: var(--space-2) 0;
  padding: var(--space-2) var(--space-3);
  background: var(--color-expense-bg);
  border: 1px solid rgba(220,38,38,0.2);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--color-expense);
}
