/* ========== MOBILE TABLES — Universal Pattern (v1.5.68) ==========
 *
 * Estratégia em 3 camadas:
 *
 * 1. DESKTOP / TABLET (≥768px):
 *    - Sticky thead (fica visível no scroll vertical)
 *    - Scroll horizontal SE necessário, com fade gradient à direita
 *      indicando "tem mais pra ver"
 *    - Touch momentum (-webkit-overflow-scrolling)
 *    - A11y: tabindex=0 no wrap (scroll horizontal navegável por teclado)
 *
 * 2. MOBILE (<768px):
 *    - Cada <tr> vira um CARD empilhado (grid label/valor verticalizado)
 *    - <thead> visualmente escondido (mas screen-readers leem via off-screen)
 *    - Primeira <td> vira o "título" do card, full-width, destaque
 *    - Demais <td> usam atributo data-label="X" pra mostrar a coluna
 *    - Touch targets ≥44px em rows clicáveis e botões "Mostrar mais"
 *
 * 3. JS contract:
 *    - Cada <td> precisa ter `data-label="..."` (= o header equivalente)
 *    - Wrap precisa ter `role="region"`, `tabindex="0"`, `aria-label="..."`
 *    - <th> precisa ter `scope="col"` (a11y)
 *
 * Aplicado a 6 tabelas:
 *   Dashboard: SCKs, Ofertas, Eventos Recentes
 *   Quiz Analytics: UTM, Sessões, Vendas
 */

/* --- Desktop/Tablet — affordance + sticky --- */
.dash2-table-wrap,
.qa-table-wrap {
  position: relative;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
  overflow-x: auto;
}

/* Fade gradient à direita: indica que tem mais coluna. NÃO mostra se não tem
   overflow (CSS não detecta isso, então usamos um pseudo "sticky" que só
   aparece quando há scroll real — funciona em Chrome/Safari/Firefox). */
.dash2-table-wrap::after,
.qa-table-wrap::after {
  content: "";
  position: sticky;
  right: 0;
  top: 0;
  bottom: 0;
  width: 28px;
  margin-left: -28px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(0, 0, 0, 0.06));
  display: block;
  align-self: stretch;
  flex-shrink: 0;
}

/* Sticky header (só desktop). Mobile o thead é off-screen. */
@media (min-width: 768px) {
  .dash2-table thead th,
  .qa-table thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--bg-card, #fff);
  }
}

/* Focus visible no wrap (keyboard scroll). */
.dash2-table-wrap:focus-visible,
.qa-table-wrap:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 12px;
}

/* Touch min height em rows. */
.dash2-table tbody tr,
.qa-table tbody tr {
  min-height: var(--tap-target);
}

/* --- MOBILE: Card stack (<768px) --- */
@media (max-width: 767px) {
  /* Wrap: remove tabela visual, vira container de cards */
  .dash2-table-wrap,
  .qa-table-wrap {
    overflow: visible;
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
  }
  .dash2-table-wrap::after,
  .qa-table-wrap::after {
    display: none;
  }

  /* Tabela vira block container */
  .dash2-table,
  .qa-table {
    display: block;
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
  }

  /* Header off-screen (não visível mas screen-reader lê) */
  .dash2-table thead,
  .qa-table thead {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
  }

  .dash2-table tbody,
  .qa-table tbody {
    display: block;
  }

  /* Cada row vira um CARD */
  .dash2-table tr,
  .qa-table tr {
    display: grid;
    grid-template-columns: minmax(0, 42%) minmax(0, 1fr);
    gap: 6px 12px;
    padding: 12px 14px;
    margin: 0 0 10px;
    background: var(--bg-card, #fff);
    border: 1px solid var(--border, #e9ecef);
    border-radius: 12px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
    /* permite tap em row inteira ser confortável */
    min-height: var(--tap-target);
  }

  /* Hover/zebra desabilitados em card mode (não fazem sentido) */
  .dash2-table tbody tr:nth-child(even),
  .qa-table tbody tr:nth-child(even),
  .qa-table tr:hover,
  .dash2-table tr:hover {
    background: var(--bg-card, #fff);
  }

  /* Cells: cada uma é um par (label, valor) — display contents permite
     que o grid template tr defina o layout direto sobre as TDs */
  .dash2-table td,
  .qa-table td {
    display: contents;
  }

  /* Pseudo "label" usando data-label do <td> */
  .dash2-table td::before,
  .qa-table td::before {
    content: attr(data-label);
    color: var(--text-secondary, #64748b);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: var(--ls-caps, 0.04em);
    align-self: center;
    line-height: 1.3;
  }

  /* Valor da cell: alinhado à direita, padding zero (já está no tr) */
  .dash2-table td > *,
  .qa-table td > *,
  .dash2-table td:not(:has(> *)),
  .qa-table td:not(:has(> *)) {
    text-align: right;
  }

  /* Primeira cell vira "título" do card — full width, sem label */
  .dash2-table tr td:first-child,
  .qa-table tr td:first-child {
    grid-column: 1 / -1;
    border-bottom: 1px solid var(--border-light, #f1f5f9);
    padding-bottom: 10px;
    margin-bottom: 4px;
    text-align: left;
  }
  .dash2-table tr td:first-child::before,
  .qa-table tr td:first-child::before {
    display: none;
  }
  .dash2-table tr td:first-child {
    font-size: var(--font-md, 14px);
    font-weight: 600;
    color: var(--text, #1A1A2E);
    white-space: normal;
    line-height: 1.35;
  }

  /* Quebra de SCK longo no mobile (era nowrap+ellipsis no desktop) */
  .dash2-td-name,
  .qa-truncate {
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    display: block !important;
  }

  /* Valores numéricos (Total, Aprov, Revenue): alinhados à direita */
  .dash2-cell-ok,
  .dash2-cell-warn,
  .dash2-cell-bad {
    text-align: right;
    font-weight: 500;
  }

  /* Botões dentro de td (ex: "Ver →" em sessões): full-width, tap-friendly */
  .qa-table td button,
  .dash2-table td button,
  .qa-btn-link,
  .dash2-btn-link {
    width: 100%;
    min-height: var(--tap-target);
    padding: 12px 16px;
    border-radius: 8px;
    font-size: var(--font-base, 14px);
  }
}
