/**
 * Polo Exchange — Professional data tables (app shell + dashboard)
 */

.app-main,
.dash-root {
  --tbl-radius: var(--eui-radius, 12px);
  --tbl-header-bg: var(--eui-surface-muted, #f8fafc);
  --tbl-row-alt: color-mix(in srgb, var(--eui-surface-muted, #f8fafc) 55%, var(--eui-surface, #fff));
  --tbl-row-hover: color-mix(in srgb, var(--eui-accent, #4f46e5) 7%, var(--eui-surface, #fff));
  --tbl-accent-bar: var(--eui-accent, #4f46e5);
  --tbl-scrollbar: color-mix(in srgb, var(--eui-text-tertiary, #94a3b8) 55%, transparent);
}

body.theme-dark .app-main,
body.dark .app-main,
body.theme-dark .dash-root,
body.dark .dash-root {
  --tbl-row-alt: color-mix(in srgb, var(--eui-surface-muted) 70%, transparent);
  --tbl-row-hover: color-mix(in srgb, var(--eui-accent, #6366f1) 14%, transparent);
}

/* ── Scrollable table shell ─────────────────────────────────── */
.app-main .table-wrap,
.dash-root .dash-panel__table-wrap {
  width: 100%;
  overflow: auto;
  border-radius: var(--tbl-radius);
  border: 1px solid var(--eui-border);
  background: var(--eui-surface);
  box-shadow:
    var(--eui-shadow-xs, 0 1px 2px rgba(15, 23, 42, 0.04)),
    inset 0 1px 0 color-mix(in srgb, #fff 65%, transparent);
  transition:
    box-shadow 0.22s var(--eui-ease, ease),
    border-color 0.22s ease;
  scrollbar-width: thin;
  scrollbar-color: var(--tbl-scrollbar) transparent;
  -webkit-overflow-scrolling: touch;
}

.app-main .table-wrap:hover,
.dash-root .dash-panel__table-wrap:hover {
  box-shadow: var(--eui-shadow-sm, 0 4px 12px -4px rgba(15, 23, 42, 0.08));
}

.app-main .table-wrap:focus-within,
.dash-root .dash-panel__table-wrap:focus-within {
  border-color: color-mix(in srgb, var(--eui-accent) 35%, var(--eui-border));
}

.app-main .table-wrap::-webkit-scrollbar,
.dash-root .dash-panel__table-wrap::-webkit-scrollbar {
  height: 8px;
  width: 8px;
}

.app-main .table-wrap::-webkit-scrollbar-thumb,
.dash-root .dash-panel__table-wrap::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: var(--tbl-scrollbar);
}

body.app-has-custom-bg .app-main .table-wrap,
body.app-has-custom-bg .dash-root .dash-panel__table-wrap {
  background: color-mix(in srgb, var(--eui-surface) 88%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Tall / report tables (screen-only scroll; preview/print documents expand fully) */
@media screen {
  .app-main .tx-reports-table-wrap,
  .app-main .safe-profit-table-wrap,
  .app-main .safe-vault-profit-table-wrap {
    max-height: min(70vh, 720px);
  }

  .app-main .tx-reports-preview .tx-reports-table-wrap,
  .app-main .tx-reports-print-document .tx-reports-table-wrap,
  .app-main .tx-reports-preview-overlay__paper .tx-reports-table-wrap {
    max-height: none;
    overflow-y: visible;
  }
}

.app-main .tx-reports-table-wrap:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--eui-accent) 45%, transparent);
  outline-offset: 2px;
}

/* ── Core data tables ───────────────────────────────────────── */
.app-main .data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  font-family: var(--eui-font, inherit);
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  font-variant-numeric: tabular-nums;
}

.app-main .data-table thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  padding: 0.8rem 1rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.065em;
  text-transform: uppercase;
  color: var(--eui-text-secondary);
  text-align: left;
  vertical-align: middle;
  white-space: nowrap;
  background: var(--tbl-header-bg);
  border-bottom: 1px solid var(--eui-border);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--eui-border) 75%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.app-main .data-table td {
  padding: 0.72rem 1rem;
  font-size: 0.875rem;
  line-height: 1.4;
  color: var(--eui-text);
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid color-mix(in srgb, var(--eui-border) 65%, transparent);
  transition:
    background-color 0.16s ease,
    color 0.16s ease,
    box-shadow 0.16s ease;
}

.app-main .data-table tbody tr {
  transition: background-color 0.16s ease;
}

.app-main .data-table tbody tr:nth-child(even) td {
  background: var(--tbl-row-alt);
}

.app-main .data-table tbody tr:hover td {
  background: var(--tbl-row-hover);
}

.app-main .data-table tbody tr:hover td:first-child {
  box-shadow: inset 3px 0 0 var(--tbl-accent-bar);
}

.app-main .data-table tbody tr:last-child td {
  border-bottom: none;
}

.app-main .data-table tbody tr:only-child td {
  border-bottom: none;
}

/* Numeric / amount emphasis */
.app-main .data-table th.num,
.app-main .data-table td.num,
.app-main .data-table .col-num {
  text-align: right;
}

.app-main .data-table td:has(.rate-buy),
.app-main .data-table td:has(.rate-sell),
.app-main .data-table td:has(.profit-value-badge),
.app-main .data-table td:has(.is-profit),
.app-main .data-table td:has(.is-strong) {
  font-variant-numeric: tabular-nums;
}

.app-main .data-table .rate-buy {
  color: var(--eui-success, #059669);
  font-weight: 600;
}

.app-main .data-table .rate-sell {
  color: #6d28d9;
  font-weight: 600;
}

body.theme-dark .app-main .data-table .rate-sell,
.dark .app-main .data-table .rate-sell {
  color: #c4b5fd;
}

/* Row states */
.app-main .data-table tbody tr.row-edited td {
  background: color-mix(in srgb, var(--eui-warning, #d97706) 12%, var(--eui-surface)) !important;
}

.app-main .data-table tbody tr.row-deleted td {
  background: color-mix(in srgb, var(--eui-danger, #dc2626) 10%, var(--eui-surface)) !important;
  color: color-mix(in srgb, var(--eui-danger) 75%, var(--eui-text));
  text-decoration: line-through;
  opacity: 0.92;
}

.app-main .data-table tbody tr.row-deleted:hover td {
  background: color-mix(in srgb, var(--eui-danger) 16%, var(--eui-surface)) !important;
}

/* Empty / placeholder rows */
.app-main .data-table tbody tr.is-empty td,
.app-main .data-table tbody tr td.empty-cell {
  padding: 1.35rem 1rem;
  text-align: center;
  color: var(--eui-text-tertiary);
  font-size: 0.8125rem;
  font-weight: 500;
  background: transparent !important;
  box-shadow: none !important;
}

/* Badges & pills inside tables */
.app-main .data-table .badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid color-mix(in srgb, currentColor 18%, transparent);
  line-height: 1.25;
}

.app-main .data-table .tx-reports-ref {
  display: inline-block;
  padding: 0.15rem 0.45rem;
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--eui-text-secondary);
  background: color-mix(in srgb, var(--eui-surface-muted) 80%, var(--eui-surface));
  border: 1px solid color-mix(in srgb, var(--eui-border) 90%, transparent);
}

.app-main .data-table .tx-reports-type {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.5rem;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.app-main .data-table .tx-reports-type--buy {
  color: #047857;
  background: color-mix(in srgb, #10b981 14%, transparent);
  border-color: color-mix(in srgb, #10b981 28%, transparent);
}

.app-main .data-table .tx-reports-type--sell {
  color: #5b21b6;
  background: color-mix(in srgb, #8b5cf6 14%, transparent);
  border-color: color-mix(in srgb, #8b5cf6 28%, transparent);
}

.app-main .data-table .tx-reports-status {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.45rem;
  border-radius: 6px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.app-main .data-table .tx-reports-status--active {
  color: #047857;
  background: color-mix(in srgb, #10b981 12%, transparent);
}

.app-main .data-table .tx-reports-status--edited {
  color: #b45309;
  background: color-mix(in srgb, #f59e0b 14%, transparent);
}

.app-main .data-table .tx-reports-status--deleted {
  color: #b91c1c;
  background: color-mix(in srgb, #ef4444 12%, transparent);
}

.app-main .data-table a.tx-reports-invoice-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.65rem;
  padding: 0.25rem 0.55rem;
  border-radius: 6px;
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1.2;
  color: #1d4ed8;
  background: #eff6ff;
  border: 1px solid color-mix(in srgb, #93c5fd 95%, transparent);
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}

.app-main .data-table a.tx-reports-invoice-link:hover {
  color: #1e3a8a;
  background: #dbeafe;
  border-color: #93c5fd;
}

body.theme-dark .app-main .data-table a.tx-reports-invoice-link,
.dark .app-main .data-table a.tx-reports-invoice-link {
  color: #93c5fd;
  background: rgba(30, 58, 138, 0.35);
  border-color: rgba(59, 130, 246, 0.45);
}

body.theme-dark .app-main .data-table a.tx-reports-invoice-link:hover,
.dark .app-main .data-table a.tx-reports-invoice-link:hover {
  color: #bfdbfe;
  background: rgba(30, 58, 138, 0.55);
}

/* Profit / expenditure badges */
.app-main .data-table .profit-type-badge,
.app-main .data-table .profit-value-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0.24rem 0.56rem;
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
}

/* Inline actions in table cells */
.app-main .data-table .table-actions,
.app-main .data-table .mini-inline-action {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
}

.app-main .data-table .btn,
.app-main .data-table .btn-sm,
.app-main .data-table button {
  border-radius: 8px;
}

/* Currency table */
.app-main .data-table.currency-table thead th {
  white-space: nowrap;
}

.app-main .data-table.currency-table .currency-rate-col-badge {
  margin-left: 0.25rem;
}

/* Audit log table */
.app-main .data-table.audit-log-table tbody tr:nth-child(even) td {
  background: var(--tbl-row-alt);
}

.app-main .data-table.audit-log-table code {
  font-size: 0.78rem;
  padding: 0.12rem 0.35rem;
  border-radius: 5px;
  background: color-mix(in srgb, var(--eui-surface-muted) 90%, transparent);
  border: 1px solid color-mix(in srgb, var(--eui-border) 80%, transparent);
}

/* Row flash (live updates) */
.app-main .data-table tbody tr.eui-row-flash td {
  animation: app-tbl-row-flash 0.65s ease;
}

@keyframes app-tbl-row-flash {
  0% {
    background: color-mix(in srgb, var(--eui-accent) 22%, transparent);
  }
  100% {
    background: inherit;
  }
}

/* ── Dashboard tables (align with data-table look) ──────────── */
.dash-root .dash-panel__table-wrap {
  border-radius: var(--tbl-radius);
  border: 1px solid var(--eui-border);
  background: var(--eui-surface);
  box-shadow: var(--eui-shadow-xs);
}

.dash-root .dash-table,
.dash-root .dash-panel__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  text-align: left;
  font-size: 0.875rem;
  font-family: var(--eui-font, inherit);
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  font-variant-numeric: tabular-nums;
}

.dash-root .dash-table thead,
.dash-root .dash-panel__table thead {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.065em;
  text-transform: uppercase;
}

.dash-root .dash-table thead th,
.dash-root .dash-panel__table th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 0.8rem 1rem;
  color: var(--eui-text-secondary);
  background: var(--tbl-header-bg);
  border-bottom: 1px solid var(--eui-border);
  backdrop-filter: blur(10px);
}

.dash-root .dash-table td,
.dash-root .dash-panel__table td {
  padding: 0.72rem 1rem;
  color: var(--eui-text);
  border-bottom: 1px solid color-mix(in srgb, var(--eui-border) 65%, transparent);
  transition: background-color 0.16s ease;
}

.dash-root .dash-table tbody tr:nth-child(even) td,
.dash-root .dash-panel__table tbody tr:nth-child(even) td {
  background: var(--tbl-row-alt);
}

.dash-root .dash-table tbody tr:hover td,
.dash-root .dash-panel__table tbody tr:hover td {
  background: var(--tbl-row-hover);
}

.dash-root .dash-table tbody tr:hover td:first-child,
.dash-root .dash-panel__table tbody tr:hover td:first-child {
  box-shadow: inset 3px 0 0 var(--tbl-accent-bar);
}

.dash-root .dash-panel__table .is-strong {
  color: var(--eui-text);
  font-weight: 600;
}

.dash-root .dash-panel__table .is-profit {
  color: var(--eui-success);
  font-weight: 600;
}

/* Cards that embed tables — soften double borders */
.app-main .card > .table-wrap:first-child,
.app-main .card > .table-wrap:last-child {
  margin-top: 0.15rem;
}

.app-main .profit-table-wrap {
  padding: 0.25rem;
  border: 1px solid var(--eui-border);
  border-radius: var(--tbl-radius);
  background: color-mix(in srgb, var(--eui-surface) 92%, var(--eui-surface-muted));
}

.app-main .profit-data-table {
  border: none;
  border-radius: calc(var(--tbl-radius) - 4px);
  overflow: hidden;
}

@media (max-width: 640px) {
  .app-main .data-table thead th,
  .app-main .data-table td,
  .dash-root .dash-table th,
  .dash-root .dash-table td,
  .dash-root .dash-panel__table th,
  .dash-root .dash-panel__table td {
    padding: 0.62rem 0.75rem;
    font-size: 0.8125rem;
  }

  .app-main .data-table thead th {
    font-size: 0.625rem;
  }
}
