/* Pagination Component Styles */

/* Pagination container: centers and spaces the pagination block */
.pagination-container {
  margin-top: 2rem;
  padding: 1.5rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  background: rgb(var(--color-bg-primary));
  border-radius: 0.75rem;
  box-shadow: 0 2px 8px 0 rgba(0,0,0,0.04);
}

/* Info row: shows current page info */
.pagination-info-row {
  width: 100%;
  margin-bottom: 0.5rem;
  color: rgb(var(--color-text-secondary));
  font-size: 0.95rem;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
}

/* Buttons row: lays out the page buttons */
.pagination-buttons-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
}

/* Pagination button: base style */
.pagination-button {
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 0.75rem;
  background: transparent;
  color: rgb(var(--color-text-primary));
  border: 1px solid rgb(var(--color-border));
  border-radius: 0.5rem;
  font-size: 1rem;
  font-weight: 500;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  transition: 
    background 0.15s,
    color 0.15s,
    border-color 0.15s,
    box-shadow 0.15s;
  outline: none;
  user-select: none;
}

/* Active/current page button */
.pagination-button.active,
.pagination-button[aria-current="page"] {
  background: rgb(var(--color-primary));
  color: #fff;
  border-color: rgb(var(--color-primary));
  box-shadow: 0 0 0 2px rgba(var(--color-primary), 0.15);
  cursor: default;
  pointer-events: none;
}

/* Hover/focus states */
.pagination-button:not(.active):not([aria-current="page"]):hover,
.pagination-button:not(.active):not([aria-current="page"]):focus {
  background: rgb(var(--color-bg-tertiary));
  color: rgb(var(--color-primary));
  border-color: rgb(var(--color-primary));
  box-shadow: 0 0 0 2px rgba(var(--color-primary), 0.10);
}

/* Disabled state */
.pagination-button:disabled,
.pagination-button[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
  background: rgb(var(--color-bg-tertiary));
  color: rgb(var(--color-text-muted));
  border-color: rgb(var(--color-border));
}

/* Ellipsis for skipped pages */
.pagination-ellipsis {
  min-width: 2.25rem;
  height: 2.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
  color: rgb(var(--color-text-muted));
  font-size: 1rem;
  font-weight: 500;
}



  /* Info row: shows current page info */
  .pagination-info-row {
    width: 100%;
    margin-bottom: 0.5rem;
    color: rgb(var(--color-text-secondary));
    font-size: 0.95rem;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.5rem;
  }

  /* Buttons row: lays out the page buttons */
  .pagination-buttons-row {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.25rem;
    flex-wrap: wrap;
  }

  /* Pagination button: base style */
  .pagination-button {
    min-width: 2.25rem;
    height: 2.25rem;
    padding: 0 0.75rem;
    background: transparent;
    color: rgb(var(--color-text-primary));
    border: 1px solid rgb(var(--color-border));
    border-radius: 0.5rem;
    font-size: 1rem;
    font-weight: 500;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: 
      background 0.15s,
      color 0.15s,
      border-color 0.15s,
      box-shadow 0.15s;
    outline: none;
    user-select: none;
  }

  /* Active/current page button */
  .pagination-button.active,
  .pagination-button[aria-current="page"] {
    background: rgb(var(--color-primary));
    color: #fff;
    border-color: rgb(var(--color-primary));
    box-shadow: 0 0 0 2px rgba(var(--color-primary), 0.15);
    cursor: default;
    pointer-events: none;
  }

  /* Hover/focus states */
  .pagination-button:not(.active):not([aria-current="page"]):hover,
  .pagination-button:not(.active):not([aria-current="page"]):focus {
    background: rgb(var(--color-bg-tertiary));
    color: rgb(var(--color-primary));
    border-color: rgb(var(--color-primary));
    box-shadow: 0 0 0 2px rgba(var(--color-primary), 0.10);
  }

  /* Disabled state */
  .pagination-button:disabled,
  .pagination-button[aria-disabled="true"] {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
    background: rgb(var(--color-bg-tertiary));
    color: rgb(var(--color-text-muted));
    border-color: rgb(var(--color-border));
  }
