/* ══════════ FONTS ══════════ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=Inter:wght@400;500;600;700&display=swap');

/* ══════════ TOKENS ══════════ */
:root {
  --bg: #f7f6f3;
  --bg-warm: #f2f0ec;
  --text: #1e2a24;
  --text-2: #4a5650;
  --text-3: #7d8a82;
  --card: #ffffff;
  --line: #d5d0c8;
  --line-light: #e8e4dd;
  --accent: #2d4a3e;
  --accent-hover: #1f3a2f;
  --accent-subtle: #eef3f0;
  --accent-muted: #8aab9a;
  --header-bg: #2d4a3e;
  --ok: #2d6a4f;
  --ok-bg: #ecf5f0;
  --ok-border: #95d5b2;
  --warn: #b5651d;
  --warn-bg: #fdf6ee;
  --warn-border: #e8c596;
  --danger: #a63d40;
  --danger-bg: #fdf0f0;
  --danger-border: #e8a5a5;
  --pending: #6b5b8a;
  --pending-bg: #f4f1f9;
  --pending-border: #c4b5e0;
  --r: 8px;
  --r-lg: 12px;
  --r-xl: 16px;
  --shadow-xs: 0 1px 2px rgba(45,74,62,.04);
  --shadow-sm: 0 1px 3px rgba(45,74,62,.06), 0 1px 2px rgba(0,0,0,.03);
  --shadow-md: 0 4px 12px rgba(45,74,62,.08), 0 1px 3px rgba(0,0,0,.03);
  --font: "Inter", system-ui, -apple-system, sans-serif;
  --font-serif: "Playfair Display", Georgia, "Times New Roman", serif;
}

/* ══════════ RESET ══════════ */
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; font-family: var(--font); color: var(--text); background: var(--bg); font-size: 13.5px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
h1,h2,h3,h4,p { margin: 0; }
button { font-family: inherit; cursor: pointer; }

/* ══════════ HEADER ══════════ */
.topbar { background: var(--header-bg); position: sticky; top: 0; z-index: 100; }
.topbar-inner { max-width: 1140px; margin: 0 auto; padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; }
.topbar-brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 34px; height: 34px; border-radius: 6px;
  background: rgba(255,255,255,.12);
  color: #fff; font-weight: 700; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  letter-spacing: -0.5px;
  border: 1px solid rgba(255,255,255,.15);
}
.topbar h1 { font-family: var(--font-serif); font-size: 1rem; font-weight: 600; color: #fff; letter-spacing: 0.01em; }
.topbar p { color: rgba(255,255,255,.45); font-size: 0.68rem; margin-top: 0; }
.topbar-period { color: rgba(255,255,255,.55); font-size: 0.72rem; font-weight: 500; }

/* ══════════ STEP BAR ══════════ */
.step-bar { background: var(--card); border-bottom: 1px solid var(--line-light); position: sticky; top: 58px; z-index: 90; }
.step-bar-inner {
  max-width: 480px; margin: 0 auto; padding: 10px 24px;
  display: flex; align-items: center; justify-content: center;
}
.step-indicator {
  display: flex; align-items: center; gap: 7px;
  background: none; border: none; padding: 5px 12px; border-radius: 8px;
  font-size: 0.76rem; font-weight: 500; color: var(--text-3);
  transition: all 0.2s;
}
.step-indicator:not(:disabled):hover { background: var(--bg); color: var(--text-2); }
.step-indicator.active { color: var(--accent); font-weight: 600; }
.step-indicator.done { color: var(--ok); }
.step-num {
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.68rem; font-weight: 700;
  background: var(--line-light); color: var(--text-3);
  transition: all 0.25s;
}
.step-indicator.active .step-num { background: var(--accent); color: #fff; box-shadow: 0 2px 8px rgba(45,74,62,.25); }
.step-indicator.done .step-num { background: var(--ok); color: #fff; }
.step-connector-wrap { flex: 0 0 40px; display: flex; align-items: center; justify-content: center; }
.step-connector { display: block; width: 100%; height: 2px; background: var(--line-light); border-radius: 1px; transition: background 0.3s; }
.step-connector-wrap.done .step-connector { background: var(--ok); }

/* ══════════ SHELL ══════════ */
.app-shell { max-width: 1140px; margin: 0 auto; padding: 24px 24px 80px; }

/* ══════════ STEP PANELS ══════════ */
.step-panel { display: none; }
.step-panel.active { display: block; animation: fadeUp 0.3s ease; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ══════════ CARDS ══════════ */
.card {
  padding: 24px; border: 1px solid var(--line-light);
  border-radius: var(--r-xl); background: var(--card);
  box-shadow: var(--shadow-sm);
}
.card + .card { margin-top: 16px; }
.card h2 { font-family: var(--font-serif); font-size: 1.05rem; font-weight: 600; letter-spacing: 0; }
.card h3 { font-family: var(--font-serif); font-size: 0.92rem; font-weight: 600; }
.card-section-label {
  display: inline-block; font-size: 0.6rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--accent);
  background: var(--accent-subtle); padding: 2px 9px; border-radius: 4px;
  margin-bottom: 8px;
}
.card-header { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 6px; }
.card-header-left { display: flex; align-items: center; gap: 8px; }
.card-icon {
  width: 28px; height: 28px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.76rem; font-weight: 800;
}
.card-icon-warn { background: var(--warn-bg); color: var(--warn); border: 1px solid var(--warn-border); }
.card-icon-info { background: var(--accent-subtle); color: var(--accent); border: 1px solid var(--accent-muted); }

.help { color: var(--text-3); font-size: 0.78rem; line-height: 1.45; }
.status { margin-top: 10px; color: var(--text-3); font-size: 0.78rem; }

/* ══════════ UPLOAD LAYOUT ══════════ */
.upload-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 16px; align-items: start; }
.upload-card { min-height: 320px; }

.upload-zone {
  margin-top: 14px; border: 2px dashed var(--line); border-radius: var(--r-lg);
  background: var(--bg-warm); padding: 40px 20px; text-align: center; cursor: pointer;
  transition: all 0.2s;
}
.upload-zone:hover, .upload-zone:focus { border-color: var(--accent-muted); background: var(--accent-subtle); outline: none; }
.upload-zone.is-dragging { border-color: var(--accent); background: var(--accent-subtle); box-shadow: 0 0 0 4px rgba(45,74,62,.08); }
.upload-zone p { margin-top: 6px; }
.upload-zone strong { color: var(--accent); }
.upload-hint { font-size: 0.72rem; color: var(--text-3); }
.upload-icon { color: var(--accent-muted); margin-bottom: 4px; }
.visually-hidden { position: absolute; width: 1px; height: 1px; margin: -1px; border: 0; padding: 0; overflow: hidden; clip: rect(0 0 0 0); }

/* ══════════ FILE LIST ══════════ */
.file-list { margin-top: 14px; display: grid; gap: 4px; }
.file-item {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  border: 1px solid var(--line-light); border-radius: var(--r); background: #faf9f7; padding: 6px 10px;
  transition: background 0.15s;
}
.file-item:hover { background: #f3f1ed; }
.file-item strong { font-size: 0.78rem; }
.file-meta { font-size: 0.68rem; color: var(--text-3); }
.file-remove {
  border: 1px solid var(--danger-border); background: var(--danger-bg); color: var(--danger);
  border-radius: 5px; padding: 2px 7px; font-size: 0.68rem; font-weight: 600; cursor: pointer;
  transition: background 0.15s;
}
.file-remove:hover { background: #f8d7d7; }

/* ══════════ PERIOD CONTROLS ══════════ */
.period-controls { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.input-group { display: flex; flex-direction: column; gap: 4px; }
.input-group > span { font-size: 0.68rem; font-weight: 600; color: var(--text-2); text-transform: uppercase; letter-spacing: 0.06em; }
input, select { font: inherit; width: 100%; border: 1px solid var(--line); border-radius: var(--r); background: #fff; color: var(--text); padding: 8px 10px; font-size: 0.82rem; transition: border-color 0.15s, box-shadow 0.15s; }
input:focus, select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(45,74,62,.10); }

.generate-actions { display: flex; flex-direction: column; gap: 8px; margin-top: 18px; }

/* ══════════ BUTTONS ══════════ */
.actions-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.btn {
  border: none; border-radius: 999px; padding: 9px 20px;
  font-weight: 600; font-size: 0.8rem; transition: all 0.15s;
  display: inline-flex; align-items: center; gap: 6px; justify-content: center;
  letter-spacing: 0.01em;
}
.btn-primary { background: var(--accent); color: #fff; box-shadow: 0 1px 3px rgba(45,74,62,.2); }
.btn-primary:hover { background: var(--accent-hover); box-shadow: 0 2px 6px rgba(45,74,62,.25); }
.btn-secondary { background: #fff; border: 1px solid var(--accent); color: var(--accent); font-weight: 500; }
.btn-secondary:hover { background: var(--accent-subtle); border-color: var(--accent-hover); }
.btn-ghost { background: none; border: 1px solid transparent; color: var(--text-2); font-weight: 500; }
.btn-ghost:hover { background: var(--bg-warm); color: var(--text); }
.btn-sm { padding: 5px 14px; font-size: 0.74rem; }
.btn-full { width: 100%; }
.btn:disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }

.step-actions { margin-top: 20px; }

/* ══════════ REVIEW HEADER ══════════ */
.review-header {
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
  margin-bottom: 16px;
}
.review-header h2 { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 600; }
.review-card { margin-top: 12px; }
.review-card:first-of-type { margin-top: 0; }

/* ══════════ COUNT BADGE ══════════ */
.count-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 24px; height: 22px; padding: 0 7px;
  border-radius: 999px; font-size: 0.68rem; font-weight: 700;
  background: var(--line-light); color: var(--text-3);
}
.count-badge.has-items { background: var(--warn-bg); color: var(--warn); border: 1px solid var(--warn-border); }
.count-badge.all-clear { background: var(--ok-bg); color: var(--ok); border: 1px solid var(--ok-border); }

/* ══════════ DASHBOARD HEADER ══════════ */
.dashboard-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 20px; }
.dashboard-title h2 { font-family: var(--font-serif); font-size: 1.15rem; font-weight: 600; letter-spacing: 0; }
.dashboard-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

/* ══════════ KPI STRIP ══════════ */
.kpi-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 12px; }
.kpi-card {
  padding: 14px 16px; border-radius: var(--r-lg);
  background: var(--card); border: 1px solid var(--line-light);
  box-shadow: var(--shadow-xs); transition: box-shadow 0.2s;
}
.kpi-card:hover { box-shadow: var(--shadow-sm); }
.kpi-card.kpi-blue { background: linear-gradient(135deg, #eef3f0 0%, #f6f9f7 100%); border-color: #b5cfbf; }
.kpi-card.kpi-green { background: linear-gradient(135deg, #ecf5f0 0%, #f5faf7 100%); border-color: #a3d4b5; }
.kpi-label { display: block; font-size: 0.65rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-3); }
.kpi-value { display: block; margin-top: 4px; font-size: 1.15rem; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }
.kpi-inline {
  margin-top: 14px; padding: 10px 14px; border-radius: var(--r);
  background: linear-gradient(135deg, #eef3f0 0%, #f6f9f7 100%); border: 1px solid #b5cfbf;
  display: flex; justify-content: space-between; align-items: center;
}
.kpi-inline .kpi-label { font-size: 0.72rem; }
.kpi-inline .kpi-value { font-size: 1rem; margin-top: 0; }

.journal-balance-status {
  margin: 0 0 16px; padding: 10px 16px; border-radius: var(--r-lg);
  font-size: 0.82rem; font-weight: 600;
  display: flex; align-items: center; gap: 8px;
}
.journal-balance-status.balanced { background: var(--ok-bg); color: var(--ok); border: 1px solid var(--ok-border); }
.journal-balance-status.unbalanced { background: var(--danger-bg); color: var(--danger); border: 1px solid var(--danger-border); }

/* ══════════ TAB BAR ══════════ */
.tab-bar {
  display: flex; gap: 2px; background: var(--bg-warm); padding: 3px;
  border-radius: var(--r-lg); margin-bottom: 16px;
  border: 1px solid var(--line-light);
}
.tab-btn {
  background: none; border: none; padding: 8px 16px;
  font-size: 0.78rem; font-weight: 500; color: var(--text-3);
  border-radius: var(--r); white-space: nowrap; transition: all 0.15s;
  flex: 1; text-align: center;
}
.tab-btn:hover { color: var(--text-2); background: rgba(255,255,255,.5); }
.tab-btn.active { color: var(--accent); background: var(--card); font-weight: 600; box-shadow: var(--shadow-xs); }

/* ══════════ TAB PANELS ══════════ */
.tab-panel { display: none; }
.tab-panel.active { display: block; animation: fadeUp 0.2s ease; }

/* ══════════ TAX GRID ══════════ */
.tax-grid { display: grid; grid-template-columns: 1fr; gap: 0; margin-top: 16px; border: 1px solid var(--line-light); border-radius: var(--r-lg); overflow: hidden; }
.tax-item { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--line-light); background: #fff; }
.tax-item:last-child { border-bottom: none; }
.tax-item-highlight { background: #faf9f7; }
.tax-label { font-size: 0.82rem; color: var(--text-2); }
.tax-value { font-size: 0.95rem; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--text); }
.tax-divider { height: 0; border-bottom: 2px solid var(--line); margin: 0; }
.tax-grid-sm { border: none; margin-top: 8px; }
.tax-grid-sm .tax-item { padding: 10px 18px; }
.tax-grid-sm .tax-value { font-size: 0.88rem; }
.tax-breakdown { margin-top: 20px; padding-top: 14px; border-top: 1px solid var(--line-light); }
.tax-breakdown h4 { font-size: 0.72rem; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; }

/* ══════════ TWO COLUMN ══════════ */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.two-col .card { margin-top: 0; }

/* ══════════ TABLES ══════════ */
.table-wrap { overflow-x: auto; margin-top: 8px; border: 1px solid var(--line-light); border-radius: var(--r-lg); }
.table-tools { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin: 12px 0 4px; }
.table-filter-input {
  width: min(280px, 100%); border: 1px solid var(--line); border-radius: var(--r);
  background: #fff; color: var(--text); padding: 6px 10px; font-size: 0.78rem;
}
table { width: 100%; border-collapse: collapse; font-size: 0.78rem; }
th, td { text-align: left; padding: 8px 12px; white-space: nowrap; }
th {
  font-size: 0.65rem; font-weight: 600; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--text-3);
  border-bottom: 1px solid var(--line); background: #f8f7f4;
}
th:first-child { border-radius: var(--r-lg) 0 0 0; }
th:last-child { border-radius: 0 var(--r-lg) 0 0; }
td { border-bottom: 1px solid var(--line-light); }
.col-right { text-align: right; }
tbody tr:hover { background: #f5f4f1; }
tbody tr:last-child td { border-bottom: none; }
th.sortable-column { cursor: pointer; user-select: none; }
th.sortable-column:hover { color: var(--text-2); }
th.active-sort { color: var(--text); }

/* ══════════ RETAIL REVIEW ══════════ */
.retail-review-select {
  font-size: 0.74rem; padding: 5px 8px; border-radius: 6px;
  border: 1px solid var(--line); background: #fff; color: var(--text); min-width: 230px;
}
.review-status-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 9px; border-radius: 999px; font-size: 0.68rem; font-weight: 600;
}
.review-status-badge.badge-linked { background: var(--ok-bg); color: var(--ok); border: 1px solid var(--ok-border); }
.review-status-badge.badge-pending { background: var(--pending-bg); color: var(--pending); border: 1px solid var(--pending-border); }
.review-status-badge.badge-cash { background: var(--warn-bg); color: var(--warn); border: 1px solid var(--warn-border); }
.review-status-badge.badge-flagged { background: var(--danger-bg); color: var(--danger); border: 1px solid var(--danger-border); }
.review-status-badge.badge-cc { background: var(--accent-subtle); color: var(--accent); border: 1px solid var(--accent-muted); }

.review-summary-bar {
  display: flex; flex-wrap: wrap; gap: 14px; margin: 10px 0 4px;
  padding: 10px 16px; background: #f8f7f4; border: 1px solid var(--line-light); border-radius: var(--r-lg);
}
.review-summary-item { display: flex; align-items: center; gap: 5px; font-size: 0.74rem; font-weight: 500; color: var(--text-2); }
.review-summary-count { font-weight: 700; font-variant-numeric: tabular-nums; }
.review-summary-dot { width: 8px; height: 8px; border-radius: 50%; }
.review-summary-dot.dot-linked { background: var(--ok); }
.review-summary-dot.dot-pending { background: var(--pending); }
.review-summary-dot.dot-cash { background: var(--warn); }
.review-summary-dot.dot-cc { background: var(--accent); }
.review-summary-dot.dot-flagged { background: var(--danger); }

/* ══════════ PILLS ══════════ */
.pill { display: inline-block; border-radius: 999px; padding: 3px 10px; font-size: 0.74rem; font-weight: 500; border: 1px solid var(--line); background: var(--bg-warm); }
.pill.ok { border-color: var(--ok-border); background: var(--ok-bg); color: var(--ok); }
.pill.warn { border-color: var(--warn-border); background: var(--warn-bg); color: var(--warn); }
.pill.bad { border-color: var(--danger-border); background: var(--danger-bg); color: var(--danger); }

/* ══════════ MISC ══════════ */
.hidden { display: none !important; }
/* Legacy compat */
.button { border: none; border-radius: 999px; padding: 8px 18px; cursor: pointer; background: var(--accent); color: #fff; font-weight: 600; font-size: 0.82rem; font-family: inherit; }
.button:hover { background: var(--accent-hover); }
.button:disabled { opacity: 0.4; cursor: not-allowed; }
.button-outline { border: 1px solid var(--accent); color: var(--accent); background: #fff; font-weight: 500; }
.button-outline:hover { background: var(--accent-subtle); }
.control-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); margin-top: 14px; }
.summary-grid { display: grid; gap: 8px; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.summary-grid article { border: 1px solid var(--line-light); border-radius: var(--r); padding: 12px; background: #faf9f7; }
.summary-grid article h3 { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-3); }
.summary-grid article p { margin-top: 4px; font-size: 1.1rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.report-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin-bottom: 12px; }
.info-card { background: #fff; }
.plain-list { margin: 10px 0 0; padding-left: 16px; color: var(--text-2); }
.plain-list li { margin-top: 4px; }
.feature-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); margin-top: 10px; }
.feature-grid article { border: 1px solid var(--line-light); border-radius: var(--r); padding: 10px; background: #faf9f7; }
.mapping-stack { display: grid; gap: 12px; }
.mapping-card { border: 1px solid var(--line-light); border-radius: var(--r-lg); padding: 12px; background: #fff; }
.mapping-title { margin-bottom: 9px; font-weight: 700; }
.field-grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }

/* ══════════ RETAIL SUMMARY GRIDS ══════════ */
.retail-status-grid, .retail-category-grid {
  display: grid; grid-template-columns: 1fr; gap: 0;
  margin-top: 12px; border: 1px solid var(--line-light);
  border-radius: var(--r-lg); overflow: hidden;
}
.retail-summary-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px; border-bottom: 1px solid var(--line-light);
  background: #fff; font-size: 0.82rem;
}
.retail-summary-row:last-child { border-bottom: none; }
.retail-summary-row:nth-child(even) { background: var(--bg); }
.retail-summary-row-label { display: flex; align-items: center; gap: 8px; color: var(--text-2); }
.retail-summary-row-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.retail-summary-row-value {
  font-weight: 700; font-variant-numeric: tabular-nums; color: var(--text);
}
.retail-summary-row-count {
  font-size: 0.68rem; color: var(--text-3); font-weight: 500;
  margin-left: 4px;
}

/* ══════════ REPORT GUIDE ══════════ */
.report-guide-card h2 { margin-bottom: 2px; }
.report-guide-list {
  margin: 0; padding: 0; list-style: none;
  display: grid; gap: 0;
  border: 1px solid var(--line-light); border-radius: var(--r-lg); overflow: hidden;
}
.report-guide-list li {
  display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line-light);
  background: #fff;
  font-size: 0.82rem;
  counter-increment: guide;
  line-height: 1.5;
}
.report-guide-list li::before {
  content: counter(guide);
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent); color: #fff;
  font-size: 0.68rem; font-weight: 700;
  flex-shrink: 0;
}
.report-guide-list li:last-child { border-bottom: none; }
.report-guide-list li:nth-child(even) { background: var(--bg); }
.report-guide-path {
  font-weight: 700; font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--accent);
}
.report-guide-arrow { color: var(--text-3); font-weight: 300; font-size: 1rem; }
.report-guide-name { font-weight: 600; color: var(--text); }
.report-guide-note {
  display: block; width: 100%;
  font-size: 0.72rem; color: var(--text-3); font-style: italic;
  padding-left: 28px; margin-top: 2px;
}

/* ══════════ BATCH MONTH NAV ══════════ */
.batch-nav {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px; margin-bottom: 16px;
  background: var(--card); border: 1px solid var(--line-light);
  border-radius: var(--r-lg); box-shadow: var(--shadow-xs);
}
.batch-month-pills {
  display: flex; gap: 4px; flex: 1; overflow-x: auto;
  scrollbar-width: none; padding: 2px 0;
}
.batch-month-pills::-webkit-scrollbar { display: none; }
.batch-pill {
  border: none; background: var(--bg-warm); color: var(--text-3);
  padding: 5px 12px; border-radius: 999px; font-size: 0.72rem;
  font-weight: 500; white-space: nowrap; cursor: pointer;
  transition: all 0.15s;
}
.batch-pill:hover { background: var(--accent-subtle); color: var(--accent); }
.batch-pill.active { background: var(--accent); color: #fff; font-weight: 600; box-shadow: 0 1px 4px rgba(45,74,62,.2); }
.batch-pill.empty { opacity: 0.4; cursor: not-allowed; }

/* ══════════ TRANSITIONS & MICRO-INTERACTIONS ══════════ */
.card { transition: box-shadow 0.2s, border-color 0.2s; }
.card:hover { box-shadow: var(--shadow-md); }
.upload-card:hover, .period-card:hover { border-color: var(--accent-muted); }
.tab-btn { transition: all 0.2s ease; }
.tab-btn.active { box-shadow: var(--shadow-sm); }
.kpi-card { transition: transform 0.15s ease, box-shadow 0.2s; }
.kpi-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); }
tbody tr { transition: background 0.1s; }
.btn { transition: all 0.2s ease; }
.btn-primary:active { transform: scale(0.98); }
.step-indicator { transition: all 0.25s ease; }
.file-item { transition: all 0.15s; }
.file-item:hover { border-color: var(--line); }
.tax-item { transition: background 0.15s; }
.tax-item:hover { background: var(--accent-subtle); }

/* ══════════ SCROLLBAR STYLING ══════════ */
.table-wrap::-webkit-scrollbar { height: 6px; }
.table-wrap::-webkit-scrollbar-track { background: var(--bg-warm); border-radius: 3px; }
.table-wrap::-webkit-scrollbar-thumb { background: var(--line); border-radius: 3px; }
.table-wrap::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* ══════════ RESPONSIVE ══════════ */
@media (max-width: 860px) {
  .upload-layout { grid-template-columns: 1fr; }
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .two-col { grid-template-columns: 1fr; }
  .dashboard-header { flex-direction: column; }
  .dashboard-actions { width: 100%; }
  .dashboard-actions .btn { flex: 1; }
  .step-actions .btn { width: 100%; }
  .review-header { flex-direction: column; gap: 10px; }
  .tab-bar { overflow-x: auto; scrollbar-width: none; }
  .tab-bar::-webkit-scrollbar { display: none; }
  .tab-btn { flex: none; }
}

@media (max-width: 480px) {
  .kpi-strip { grid-template-columns: 1fr; }
  .step-bar-inner { padding: 8px 12px; }
  .step-indicator { padding: 4px 8px; font-size: 0.7rem; }
  .app-shell { padding: 16px 12px 60px; }
}
