/* ============================================================
   PAGINATION — prev/next + page indicator
   Lives at the bottom of paginated tables.
   ============================================================ */

.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--border-subtle);
  flex-wrap: wrap;
}

.pagination__info {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

.pagination__info .numeric {
  color: var(--text-secondary);
  font-weight: var(--weight-medium);
}

.pagination__controls {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.pagination__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-strong);
  background: var(--bg-surface);
  color: var(--text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast);
  font-family: inherit;
  text-decoration: none;
}

.pagination__btn:hover:not(:disabled) {
  background: var(--bg-subtle);
  color: var(--text-primary);
}

.pagination__btn:disabled,
.pagination__btn[aria-disabled="true"] {
  opacity: 0.4;
  cursor: not-allowed;
}

.pagination__btn svg {
  width: 14px;
  height: 14px;
  stroke-width: 2;
}

.pagination__btn--current {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--text-on-primary);
  font-weight: var(--weight-semibold);
}

.pagination__btn--current:hover:not(:disabled) {
  background: var(--color-primary-hover);
  color: var(--text-on-primary);
}

.pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}
