@layer components {
  .table-wrapper {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
  }

  .data-table thead {
    background-color: var(--color-ink-lightest);
    position: sticky;
    top: 0;
  }

  .data-table th {
    padding: var(--space-3) var(--space-4);
    text-align: left;
    font-size: var(--text-xs);
    font-weight: var(--font-semibold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-text-subtle);
    border-bottom: 1px solid var(--color-border);
    white-space: nowrap;
  }

  .data-table td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--color-border);
    color: var(--color-ink-darker);
    vertical-align: middle;
    font-size: var(--text-sm);
  }

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

  .data-table tbody tr {
    transition: background-color var(--transition-fast);
  }

  .data-table tbody tr:hover {
    background-color: var(--color-ink-lightest);
  }

  .data-table__actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    justify-content: flex-end;
    white-space: nowrap;
  }

  .data-table__num {
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: var(--font-medium);
    font-family: var(--font-mono);
  }

  .data-table--compact th,
  .data-table--compact td {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-x-small);
  }

}
