/* =============================================
   Pagination Component — UI-0083
   ============================================= */

/* --- Pagination Wrapper --- */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  flex-wrap: wrap;
  font-family: var(--font-sans);
}

/* --- Page Button (shared) --- */
.pagination__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  font-size: var(--text-sm); /* 14px */
  font-weight: var(--font-medium);
  color: var(--text-secondary, #4A5568);
  background-color: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: background-color var(--duration-fast) var(--ease-default),
              color var(--duration-fast) var(--ease-default),
              border-color var(--duration-fast) var(--ease-default);
  white-space: nowrap;
}

.pagination__btn:hover:not(:disabled):not(.is-active) {
  background-color: var(--bg-subtle, #F7F8FA);
  border-color: var(--border-default, #E2E8F0);
}

/* --- Active Page --- */
.pagination__btn.is-active {
  background-color: var(--color-electric, #2F80ED);
  color: var(--color-white, #FFFFFF);
  border-color: var(--color-electric, #2F80ED);
  cursor: default;
}

/* --- Disabled State --- */
.pagination__btn:disabled,
.pagination__btn.is-disabled {
  color: var(--text-muted, #B0BAC5);
  cursor: not-allowed;
  pointer-events: none;
}

/* --- Prev / Next Buttons (wider for icon+text) --- */
.pagination__btn--prev,
.pagination__btn--next {
  width: auto;
  padding: 0 var(--space-3);
  gap: var(--space-2);
  border: 1px solid var(--border-default, #E2E8F0);
}

.pagination__btn--prev svg,
.pagination__btn--next svg {
  width: var(--icon-xs);
  height: var(--icon-xs);
  stroke: currentColor;
  fill: none;
}

.pagination__btn--prev:hover:not(:disabled),
.pagination__btn--next:hover:not(:disabled) {
  background-color: var(--bg-subtle, #F7F8FA);
  color: var(--text-primary, #111111);
}

/* --- Ellipsis --- */
.pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  font-size: var(--text-sm);
  color: var(--text-muted, #B0BAC5);
  cursor: default;
  user-select: none;
}

/* --- Page Info Text --- */
.pagination__info {
  font-size: var(--text-sm);
  color: var(--text-muted, #B0BAC5);
  padding: 0 var(--space-2);
  white-space: nowrap;
}

/* --- Full Pagination Row (with info + controls) --- */
.pagination-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  padding: var(--space-4) 0;
}

.pagination-row__info {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--text-secondary, #64748b);
}

.pagination-row__info strong {
  color: var(--text-primary, #111111);
  font-weight: var(--font-semibold);
}

/* --- Per-page selector --- */
.pagination__per-page {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-secondary, #64748b);
  font-size: var(--text-sm);
}

.pagination__per-page select {
  padding: 4px 8px;
  border: 1px solid var(--border-default, #e2e8f0);
  border-radius: var(--radius-md);
  background: var(--color-white, #fff);
  font-size: var(--text-sm);
  color: var(--text-primary, #111111);
  cursor: pointer;
  transition: border-color var(--duration-fast) var(--ease-default);
}

.pagination__per-page select:hover {
  border-color: var(--border-strong, #cbd5e1);
}

.pagination__per-page select:focus {
  outline: none;
  border-color: var(--color-electric, #2F80ED);
  box-shadow: 0 0 0 3px rgba(47, 128, 237, 0.1);
}

/* --- Responsive --- */
@media (max-width: 640px) {
  .pagination-row {
    flex-direction: column;
    gap: var(--space-3);
    text-align: center;
  }

  .pagination {
    flex-wrap: wrap;
  }

  .pagination__btn--prev,
  .pagination__btn--next {
    flex: 1;
    min-width: 100px;
  }
}
